我正在尝试使用mock和@patch装饰器为Python应用程序构建测试.
给定以下目录结构:
|-- mypackage
| |-- mymodule
| | |-- __init__.py
| | \-- somefile.py
| \-- myothermodule
| |-- tests
| | |-- __init__.py
| | \-- test_func_to_test.py
| \-- __init__.py
\-- __init__.py
Run Code Online (Sandbox Code Playgroud)
文件内容如下:
#mypackage/mymodule/somefile.py
def some_function():
return 'A'
Run Code Online (Sandbox Code Playgroud)
#mypackage/myothermodule/__init__.py
from mypackage.mymodule.somefile import some_function
def func_to_test():
return some_function()
Run Code Online (Sandbox Code Playgroud)
#mypackage/myothermodule/tests/test_func_to_test.py
from unittest import TestCase
from mock import patch
class TestFunc_to_test(TestCase):
def test_func_to_test(self):
from mypackage.myothermodule import func_to_test
self.assertEqual('A', func_to_test())
@patch('mypackage.mymodule.somefile.some_function')
def test_func_to_test_mocked(self, some_mock_function):
from mypackage.myothermodule import func_to_test
some_mock_function.return_value = 'B'
self.assertEqual('B', func_to_test())
Run Code Online (Sandbox Code Playgroud)
我的问题是,虽然在第一测试通过(test_func_to_test),第二测试(test_func_to_test_mocked)没有(由于一个AssertionError).
我已经能够使用相同的方法从"内置"模块(例如,request.get)中模拟函数,但是当我尝试从我的一个函数中修补函数时,我似乎无法使@patch工作.模块...
任何帮助,将不胜感激 :)
eca*_*mur 16
mypackage.myothermodule已导入,因此该名称some_function已绑定在该模块中.您需要在调用它的模块中模拟该名称的用法:
@patch('mypackage.myothermodule.some_function')
Run Code Online (Sandbox Code Playgroud)
您也可以重新加载mypackage.myothermodule:
import mypackage.myothermodule
reload(mypackage.myothermodule)
Run Code Online (Sandbox Code Playgroud)