从技术上讲,我已经解决了我正在处理的问题,但我不禁觉得我的解决方案很丑:
我有一个 pytest 套件,我可以在两种模式下运行:本地模式(用于开发测试;一切都通过 Chrome 在我的开发盒上运行)和 Seriousface 回归测试模式(用于 CI;该套件可以在无数浏览器上运行和操作系统)。我有一个命令行标志可以在两种模式之间切换,--test-local
. 如果它在那里,我以本地模式运行。如果它不存在,我会以严肃的方式运行。这是我的做法:
# contents of conftest.py
import pytest
def pytest_addoption(parser):
parser.addoption("--test-local", action="store_true", default=False, help="run locally instead of in seriousface mode")
def pytest_generate_tests(metafunc):
if "dummy" in metafunc.fixturenames:
if metafunc.config.getoption("--test-local"):
driverParams = [(True, None)]
else:
driverParams = [(False, "seriousface setting 1"), (False, "seriousface setting 2")]
metafunc.parameterize("dummy", driverParams)
@pytest.fixture(scope="function")
def driver(dummy):
_driver = makeDriverStuff(dummy[0], dummy[1])
yield _driver
_driver.cleanup()
@pytest.fixture
def dummy():
pass
问题是,那个dummy
装置很可怕。我尝试过直接pytest_generate_tests
对夹具进行参数化driver
,但它最终会替换夹具,而不是仅仅将东西放入其中,因此cleanup()
在测试完成时永远不会被调用。使用 dummy 可以让我用参数元组替换 dummy,以便将其传递到driver()
.
但是,重申一下,我所拥有的确实有效,感觉就像是一个 janky hack。