01、声明
在介绍pytest-xdist时,不讲任何原理,需要看原理的请移至官方:https://pypi.org/project/pytest-xdist/
当我们自动化测试用例非常多的时候, 一条条按顺序执行会非常慢,pytest-xdist的出现就是为了让自动化测试用例可以分布式执行,从而节省自动化测试时间,pytest-xdist是属于进程级别的并发。
pytest-xdist插件在测试过程中可以使我们的测试用例一起并行测试,运行情况是根据你运行环境存在多个CPU,运行过程中可以进行组合测试运行,从而缩短我们的测试时间。
1、pytest-xdist插件安装
只需要在终端中运行如下命令:
pip install pytest-xdist
2、pytest-xdist执行用例的条件
需满足以下条件:
-
每一条用例必须是独立的。用例之间没有依赖关系,用例可以完全独立运行【独立运行】
-
每一条用例没有特定的执行顺序,就是每条用例都要遵循随机执行【随机执行】
-
每条用例的测试结果不能影响到其他的测试用例。【不影响其他用例】
pytest-sdist 与 pytest-parallel的小区别
-
pytest-xdist在win中调用的是多进程,而parallel在win中调用的是多线程,win中只有单进程
-
pytest-xdist调用时,会使session执行多次,算是一个win的bug,但是官方给出的解决方案是,使用filelock锁
-
使用parallel时,在win中调用多线程,但是allure报告不支持多线程,allure是集成报告,根据session来集成,所以就是出现一个线程一个报告
3、pytest-xdist使用方法
pytest
-n
x
n