我正在使用具有 pytest 依赖关系的 pytest 开发功能测试套件。我 99% 都喜欢这些工具,但我不知道如何让一个文件中的测试依赖于另一个文件中的测试。理想情况下,我希望对依赖者进行零更改,并且只更改依赖者中的内容。我希望测试能够像这样依赖 test_one:
# contents of test_one.py
@pytest.mark.dependency()
def test_one():
# do stuff
@pytest.mark.dependency(depends=["test_one"])
def test_point_one():
# do stuff
像这样:
# contents of test_two.py
@pytest.mark.dependency(depends=["test_one"])
def test_two():
# do stuff
当我pytest test_one.py
正确运行它时,它会订购东西(test_point_one
如果test_one
失败则跳过),但是当我运行时pytest test_two.py
,它会跳过test_two
.
我尝试添加import test_one
到 test_two.py 无济于事,并验证了导入实际上是正确导入的——它不仅仅是被 pytest 忽略了“哦,嘿,我已经完成了收集测试,我什么都做不到”不要跳过!懒惰万岁!”
test_two()
我知道我可以在技术上投入test_one.py
并且它会起作用,但我不想只是将每个测试转储到一个文件中(这最终会演变成)。我试图通过将所有东西放在正确的架子上来保持物品整洁,而不仅仅是将它们全部推入壁橱。
此外,我意识到如果我能做到这一点,就会存在创建循环依赖的可能性。我没关系。如果我像那样朝自己的脚开枪,老实说,我活该。