修补时,顶级和本地导入这两种情况必须以不同的方式处理。您必须按照文档中或Ned
Batchelder的本博文中的描述对模块中使用的对象进行修补,后者将更详细地描述问题。
在第一种情况下,您需要在修补模块 后
z在运行时导入模块,以便导入修补后的模块。在第二种情况(顶级导入的更标准的情况)中,您 在 修补模块
之前先 导入模块,现在在模块中已有未修补的引用,因此要使修补起作用,您必须修补 此引用 :
z``b__
@patch('a.b.z')def test_do_stuff_with_patched_x_y_z(self, mocked_z): ...
总结一下:您始终必须检查要使用的对象如何在要测试的模块中导入。基本上有两种情况:
- 该对象的导入方式为
import x
或import x.y
(和使用方式类似x.y.z
)-在这种情况下,可以将其修补为x.y.z
。如果像在最初的情况那样在函数内部本地导入模块,也是如此。 - 像
from x.y import z
(或from .y import z
)一样导入对象-在这种情况下,将创建引用该对象的本地引用,并且应对该引用进行修补(例如,a.b.z
在您的情况下)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)