我有以下功能要测试:
my_package.db_engine.db_functions.py:
from ..utils import execute_cmd
from my_package.db_engine.db_functions import dbinfo
def dbinfo(db_name):
params = (cmd_cfg.DB, add_pj_suffix(db_name))
cmd = get_db_cmd_string(cmd_cfg.DBINFO, params=params)
cmd_result = execute_cmd(cmd)
result_dict = map_cmd_output_to_dict(cmd_result)
return result_dict
该函数获取数据库的名称,然后从中构建命令字符串并执行该命令:subprocess
与execute_cmd
方法。
我想测试这个功能而不实际执行subprocess
。我只想检查命令是否正确构建并正确传递给execute_cmd
。因此我需要嘲笑execute_cmd
从模块导入的方法utils
.
我的文件夹结构如下:
my_project
|_src
| |_my_package
| | |_db_engine
| | | |_db_functions.py
| | | |_ __init__.py
| | |_utils.py
| | |_ __init__.py
| | |_ ....
| |_ __init__.py
|_tests
|_test_db_engine.py
因此,对于我的测试,我尝试了以下内容test_db_engine.py
:
import unittest
from mock import patch
from my_package.db_engine.db_functions import dbinfo
def execute_db_info_cmd_mock():
return {
'Last Checkpoint': '1.7',
'Last Checkpoint Date': 'May 20, 2015 10:07:41 AM'
}
class DBEngineTestSuite(unittest.TestCase):
""" Tests für DB Engine"""
@patch('my_package.utils.execute_cmd')
def test_dbinfo(self, test_patch):
test_patch.return_value = execute_db_info_cmd_mock()
db_info = dbinfo('MyDBNameHere')
self.assertEqual(sandbox_info['Last Checkpoint'], '1.7')
实际命令的执行会产生1.6
for Last Checkpoint
。因此,为了验证是否使用了模拟返回值,我将其设置为1.7
。
但是没有使用该函数的模拟,因为测试用例的执行仍然会产生1.6
因为它正在执行应该用模拟修补的实际函数。
知道我在这里做错了什么吗?