Pytest测试实战|分布式执行

Pytest测试框架另外一个优秀的特性是提供了支持分布式的执行,当需要被执行的测试用例很多的时候,使用分布式执行的方式提升自动化测试执行的效率,从而尽快的得到测试的结果。

pytest分布式执行

在自动化测试中,当被执行的测试用例个数在几百个甚至上千个测试用例的时候,那么这个时候执行的测试效率会非常低,一般执行的耗时都会在半小时或者是半小时以上,这么久的执行耗时一般不符合测试的诉求。特别是在集成回归测试与上线后的测试验证中,希望能够尽快地得到自动化测试用例执行的结果,从而得出测试的整体质量情况。因此提升自动化测试用例执行的效率是非常重要的。在Pytest测试框架中通过pytest-xdist插件的方式能够满足分布式执行被执行的测试用例,从而提升整体的测试效率。以下面的测试案例代码为案例,来详细的演示下分布式执行与未分布式执行的区别,案例代码如下:

import requests

import time

import pytest


def writeID(productID):

with open('productID','w') as f:

return f.write(str(productID))


def getProductID():

with open('productID') as f:

return f.read()


def addProduct(headers):

r=requests.post(

url='http://0.0.0.0:8000/interface/product/',

json={"name":"无涯课堂","product_type":"WEB","version":"V1.0.0","master":"无涯","description":"This Is A Test"},

headers=headers)

writeID(productID=r.json()['id'])

return r



def delProduct(headers):

r=requests.delete(

url='http://0.0.0.0:8000/interface/product/{productID}'.format(

productID=getProductID()),

headers=headers)

return r


def setProduct(headers):

r=requests.put(

url='http://0.0.0.0:8000/interface/product/{productID}/'.format(productID=getProductID()),

json={"name":"wuyaShare","product_type":"WEB","version":"V1.0.0","master":"无涯","description":"This Is A Test","id":getProductID()},

headers=headers)

return r



@pytest.fixture()

def apiInit(headers):

addProduct(headers=headers)

yield

delProduct(headers=headers)


def test_add_product(headers):

r=addProduct(headers=headers)

delProduct(headers=headers)

assert r.status_code==201

assert r.json()['name']=='无涯课堂'


def test_case_query(apiInit,headers):

r=requests.get(

url='http://0.0.0.0:8000/interface/products?name=无涯课堂',

headers=headers)

assert r.status_code==200

assert r.json()[0]['id']==int(getProductID())


def test_set_product_name(headers):

addProduct(headers=headers)

r=setProduct(headers=headers)

delProduct(headers=headers)

assert r.status_code==200

assert r.json()['name']=='wuyaShare'



def test_del_product(headers):

addProduct(headers=headers)

r=delProduct(headers=headers)

  assert r.status_code==204

如上是一个产品模块中完整的测试用例,包含了增删改查的API测试用例,执行后的耗时以及结果信息如下:

从如上看,执行的耗时是1.73s,其实在实际的工作里面,编写的API自动化测试用例业务逻辑会非常复杂而且数量也会非常多,执行的耗时基本以分钟为单位。下面我们使用分布式执行的方式来执行同样的API测试用例,看执行的耗时。在分布式执行中,本质上是在执行的过程中开启多个work的进程,同时执行多个测试用例从而达到执行效率的提升,执行的命令如下:

pytest -v -s -n 1  test_platform.py

执行如上的结果后,执行的结果信息以及执行的耗时具体如下:

如上可以看到执行耗时并没有进行提升反而执行效率进行了下降,这是因为被执行的测试用例在基数上还是比较少,从开启work进程到同时执行多个测试用例的这个过程中也是需要耗时的,所以在使用分布式执行测试用例的过程中特别需要注意这点。在之前测试用例的基础上再增加测试用例的基数,常规执行的耗时以及结果信息如下:

再次使用分布式执行的方式来进行执行,本次执行开启2个work进程,执行的命令如下:

pytest -v -s  -n auto    test_platform.py

执行如上的命令后,执行的结果信息以及耗时结果如下:

如上结果中可以看到执行耗时在本次提升了约环比为19%的提升。在分布式执行的过程中,“-n”后面的数字代表的是CPU数目,一般而言使用“auto”它会自动检测到系统里的CPU数目。

分布式执行有它天然的优势但是也存在它的缺陷,特别是在参数化或者是多个work进程同时执行的时候操作同一个对象,中间会涉及到数据安全部分从而导致某些测试用例在分布式执行下失败,实际单独执行的时候是成功。后续文章详细地阐述下Python并发执行下数据安全的规则与过程。感谢您的阅读。

最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取【保证100%免费】

​​​软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值