我注意到类方法被正确地模拟了,但是该函数绕过了mock并运行了实际的函数。
from module1 import myClass
from module2 import my_function
import unittest
from mock import patch
class TestStuff(unittest.TestCase):
@patch('module2.my_function')
@patch('module1.myClass.my_method')
def test_my_function(self, mock_method, mock_function):
test_obj = myClass()
test_obj.my_method()
assert mock_method.called
my_function()
assert mock_function.called
如果我打印出my_function()并输入(my_function),它将不会显示模拟,而是显示真实的功能。我导入一个类然后嘲笑一个方法,但我直接导入该函数是否重要?
答案 0 :(得分:1)
我遇到了类似的问题。结果我需要给它my_function的完整路径:
@patch(' home.myuser.myprojects.mymodule.myfunc&#39)
答案 1 :(得分:1)
我想我发现了这个问题: 当我测试一个函数,并且我想要模拟它时,我不应该导入它。导入它会导致它被使用,即使我已经放置了补丁装饰器。 我认为这是关于模拟/测试如何工作的一般混淆。我想要做的是在不实际查询数据库的情况下测试函数。我没有嘲笑整个函数,而是采用实际命中db - query.all()的行 - 并将其作为自己的函数,然后将其模拟出来。
from module1 import myClass
from module2 import my_function
import unittest
from mock import patch
class TestStuff(unittest.TestCase):
@patch('module2.db_query')
@patch('module1.myClass.my_method')
def test_my_function(self, mock_method, mock_db_query):
test_obj = myClass()
test_obj.my_method()
assert mock_method.called
my_function() # my_function calls db_query(), now mocked out
assert mock_db_query.called
如果我想要实际模拟my_function的全部内容,我可能只是没有导入它。至少我是如何理解这一点的。