pytest(13)-多线程、多进程执行用例
有些项目的测试用例较多,测试用例时需要分布式执行,缩短运行时间。
pytest框架中提供可用于分布式执行测试用例的插件:pytest-parallel、pytest-xdist,接下来我们来学习这两个插件的使用方法。
pytest-parallel
pytest-parallel同时支持多线程、多进程两种方式执行测试用例。
安装
安装命令:pip install pytest-parallel==0.0.10
注意,虽然最新的版本为0.1.1,但在windows系统中需要指定安装0.0.10版本,否则使用pytest-parallel参数执行用例时会报如下错误,其他系统暂未尝试。
AttributeError: Can't pickle local object 'pytest_addoption.<locals>.label_type.<locals>.a_label_type'
参数说明
pytest-parallel提供参数执行测试用例,示例如下:
if __name__ == '__main__':
pytest.main(['-s', 'testcase/test_case.py', '--workers=1', '--tests-per-worker=3'])
参数说明:
--workers=n指定运行的进程数为n,默认为1,windows系统中只能为1--tests-per-worker=m指定运行的线程数为m- 若两个参数都指定,则表示启动n个进程,每个进程最多启动m线程执行,总线程数=进程数*线程数
- windows系统中不支持
--workers取其他值,即只能为1,mac或linux系统中可取其他值
使用
接下来举例进行说明。
测试用例模块test_case.py:
import pytest
import time
def test_01():
print("执行test_01")
time.sleep(3)
def test_02():
print("执行test_02")
time.sleep(4)
def test_03():
print("执行test_03")
time.sleep(5)
def test_04():
print("执行test_04")
time.sleep(6)
不使用pytest-parallel执行用例:
if __name__ == '__main__':
pytest.main(['-s', 'testcase/test_case.py'])
# 执行结果如下:
collected 4 items
testcase\test_case.py
.执行test_01
.执行test_02
.执行test_03
.执行test_04
============================= 4 passed in 18.05s ==============================
使用pytest-parallel分布式执行用例:
if __name__ == '__main__':
pytest.main(['-s', 'testcase/test_case.py', '--workers=1', '--tests-per-worker=3'])
# 执行结果如下:
collected 4 items
pytest-parallel: 1 worker (process), 3 tests per worker (threads)
执行test_01
执行test_03执行test_02
.执行test_04
...
============================== 4 passed in 9.04s ==============================
从以上结果可以看出来:
不使用
pytest-parallel执行 test_case.py 中的测试用例所用时间为18.05s使用
pytest-parallel执行 test_case.py 中的测试用例,当--workers=1、--tests-per-worker=3时所用时间为9.04s
pytest-xdist
pytest-xdist只支持多进程执行测试用例,不支持多线程执行。
安装
安装命令:pip install pytest-xdist
参数说明
pytest-xdist提供参数执行测试用例,示例如下:
if __name__ == '__main__':
pytest.main(['-s', 'testcase/test_case.py', '-n=4'])
参数说明:
-n=指定进程数,如-n=4表示开启4个cpu进行执行测试用例。pytest-xdist支持windows系统使用,同样也支持mac、linux。
使用
使用pytest-xdist分布式执行用例:
if __name__ == '__main__':
pytest.main(['-s', 'testcase/test_case.py', '-n=4'])
# 执行结果如下:
plugins: allure-pytest-2.9.45, forked-1.4.0, html-2.1.1, metadata-1.10.0, ordering-0.6, parallel-0.0.10, rerunfailures-9.1.1, xdist-2.5.0
gw0 I / gw1 I / gw2 I / gw3 I
gw0 [4] / gw1 [4] / gw2 [4] / gw3 [4]
....
============================== 4 passed in 7.19s ==============================
从结果可以看出来,使用pytest-xdist执行test_case.py中的测试用例,当-n=4时所用时间为7.19s
总结
pytest-parallel支持多线程执行用例,但在windows系统中只支持单个进程执行,即windows中只能--workers=1。pytest-xdist只支持多进程执行用例,但可以在windows系统中进行参数设置。推荐使用
pytest-parallel,因为支持多线程执行,且自动化测试项目一般会搭建在mac或linux系统中运行,--workers可以取别的值。
在使用过程中可能会遇到其他一些问题,欢迎评论探讨。
pytest(13)-多线程、多进程执行用例的更多相关文章
- Pytest系列(13)- 重复执行用例插件之pytest-repeat的详细使用
如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 前言 平常在做功能测试的时候,经常 ...
- selenium+python-unittest多线程执行用例
前言 假设执行一条脚本(.py)用例一分钟,那么100个脚本需要100分钟,当你的用例达到一千条时需要1000分钟,也就是16个多小时...那么如何并行运行多个.py的脚本,节省时间呢?这就用到多线程 ...
- python--selenium多线程执行用例实例/执行多个用例
python--selenium多线程执行用例实例/执行多个用例 我们在做selenium测试的时候呢,经常会碰到一些需要执行多个用例的情况,也就是多线 程执行py程序,我们前面讲过单个的py用例怎么 ...
- selenium+python自动化90-unittest多线程执行用例
前言 假设执行一条脚本(.py)用例一分钟,那么100个脚本需要100分钟,当你的用例达到一千条时需要1000分钟,也就是16个多小时... 那么如何并行运行多个.py的脚本,节省时间呢?这就用到多线 ...
- unittest多线程执行用例
前言 假设执行一条脚本(.py)用例一分钟,那么100个脚本需要100分钟,当你的用例达到一千条时需要1000分钟,也就是16个多小时... 那么如何并行运行多个.py的脚本,节省时间呢?这就用到多线 ...
- Python-Unittest多线程执行用例
前言 假设执行一条脚本(.py)用例一分钟,那么100个脚本需要100分钟,当你的用例达到一千条时需要1000分钟,也就是16个多小时... 那么如何并行运行多个.py的脚本,节省时间呢?这就用到多线 ...
- C++程序员面试题目总结(涉及C++基础、多线程多进程、网络编程、数据结构与算法)
说明:C++程序员面试题目总结(涉及C++基础知识.多线程多进程.TCP/IP网络编程.Linux操作.数据结构与算法) 内容来自作者看过的帖子或者看过的文章,个人整理自互联网,如有侵权,请联系作者 ...
- 12、pytest -- 缓存:记录执行的状态
目录 1. cacheprovider插件 1.1. --lf, --last-failed:只执行上一轮失败的用例 1.2. --ff, --failed-first:先执行上一轮失败的用例,再执行 ...
- iOS开发——多线程OC篇&多线程中的单例
多线程中的单例 #import "DemoObj.h" @implementation DemoObj static DemoObj *instance; // 在iOS中,所有对 ...
随机推荐
- 利用EndpointSlices扩展Kubernetes网络,提供更强的可伸缩性和功能
EndpointSlices是一个令人兴奋的新API,它提供了Endpoints API的可扩展和可扩张的替代方案.EndpointSlice跟踪Pod服务后面的IP地址,端口,准备情况和拓扑信息.在 ...
- python分支结构与循环结构
python分支结构 一.if 单条件形式 # 年轻人的世界都不容易 age > 18 age = int(input("请输入您的年龄:")) # input()函数 模拟 ...
- 开源数据可视化BI工具SuperSet(使用)
上一篇介绍了Linux 下如何安装SuperSet ,本篇简单介绍一下如何使用 1.输入安装时设置的用户名密码登录控制台 2.控制界面如下 3.第一步添加数据源(已安装好的mysql) 点击 da ...
- winform 中心旋转 图片旋转
//设置左上角到中心点 g.TranslateTransform(int.Parse(x), int.Parse(y)); //旋转角度 g.RotateTransform(int.Parse(&qu ...
- Simulink S-Function的使用(以串口接收MPU6050六轴陀螺仪参数为实例)
S-Function 允许使用自定义C/C++函数作为传递函数,具有可移植性.也可以同样利用MATLAB函数进行相同的运算,看开发者熟悉程度而定. 项目流程 由系统串口接收数据包. 通过S-Funct ...
- django之集成阿里云通信(发送手机短信验证码)
python3 + django2.0 集成 "阿里云通信" 服务: (SDK文档地址:https://help.aliyun.com/document_detail/55491. ...
- 2022.02.05 DAY2
前言 今天陪老姐送对象去安庆了,上午还去了西风禅寺求了个签,第一次拿到中评签,看来今年还需要继续努力哈哈哈.一直到晚上才有时间去做点题目,今天依旧是leetcode. 题目 leetcode 1 两数 ...
- HBase安装教程
一.版本介绍 linux : CentOS7 Hadoop : 2.7.6 zookeeper : 3.4.6 hbase : 1.4.6 jdk : jdk1.8.0_171 三个节点的主机名分别为 ...
- Nacos极简教程
简介 Nacos是服务发现与注册,服务配置中心. Nacos 具有如下特性: 服务发现和服务健康监测:支持基于DNS和基于RPC的服务发现,支持对服务的实时的健康检查,阻止向不健康的主机或服务实例发送 ...
- JS let, var, const的用法以及区别
本文摘自多位前辈的博文,另外还有一些我的多余补充,摘自地址已补充.非常感谢各位前辈.仅以笔记学习为目的! 深入学习ES6的知识还请访问阮一峰老师的ES6教程 如果不使用let或者const,在JS只有 ...