- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 Python 中模拟具有副作用的实例方法。我希望/期望使用初始“self”参数来调用我的副作用,我可以用它来确定返回值。
所以我有这样的东西:
import mock
class TestCases(unittest.TestCase):
@mock.patch('Item.exists')
def test_foo(self, mock_item_exists):
def item_exists_side_effect(*args, **kwargs):
# I expect args[0] here to be supplied and to refer to the item
_self = args[0]
return _self.name == 'bar'
mock_item_exists.side_effect = item_exists_side_effect
...
但是,当调用 Item.exists() 时,我最终会进入副作用函数,但参数列表为空。
这是预期的吗?我做错了什么吗?
最佳答案
看起来原因是这样的:
Why does mock ignore the instance/object passed to a mocked out method when it is called?
即通过调用mock.patch,我将实例方法变成了类方法。
关于python - 使用 Mock.side_effect 作为实例方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32529934/
在装饰器中传递 side_effect 与在函数中设置有什么区别?我什么时候应该使用一个? @patch(“my_class.Order.get_order”, side_effect=“moc
在模拟中,我希望某个函数在测试中返回一个新值。我就是这样做的。 Class MyClass: my_var = None def foo(self, var1):
我在名为“my_module”的模块中的名为“my_class”的类中有一个函数,该模块包含以下代码段: try: response = self.make_request_response(re
mock.reset_mock() 不会重置副作用迭代器。有没有一种方法可以做到这一点而无需再次创建模拟? >>> from mock import MagicMock >>> mock = Magi
我有一个像下面这样的单元测试: # utilities.py def get_side_effects(): def side_effect_func3(self): # N
我正在尝试在 Python 中模拟具有副作用的实例方法。我希望/期望使用初始“self”参数来调用我的副作用,我可以用它来确定返回值。 所以我有这样的东西: import mock class T
我有这个类 Foo,它的函数使用我在其构造函数中初始化的数据帧。我想在我的测试类 FooTest 中测试它的功能。 from src.shared.utils import get_spark_dat
有没有办法在 side_effect 中使用 mock 临时撤消修补?特别是我想做这样的事情: from mock import patch import urllib2 import unittes
因此示例代码非常基础: @mock.patch.object(BookForm, 'is_valid') def test_edit(self, mocked_is_valid): creat
我正在使用 patch来自 unittest.mock在我的测试中更改远程 API 调用的行为。 我有三个不同的函数,它们返回三个不同的 json表示要从 API 返回的模拟数据的文件。对于每个模拟
是否可以有Mock对象在调用时返回一个值并在调用时执行一条语句?例如这个: > mocked_func = Mock(return_value='Returned foo',
我正在测试一个读取文件、对内容进行操作并根据所看到的内容返回一个值的函数。我测试的函数 testme 位于 module.py 中。我正在运行 python 2.7。我知道我可以用 import un
我必须说我是 python mock 的新手。我有一个side_effect 迭代器: myClass.do.side_effect = iter([processStatus, memoryStat
为了测试一个轮询函数,我想模拟一个子函数的调用,这样第一次调用它就会失败,第二次调用它就会成功。这是它的一个非常简化的版本: poll_function(var1): value = sub_
我正在尝试在 Python 类中练习以下方法: def find_tests(self): tests_dir = glob.glob("tests/*") if not tests_
from unittest.mock import patch def get_title(): return 'title' def get_msg(): return 'msg'
我是一名优秀的程序员,十分优秀!