【发布时间】:2017-06-19 19:36:58
【问题描述】:
所以我有两个主要的代码部分:
- 在目录中生成大量配置文件。
- 运行之前生成的单个配置文件。
我想运行一个测试,首先我执行 code1 并生成所有文件,然后为每个配置文件运行 code2 并验证结果是否良好。 到目前为止,我的尝试是:
@pytest.fixture(scope='session')
def pytest_generate_tests(metafunc, tmpdir_factory):
path = os.path.join(tmpdir_factory, "configs")
gc.main(path,
gc.VARIANTS, gc.MODELS,
default_curvature_avg=0.0,
curvature_avg_variation=0.9,
default_gradient_avg=0.0,
gradient_avg_variation=0.9,
default_inversion="approximate",
vary_inversion=False,
vary_projections=True)
params = []
for model in os.listdir(path):
model_path = os.path.join(path, model)
for dataset in os.listdir(model_path):
dataset_path = os.path.join(model_path, dataset)
for file_name in os.listdir(dataset_path):
config_file = os.path.join(dataset_path, file_name)
folder = os.path.join(dataset_path, file_name[:-5])
tmpdir_factory.mktemp(folder)
params.append(dict(config_file=config_file, output_folder=folder))
metafunc.addcall(funcargs=dict(config_file=config_file, output_folder=folder))
def test_compile_and_error(config_file, output_folder):
final_error = main(config_file, output_folder)
assert final_error < 0.9
但是,tmpdir_factory 夹具不适用于 pytest_generate_tests 方法。我的问题是如何通过生成所有测试来实现我的目标?
【问题讨论】: