1

我有 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 插件的测试文件分发顺序?(我不想重命名文件名)

4

0 回答 0