- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在装饰器中传递 side_effect 与在函数中设置有什么区别?我什么时候应该使用一个?
@patch(“my_class.Order.get_order”, side_effect=“mock_order”)
def test_order(self, mock_order):
@patch(“my_class.Order.get_order”)
def test_order(self, mock_order):
mock_order.side_effect = self.mock_order
最佳答案
除了设置副作用的时间外,没有区别。
在您的示例中,在测试函数的开头设置了副作用,这两个变体在语义上是可以互换的,并且使用哪个是品味问题(我会说装饰器最好地表明它是为了整个测试,但如果装饰器表达式太长,也会考虑可读性)。
原则上,在应用副作用时存在差异,因为装饰器在加载时创建修补对象,而在测试中分配副作用仅在运行时分配。尽管据我所知,这不会影响测试功能。
仅当在第一种方法中使用全局已知变量或函数作为副作用时,这才是正确的,因为类本身尚未定义,并且在加载时不存在类实例。如果您想使用类本身的属性或方法,则只有第二个变体才能工作。任何依赖于测试类本身的副作用都不会起作用。
如果您只想在测试的后期设置副作用,或者想在测试期间更改它,显然只能使用第二个变体。
总结一下:
关于python - 函数中的 side_effect 与装饰器中的 side_effect 之间的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61081807/
在装饰器中传递 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'
我是一名优秀的程序员,十分优秀!