我有 10 个测试文件:
sc0 - 运行 4 分钟
sc1 - 运行 6 分钟
sc2 - 运行 6 分钟
sc3 - 运行 25 分钟
sc4 - 运行 25 分钟
sc5 - 运行 5 分钟
sc6 - 运行 5 分钟
sc7 - 运行 5 分钟
sc8 - 运行 6 分钟
sc9 - 运行 33 分钟
我使用下面的命令来并行运行测试(每个文件应该按顺序运行)
pytest -n 3 --dist loadfile --junit-xml=pytest-junit.xml -o junit_family=xunit2
我看到工作人员根据文件名顺序运行测试,总执行时间为 1 小时
分布是:
worker0 - sc0 (4m), sc3 (25m) 和 sc9 (33m) = 1h
worker1 - sc1 (6m), sc4 (25m) = 31m
worker2 - sc2 (6m), sc5 (5m), sc6 (5m), sc7 (5m), sc8 (6m) = 27m
但如果我能够控制工作人员拆分决定选择哪个文件,我可以节省 20m 的测试执行时间
worker0 - sc3 (25m), sc0 (4m), sc2 (6m), sc7 (5m) = 40m
worker1 - sc4 (25m), sc1 (6m), sc5 (5m), sc8 (6m) = 42m
worker2 - sc9 (33m), sc6 (5m) = 38m
如何控制 pytest-xdist 插件的测试文件分发顺序?(我不想重命名文件名)