假设项目中有两个软件包:some_package
和another_package
。
# some_package/foo.py:
def bar():
print('hello')
# another_package/function.py
from some_package.foo import bar
def call_bar():
# ... code ...
bar()
# ... code ...
我想测试another_package.function.call_bar
来模拟some_package.foo.bar
,因为它具有一些我想避免的网络I / O。
这是一个测试:
# tests/test_bar.py
from another_package.function import call_bar
def test_bar(monkeypatch):
monkeypatch.setattr('some_package.foo.bar', lambda: print('patched'))
call_bar()
assert True
令我惊讶的是,它输出hello
而不是patched
。我尝试调试该东西,将IPDB断点置于测试中。当我在断点之后手动导入some_package.foo.bar
并调用bar()
时,我得到patched
。
在我的实际项目中,情况更加有趣。如果我在项目根目录中调用pytest,则不会修补我的函数,但是当我将tests/test_bar.py
指定为参数时,它将起作用。
据我了解,它与from some_package.foo import bar
语句有关。如果它是在进行monkeypatching之前执行的,则修补将失败。但是,在上述示例的压缩测试设置中,修补在两种情况下均不起作用。
为何在达到断点后仍可在IPDB REPL中使用?
参考方案
命名导入为对象创建一个新名称。如果您随后替换对象的旧名称,则新名称不受影响。
导入模块,并使用module.bar
代替。那将始终使用当前对象。
编辑:
import module
def func_under_test():
module.foo()
def test_func():
monkeypatch.setattr(...)
func_under_test
pytest-在所有其他测试之后重新运行失败的测试 - python在我的场景中,我有一个写入文件的测试,还有一个(但可能还有更多)要读取该文件的测试。我不能简单地提取将文件写入功能/夹具的过程,因为它涉及其他一些夹具,这些夹具在内部启动其他二进制文件,而该二进制文件则写入该文件。所以我有一个固定装置,可以检查文件是否已经存在。到目前为止我尝试过的是:flaky和pytest-rerunfailures插件-不适合,因为它们…
Python GPU资源利用 - python我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…
重用现有的上下文管理器作为pytest固定装置 - python我有多个测试所需的现有上下文管理器。与其在每个测试中编写一个with块,不如在此上下文管理器中制作一个固定装置,并用@pytest.mark.usefixtures("my_fixture")装饰测试会更好。我可以将上下文管理器重新实现为一种固定装置,但这似乎是在重复代码。所以我想在新的夹具中引用原始的上下文管理器。这就是我所拥有的:im…
针对多个数据库版本运行pytest测试套件 - python我构建了一个在后端使用数据库的应用程序。对于集成测试,我在Docker中启动数据库并使用pytest运行测试套件。我在autouse=True中使用了会话作用域的夹具来启动Docker容器:@pytest.fixture(scope='session', autouse=True) def run_database(): # setup …
Python:图像处理可产生皱纹纸效果 - python也许很难描述我的问题。我正在寻找Python中的算法,以在带有某些文本的白色图像上创建皱纹纸效果。我的第一个尝试是在带有文字的图像上添加一些真实的皱纹纸图像(具有透明度)。看起来不错,但副作用是文本没有真正起皱。所以我正在寻找更好的解决方案,有什么想法吗?谢谢 参考方案 除了使用透明性之外,假设您有两张相同尺寸的图像,一张在皱纹纸上明亮,一张在白色背景上有深…