gpt4 book ai didi

python - 在python中模拟文件对象或iterables

转载 作者:太空狗 更新时间:2023-10-29 17:30:28 26 4
gpt4 key购买 nike

哪种方式适合模拟和测试由 open() 返回的迭代对象的代码, 使用 mock图书馆?

whitelist_data.py:

WHITELIST_FILE = "testdata.txt"

format_str = lambda s: s.rstrip().lstrip('www.')
whitelist = None

with open(WHITELIST_FILE) as whitelist_data:
whitelist = set(format_str(line) for line in whitelist_data)

if not whitelist:
raise RuntimeError("Can't read data from %s file" % WHITELIST_FILE)

def is_whitelisted(substr):
return 1 if format_str(substr) in whitelist else 0

这是我尝试测试它的方法。

import unittest
import mock

TEST_DATA = """
domain1.com
domain2.com
domain3.com
"""

class TestCheckerFunctions(unittest.TestCase):

def test_is_whitelisted_method(self):
open_mock = mock.MagicMock()
with mock.patch('__builtin__.open',open_mock):
manager = open_mock.return_value.__enter__.return_value
manager.__iter__ = lambda s: iter(TEST_DATA.splitlines())
from whitelist_data import is_whitelisted
self.assertTrue(is_whitelisted('domain1.com'))

if __name__ == '__main__':
unittest.main()

python tests.py 的结果是:

$ python tests.py

E
======================================================================
ERROR: test_is_whitelisted_method (__main__.TestCheckerFunctions)
----------------------------------------------------------------------
Traceback (most recent call last):
File "tests.py", line 39, in test_is_whitelisted_method
from whitelist_data import is_whitelisted
File "/Users/supa/Devel/python/whitelist/whitelist_data.py", line 20, in <module>
whitelist = set(format_str(line) for line in whitelist_data)
TypeError: 'Mock' object is not iterable

----------------------------------------------------------------------
Ran 1 test in 0.001s

UPD:感谢 Adam,我重新安装了模拟库(pip install -e hg+https://code.google.com/p/mock#egg=mock) 并更新了 tests.py。就像一个魅力。

最佳答案

您正在寻找一个MagicMock。这支持迭代。

在 mock 0.80beta4 中,patch 返回一个 MagicMock。所以这个简单的例子有效:

import mock

def foo():
for line in open('myfile'):
print line

@mock.patch('__builtin__.open')
def test_foo(open_mock):
foo()
assert open_mock.called

如果您正在运行 mock 0.7.x(看起来您是),我认为您无法仅通过补丁来完成此任务。您需要单独创建模拟,然后将其传递到补丁中:

import mock

def foo():
for line in open('myfile'):
print line

def test_foo():
open_mock = mock.MagicMock()
with mock.patch('__builtin__.open', open_mock):
foo()
assert open_mock.called

注意 - 我已经使用 py.test 运行这些,但是,这些相同的方法也适用于 unittest。

关于python - 在python中模拟文件对象或iterables,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8166633/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com