我注意到类方法被正确地模拟出来了,但是函数绕过了模拟并运行了实际的函数。
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),它将不会显示模拟函数,而是显示真正的函数。我导入一个类,然后模拟一个方法,但是我直接导入函数,这有关系吗?
发布于 2015-11-10 09:23:02
我想我发现了问题所在:当我测试一个函数时,如果我想模拟一些东西,我就不应该导入它。导入它会导致使用它,即使我已经放置了补丁装饰器。我认为这是对mocking/ this如何工作的普遍困惑。我想要做的是在不实际查询数据库的情况下测试函数。而不是模拟整个函数,我可以选择实际命中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,我可以不导入它。至少我现在是这么理解的。
发布于 2015-11-10 08:09:24
我遇到了类似的问题。原来我需要给它提供my_function的完整路径:
@patch('home.myuser.myprojects.mymodule.myfunc')
https://stackoverflow.com/questions/33619976
复制相似问题