关于pytest分布式多线程运行测试用例报错及解决办法,附实例

先抛成果,分布式执行测试用例,比正常执行测试用例,节约了很多时间。
如图:
在这里插入图片描述
windows下想用多进程用pytest-xdist
(不支持多线程),想用多线程用pytest-parallel。今天来讲后者多线程的使用。

   pytest-parallel常用配置如下:
   -- workers * 进程数  默认1 
   workers 2  表示2个进程运行
   --tests-per-worker * 多线程运行,最大并发线程数
   --workers 2 --tests-per-worker 4 
   2个进程并行,每个进程最大4个线程,总8个线程。
   例,pytest.main(["-s","test_*.py","--workers=2","--tests-per-worker=4"])

遇到的问题:pytest parallel在windows下执行失败及解决办法AttributeError: Can ‘t pickle local object’pytest_addoption. <locals?
解决方法: 将pytest-parallel版本回退到0.0.10。
cmd命令行下卸载package包:
pip uninstall packageName
cmd命令行下安装特定版本的package包:pip install packageName-version(如0.0.10)
另,如下是不使用分布式/使用分布式执行测试用例,所用时间脚本,及结果对比
第一种正常执行用例时间:
if_name_==’main’:
⭐️time_start = ⭐️time.time(pytest.main([’./case’]) ⭐️time_end = time.time()
⭐️timeall =(time_end - time start)des ⭐️print(timeall) ⭐️logging.info("***************执行用例总时间{:.2f}s ***************".format(timeall))

第二种分布式运行测试用例时间:
if name==“main”:
⭐️time_start = time.time()
⭐️pytest.main(["-s”, “./case”,“workers=2”,"–tests per worker=4"])
⭐️time_end = time.time())
⭐️timeall =(time_end-time_start)
⭐️logging.info(“分布式执行用例总时间(:.2f)s”.format(time all)

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值