pytest-在所有其他测试之后重新运行失败的测试 - python

在我的场景中,我有一个写入文件的测试,还有一个(但可能还有更多)要读取该文件的测试。我不能简单地提取将文件写入功能/夹具的过程,因为它涉及其他一些夹具,这些夹具在内部启动其他二进制文件,而该二进制文件则写入该文件。所以我有一个固定装置,可以检查文件是否已经存在。

到目前为止我尝试过的是:

flaky和pytest-rerunfailures插件-不适合,因为它们都会在失败时立即重新运行测试(当文件仍然不存在时),我想将其附加到测试队列的末尾。
手动修改测试队列,如下所示:

...

request.session.items.append(request.node)
pytest.xfail("file not present yet")

这种类型的作品,但是只有当我在单跑者上运行时(没有xdist或通过传递-n0 cli arg来打开它时,
在我的测试报告中,我看到这样的事情:

test_load_file_before_save xfail
test_save_file PASSED        
test_load_file PASSED        
test_load_file_before_save PASSED    

使用xdist运行时,不会重复执行xfailed测试。有人知道如何进行吗?用某种方法强制xdist刷新测试列表?

参考方案

您可以使用pytest.cache获取测试运行状态,并在失败的情况下将该测试附加到队列中。

if request.config.cache.get(request.node):
    request.session.items.append(request.node)
    pytest.xfail("file not present yet")

您还可以在pytest缓存中设置自定义值,以使用request.config.cache.set(data,val)在不同的运行中使用。

如果要写入测试目录中的文件,则可以使用pytest-xdist的--looponfail开关。它监视目录并重新运行测试,直到测试通过。
从文档:
distributed and subprocess testing:
-f, --looponfail run tests in subprocess, wait for modified files and
re-run failing test set until all pass.

可能有用的链接:Pytest-cache

作为一个友好的建议,如果您计划将其测试在并行线程中运行,我建议您使测试彼此独立。

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中的算法,以在带有某些文本的白色图像上创建皱纹纸效果。我的第一个尝试是在带有文字的图像上添加一些真实的皱纹纸图像(具有透明度)。看起来不错,但副作用是文本没有真正起皱。所以我正在寻找更好的解决方案,有什么想法吗?谢谢 参考方案 除了使用透明性之外,假设您有两张相同尺寸的图像,一张在皱纹纸上明亮,一张在白色背景上有深…

Python uuid4,如何限制唯一字符的长度 - python

在Python中,我正在使用uuid4()方法创建唯一的字符集。但是我找不到将其限制为10或8个字符的方法。有什么办法吗?uuid4()ffc69c1b-9d87-4c19-8dac-c09ca857e3fc谢谢。 参考方案 尝试:x = uuid4() str(x)[:8] 输出:"ffc69c1b" Is there a way to…