pytest+allure+requests

需要安装pytest和pytest-html(生成html测试报告)
pip install pytest 和 pip install pytest-html
命名规则
Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨
Pytest的setup, setup_class和teardown, teardown_class函数(和unittest执行效果一样)
运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown
运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class

其实,pytest的操作,和unittest有很大的相同之处,首先,我们模拟一个测试软件的代码——文件work,并建立一个pytest测试文件——testdemo,如图:
在这里插入图片描述
然后写测试方法:
在这里插入图片描述
运行结果:
在这里插入图片描述
Pytest生成自带的html测试报告
pip install pytest-html() :python自带的插件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
pytest.main([‘–html=./report.html’,‘模块.py::类::test_a_001’])
运行指定模块指定类指定用例,冒号分割,并生成测试报告
在这里插入图片描述
在这里插入图片描述
-x出现一条测试用例失败就退出测试
在这里插入图片描述
在这里插入图片描述
-v: 丰富信息模式, 输出更详细的用例执行信息
在这里插入图片描述
-s:显示print内容
在这里插入图片描述
在这里插入图片描述
-q: 简化结果信息,不会显示每个用例的文件名
在这里插入图片描述
在这里插入图片描述
allure
Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。

首先要安装allure
pip install allure-pytest
allure-pytest是Pytest的一个插件,通过它我们可以生成Allure所需要的用于生成测试报告的数据
Allure常用的几个特性

@allure.feature # 用于描述被测试产品需求
@allure.story # 用于描述feature的用户场景,即测试需求
with allure.step(): # 用于描述测试步骤,将会输出到报告中
allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等,操作如下
首先,准备一个新的测试方法----test_shop:
在这里插入图片描述
结果
在这里插入图片描述
Pytest和allure结合生成html格式的测试报告
生成测试报告json
pytest.main([ ‘–alluredir’, ‘report/result’, ‘test001.py’])
在这里插入图片描述
js文件形式
在这里插入图片描述
将测试报告转为html格式 --html=…/report.html:
split = 'allure ’ + 'generate ’ + './report/result ’ + '-o ’ + './report/html ’ + ‘–clean’
os.system(split)#system函数可以将字符串转化成命令在服务器上运行
在这里插入图片描述
展示
在这里插入图片描述
在这里插入图片描述
Allure常用的几个特性
@allure.feature # 用于描述被测试产品需求
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
@allure.story # 用于描述feature的用户场景,即测试需求
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
with allure.step(): # 用于描述测试步骤,将会输出到报告中
allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
在这里插入图片描述
在这里插入图片描述
其实就是额外添加描述的功能

requests
类似python中的表单提交

    payload = {'key1': 'value1', 'key2': 'value2'}

r = requests.post(“http://httpbin.org/post”, data=payload)

传递文件(了解)
url = ‘http://httpbin.org/post’ files = {‘file’: open(‘report.xls’, ‘rb’)}
r = requests.post(url, files=files)
如图:
在这里插入图片描述
在这里插入图片描述

Requests响应

r.status_code 响应状态码
在这里插入图片描述

r.headers 响应头
在这里插入图片描述

r.cookies 响应cookies
在这里插入图片描述

r.text 响应文本
在这里插入图片描述

r. encoding 当前编码
在这里插入图片描述

r. content 以字节形式(二进制)返回
在这里插入图片描述 最常用的是根据响应状态码判断接口是否连通,经常用于做接口中断言判断

以上为手动测试,现在我们用接口测试:
在这里插入图片描述
显示成功,我们将链接进行修改,看看如何
在这里插入图片描述
传递参数进行检测
在这里插入图片描述
用csv传递测试接口数据
首先,建一个csv文件
在这里插入图片描述
将文件复制粘贴进项目
在这里插入图片描述
然后如图:
在这里插入图片描述
结果如图:
在这里插入图片描述
三个200,证明链接有效,测试方法可行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值