关于python实现requests接口测试的问题
作者:人生是一场彩排 发布时间:2023-08-27 10:09:18
标签:python,requests,接口,测试
requests接口测试的介绍
requests是一个很实用的Python HTTP客户端库,编写爬虫和测试服务器响应数据时经常会用到,Requests是Python语言的第三方的库,专门用于发送HTTP请求
requests接口测试的使用前提
pip install requests
1.requests中的get请求
1 GET无参请求
r = requests.get('http://www.baidu.com')
案例:
import requests
class Classrequset:
def Claete(self):
r = requests.get('http://www.baidu.com')
print(r.text)
a=Classrequset()
a.Claete()
2.GET传参
payload = {'key1': 'value1', 'key2': 'value2', 'key3': None}
r = requests.get('http://www.baidu.com ', params=payload)
案例:
def XWTTMethod(self):
params = {"type": "guonei", "key": "4b72107de3a197b3bafd9adacf685790"}
r = requests.get("http://v.juhe.cn/toutiao/index", params=params)
print(r.text)
a=Classrequset()
a.XWTTMethod()
2.requests中的post请求
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.post("http://httpbin.org/post", data=payload)
案例:
def XWTTMethodpost(self):
uripost="http://v.juhe.cn/toutiao/index"
datapost={"type":"youxi","page":"1","size":"10","key":"ff64bdb75dd1fbc636724101514cfbe7"}
r =requests.post(url=uripost,data=datapost)
print(r.text)
# print(r.status_code) #这是查看状态码的
a=Classrequset()
a.XWTTMethodpost()
3.Requests响应
r.status_code 响应状态码
r.heards 响应头
r.cookies 响应cookies
r.text 响应文本
r. encoding 当前编码
r. content 以字节形式(二进制)返回
最常用的是根据响应状态码判断接口是否连通,经常用于做接口中断言判断
4.Request扩充
1:添加等待时间 requests.get(url,timeout=1) #超过等待时间则报错 2:添加请求头信息 requests.get(url,headers=headers) #设置请求头 3:添加文件 requests.post(url, files=files) #添加文件
文件传输
url = 'http://httpbin.org/post'
files = {'file': open('report.xls', 'rb')}
r = requests.post(url, files=files)
5.python实现requests+pytest+allure的操作
1 流程如下
读取文件中的数据 requests拿到数据请求接口返回状态码通过断言验证返回状态码和200对比生成allure的测试报告
6.读取csv文件流程
1 存储数据(csv)
2 读取数据(readDemo)
import csv
class ReadCsv():
def readCsv(self):
item = []
rr = csv.reader(open("../request/1212223.csv"))
for csv_i in rr:
item.append(csv_i)
return item
a=ReadCsv()
print(a.readCsv())
3 request请求接口返回状态码
from request.dataDemo import ReadCsv
import requests
r=ReadCsv()
ee=r.readCsv()
ltms=[]
class RequestClass:
def requesthome(self):
for a in ee:
if a[2]=="get":
ss=requests.get(url=a[0],params=a[1])
ltms.append(ss.status_code)
else:
ss=requests.post(url=a[0],data=a[1])
ltms.append(ss.status_code)
return ltms
q=RequestClass()
print(q.requesthome())
4 pytest断言设置并结合allure生成测试报告
import pytest, allure, os
from request.request03_csv import RequestClass
r = RequestClass()
aa = r.requesthome()
class TestRequest:
def testcvsHose(self):
for s in aa:
assert s == 200
if __name__ == '__main__':
pytest.main(['--alluredir','report/result','requests_test.py'])
split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'
os.system(split)
5 测试报告展示
7.读取excle文件流程
1 存储数据(xlsx)
2 读取数据(readDemo)
from openpyxl import load_workbook
class UseExcel():
def get_TestExcel(self):
# 打开表
workbook = load_workbook('./777.xlsx')
# 定位表单
sheet = workbook['Sheet1']
print(sheet.max_row) #3 行
print(sheet.max_column) #3 列
test_data = []#把所有行的数据放到列表中
for i in range(2,sheet.max_row+1):
sub_data = {}#把每行的数据放到字典中
for j in range(1,sheet.max_column+1):
sub_data[sheet.cell(1,j).value] = sheet.cell(i,j).value
test_data.append(sub_data)#拼接每行单元格的数据
return test_data
t = UseExcel()
f = t.get_TestExcel()
print(f)
3.request请求接口返回状态码
import requests
from request.requestxls import UseExcel
a=UseExcel()
f = a.get_TestExcel()
item = []
class Use_Requestexcel():
def qualification_mord(self):
for excel_i in f:
if excel_i["method"] == "get":
rr = requests.get(url=excel_i["url"],params=excel_i["paras"])
item.append(rr.status_code)
else:
rr = requests.post(url=excel_i["url"],data=excel_i["paras"])
item.append(rr.status_code)
return item
r=Use_Requestexcel()
4 pytest断言设置并结合allure生成测试报告
import pytest, allure, os
from request.requestextes import Use_Requestexcel
r = Use_Requestexcel()
aa = r.qualification_mord()
print(aa)
class Testrequest:
def testcvsHose(self):
for s in aa:
assert s == 200
if __name__ == '__main__':
pytest.main(['--alluredir','report/result','test_req.py'])
split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'
os.system(split)
5 测试报告展示
来源:https://blog.csdn.net/m0_61430050/article/details/120705009


猜你喜欢
- 人脸图像特征提取方法(一)HOG特征提取1、HOG简介Histogram of Oriented Gridients,缩写为HOG,是目前计
- 几个常用装饰器pytest.ini 配置文件 例子:[pytest]addopts = -v -s --html=py_test/scrip
- 1. Python的figure参数主要有:def figure(num=None, # autoincrement if None, el
- 关于 Python requests ,在使用中,总结了一些小技巧把,记录下。1:保持请求之间的Cookies,我们可以这样做。
- 使用MySQL8,在整合ssm框架,用mybatis逆向工程生成的代码测试时,执行到数据库查询前均正常,但进行查询时,便卡主没有反应了,设置
- 引言今年互联网的就业环境真的好糟糕啊,好多朋友被优化。我们平常在工作中除了撸好代码,跑通项目之外,还要注意内外兼修。内功和招式都得练👌,才能
- 循环是所有编程语言中最为重要的机制之一,几乎任何拥有实际意义的计算机程序(排序、查询等)都里不开循环。 而循环也正是程序优化中非常让人头疼的
- 内置数据类型文本类型:str数值类型: int,float,complex序列类型:list,tuple,range映射类型: dict集合
- 情况一:坐标上的内容是文字时如上图这样一个横向的柱状图,y坐标轴的内容太长后会导致显示不全。因为数据是由后端传过来的,有些会很长有些会比较短
- 一、功能目标用户输入一个类似 1-2*((60-30+(-40/5)*(9-2*5/3+7/3*99/4*2998+10*568
- Python 中的 timeit 模块可以用来测试一段代码的执行耗时,如一个变量赋值语句的执行时间,一个函数的运行时间等。timeit 模块
- 1 写在前面前期一篇文章Python TensorFlow深度学习回归代码:DNNRegressor详细介绍了基于TensorFlow&nb
- 本文实例讲述了JS设计模式之责任链模式。分享给大家供大家参考,具体如下:责任链设计模式:在责任链模式里,很多对象由每一个对象对其下家的引用而
- 本文参加新星计划人工智能(Pytorch)赛道:https://bbs.csdn.net/topics/613989052一、Mnist 分
- 原理:第一步:应用程序把查询SQL语句发给服务器端执行。我们在数据层执行SQL语句时,应用程序会连接到相应的数据库服务器,把SQL语句发送给
- *父父组件(helloWorld.vue):<template> <div class="hello-world
- 修改vue-treeSelect的高度.vue-treeselect{ height: 28px; }
- 这次做一个比较贴近我实际的东西:python分析作业提交情况。要求: 将服务器中交作业的学生(
- 本文实例为大家分享了pytorch绘制曲线的具体代码,供大家参考,具体内容如下import torchimport torch.nn.fun
- 一、递归原理小案例分析(1)# 概述递归:即一个函数调用了自身,即实现了递归 凡是循环能做到的事,递归一般都能做到!(2)# 写