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中,所有对 ...
随机推荐
- springboot启动过程中常用的回调
1.介绍 springboot提供非常丰富回调接口,利用这些接口可以做非常多的事情,对于一些常用的回调接口进行介绍 2.常用的拓展接口 1.ApplicationContextInitializer ...
- jenkins启动失败 jenkins.service failed Starting Jenkins bash: /usr/bin/java: 没有那个文件或目录
失败的原因 ● jenkins.service - LSB: Jenkins Automation Server Loaded: loaded (/etc/rc.d/init.d/jenkins; b ...
- Linux基础之终端、控制台、tty、pty简介说明
最近在搞Linux提权的时候,有时候su 用户名 登录的时候发现登录不了,因为tty终端,交互不了,所以我也来总结一下 一. 基本概念 1. ttytty(终端设备的统称):tty一词源于telety ...
- javascript随机变色--案例
1.打开网页,网页效果如图所示 代码如下: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset=" ...
- leetcode 13. 罗马数字转整数 及 12. 整数转罗马数字
13. 罗马数字转整数 问题描述 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如,罗马数 ...
- seq2seq+torch7聊天机器人bug处理
[C]: in function 'error' ...root1/torch/install/share/lua/5.2/rnn/recursiveUtils.lua:44: in function ...
- 什么是XSS攻击?什么是SQL注入攻击?什么是CSRF攻击?
1. XSS(Cross Site Script,跨站脚本攻击) 是向网页中注入恶意脚本在用户浏览网页时在用户浏览器中执行恶意脚本的攻击方式. 1.1跨站脚本攻击分有两种形式: 反射型攻击(诱使用户点 ...
- 推荐召回--基于物品的协同过滤:ItemCF
目录 1. 前言 2. 原理&计算&改进 3. 总结 1. 前言 说完基于用户的协同过滤后,趁热打铁,我们来说说基于物品的协同过滤:"看了又看","买了又 ...
- 【Kafka】基于Windows环境的Kafka有关环境(scala+zookeeper+kafka+可视化工具)搭建、以及使用.NET环境开发的案例代码与演示
前言:基于Windows系统下的Kafka环境搭建:以及使用.NET 6环境进行开发简单的生产者与消费者的演示. 一.环境部署 Kafka是使用Java语言和Scala语言开发的,所以需要有对应的Ja ...
- mpfu 位编辑处理?
1. 国内的不用处理,其余都做 2. 判断是否是mp 的项目 3 设置位数编辑 请求中 和 检查中都要做 4 以某一画面作为基准,修改不同的值. 5 对象外的数据直接设置在 ...