我正在编写一个pytest插件,以便在运行它们之前订购测试。我想要一个更好的方法为我的插件编写测试。
我正在使用pytest' pytest_collection_modifyitems
hook,然后根据某些标记就地修改items
。测试这个的最简单方法是获得pytest测试的输入列表,将它们传递给我的函数,并声明输出的顺序正确。
我无法收集或创建输入测试列表。输入测试的格式应与pytest将items
传递给pytest_collection_modifyitems
钩子的格式相同,即它们应该是_pytest.python.Function
的实例,并定义了适当的标记。
我会接受以下答案:1)在给定现有Python模块的情况下收集测试,或者2)以编程方式创建_pytest.python.Function
实例,这些实例看起来像传递给pytest_collection_modifyitems
钩子的实例。任何可以轻松生成测试数据的东西。
答案 0 :(得分:3)
我建议您使用testdir
fixture进行更高级别的测试,这对于pytest插件很常见,可以通过pytester
插件获得:
pytest_plugins = "pytester"
def test_something(testdir):
"""Test some thing."""
testdir.makepyfile("""
import pytest
@pytest.mark.some
def test_some():
assert True
@pytest.mark.some_thing_else
def test_some_thing_else():
assert True
""")
result = testdir.runpytest('-vv')
assert result.stdout.lines[-4:-2] == [
u'test_something.py::test_some PASSED',
u'test_something.py::test_some_thing_else PASSED'
]
因此您可以轻松地在源代码中进行多个测试及其标记的排列,并通过断言输出行来确定实际排序。