关于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
0
投稿
猜你喜欢
- 本文实例讲述了thinkPHP框架实现类似java过滤器的简单方法。分享给大家供大家参考,具体如下:写java web代码的时候,可以定义过
- 本文实例讲述了python使用cPickle模块序列化的方法,分享给大家供大家参考。具体方法如下:import cPickledata1 =
- 前言虚拟环境是程序执行时的独立执行环境,在同一台服务器中可以创建不同的虚拟环境供不同的系统使用,项目之间的运行环境保持独立性而相互不受影响。
- 使用了application及结合数据库来保存统计数据 <html><head><title>
- goto语句在Go编程语言中的goto语句提供无条件跳转从跳转到标记声明的功能。注意:使用goto语句是高度劝阻的在任何编程语言,因为它使得
- 影响的范围: IE的所有版本在表单的radio/checkbox控件中,一旦他们的DOM结构被更改过就会出现这个bug。bug描述当象下例中
- 前言今天的文章比较基础,但却是必须掌握的,而且本文有些内容,也许你之前没想过。希望这篇文章能够让你理解环境变量并掌握 Go 环境变量相关操作
- 1 create table test(coltest varchar(20))2 实现这一功能 的 sql 语句 s
- 私有变量表示方法在变量前加上两个下划线的是私有变量。class Teacher(): def __init__(self,nam
- 利用Python,将多个excel文件合并为一个文件思路利用python xlrd包读取excle文件,然后将文件内容存入一个列表中,再利用
- 一、环境准备python3.6.7Pycharm二、创建项目我这里是在Django项目中新建了个APP,目录结构如下图所示:那么怎么在已有的
- 概述路由是自定义url地址执行指定的函数,良好的路由定义可以对seo起到很好的效果。1. 基本路由gin框架封装了http库,提供了 GET
- 本文实例讲述了Python可变和不可变、类的私有属性。分享给大家供大家参考,具体如下:可变和不可变items = []print(id(li
- 简介这两天更新完Xcode8之后发现Xcode对图标的要求又有了变化,之前用的一个小应用“IconKit”还没赶上节奏,已经不能满足Xcod
- 在网上看了很多解决方法,都没有解决,后来我自己解决了这个问题:出现的问题:在cmd上 “pip install package” 时显示 s
- 1.简介keplergl是由Uber开源的一款地理数据可视化工具,通过keplergl我们可以在Jupyter notebook中使用,可视
- jupyter notebook 图片显示模糊的解决办法加入这几行代码即可:矢量图设置import matplotlib.pyplot as
- mysql数据库没有增量备份的机制,当数据量太大的时候备份是一个很大的问题。还好mysql数据库提供了一种主从备份的机制,其实就是把主数据库
- 示例matplotlib中的animation提供了动态绘图功能,下面列举一个最简单的动态绘制三角函数的例子,来初步演示一下。import
- 一.垃圾回收机制Python中的垃圾回收是以引用计数为主,分代收集为辅。引用计数的缺陷是循环引用的问题。在Python中,如果一个对象的引用