Python接口测试之数据驱动(python驱动程序开发)
off999 2024-10-17 11:46 94 浏览 0 评论
在接口的自动化测试中,客户端发送请求给服务端,在客户端发送请求的时候,包含了请求地址,请求方法,以及请求参数等数据,那么在接口的自动化测试中如何来分离这些请求地址和请求参数了,最好的方式是以数据驱动的方式分离到excel中,这样在excel中直接维护,即使后期由于某些原因修改了请求参数,在excel中修改也是很快的。在下来的案例中,一个系统,请求登录成功后,服务端返回token给客户端,客户端再次请求的时候需要带着这个token。关于HTTP的请求流程,token,session这些的处理,在前面的文章中有很详细的介绍,这里就不再介绍,下面会直接引入代码实战这部分。
首先安装处理excel的库,这里使用的Python版本是3.6,所以先安装第三方库,安装的命令为(已安装的会提示已存在):
安装xlrd库好之后,创建excel文件,把请求地址和请求参数分离到excel中,见excel的数据:
现在来编写读取excel中的数据,主要思路为读取excel的数据后,把数据类型转为字典的数据类型,并且是按行的方式读取,实现的代码:
#!/usr/bin/env python
#-*-coding:utf-8-*-
#author:wuya
import os
import xlrd
import json
def readExcel(rowx, filePath='data.xlsx'):
''' 读取excel中数据并且返回
:parameter filePath:xlsx文件名称
:parameter rowx:在excel中的行数
'''
book = xlrd.open_workbook(filePath)
sheet = book.sheet_by_index(0)
return sheet.row_values(rowx)
来读取excel中的数据,并且查看它的数据类型是否是期望的字典类型,调用readExcel函数后,见执行的结果截图:
在截图中可以看到,数据类型是列表,并且返回了所有的数据,再次编写函数,返回XX行的请求地址和请求参数,在excel中,存在的共同点是不管数据是在那一行,第二列永远是请求地址,第三列是请求参数,编写获取请求地址和请求参数的函数,见源码:
#!/usr/bin/env python
#-*-coding:utf-8-*-
#author:wuya
import os
import xlrd
import json
def readExcel(rowx, filePath='data.xlsx'):
''' 读取excel中数据并且返回
:parameter filePath:xlsx文件名称
:parameter rowx:在excel中的行数
'''
book = xlrd.open_workbook(filePath)
sheet = book.sheet_by_index(0)
return sheet.row_values(rowx)
def getUrl(rowx):
'''
获取请求URL
:parameter rowx:在excel中的行数
'''
return readExcel(rowx)[1]
def getData(rowx):
'''
获取请求参数
:parameter rowx:在excel中的行数
'''
return json.loads(readExcel(rowx)[2])
在上面代码中,新增了获取获取请求地址和请求参数,因为请求参数数据类型是字典,所以进行了反序列化的处理。
下来编写接口用例,见数据未分离的接口用例,见实现的代码:
import unittest
import time as t
import requests
class ApiTest(unittest.TestCase):
@classmethod
def setUpClass(cls):
t.sleep(1)
@classmethod
def tearDownClass(cls):
pass
def getHeaders(self):
return {
'Parkingwang-Client-Source':'ParkingWangAPIClientWeb',
'Content-Type':'application/json;charset=UTF-8'}
def test_login_001(self):
'''登录业务:登录成功'''
r=requests.post(
url='http://180.97.80.42:9090/v5/login',
json={"username":"6666666666","password":"8144ed050cd8d053f24a1e179d7529e17c3a2ba9cfcfcd7d3bda9ec6a8156758"}, headers=self.getHeaders())
self.assertEqual(r.status_code,200)
self.assertEqual(r.json()['status'],0)
with open('token','w') as f:
f.write(r.json()['data']['token'])
def getToken(self):
with open('token','r') as f:
return f.read()
def test_login_002(self):
'''登录业务:查看用户信息'''
r=requests.post(
url='http://180.97.80.42:9090/v5/infoGet',
json={"token":self.getToken()},
headers=self.getHeaders())
self.assertEqual(r.status_code,200)
self.assertEqual(r.json()['status'],0)
if __name__ == '__main__':
unittest.main(verbosity=2)
下来使用数据驱动的方式把请求地址和请求参数分离出来,见修改后的源码:
#!/usr/bin/env python
#-*-coding:utf-8-*-
#author:wuya
import os
import xlrd
import json
def readExcel(rowx, filePath='data.xlsx'):
'''
读取excel中数据并且返回
:parameter filePath:xlsx文件名称
:parameter rowx:在excel中的行数
'''
book = xlrd.open_workbook(filePath)
sheet = book.sheet_by_index(0)
return sheet.row_values(rowx)
def getUrl(rowx):
'''
获取请求URL
:parameter rowx:在excel中的行数
'''
return readExcel(rowx)[1]
def getData(rowx):
'''
获取请求参数
:parameter rowx:在excel中的行数
'''
return json.loads(readExcel(rowx)[2])
import unittest
import time as t
import requests
class ApiTest(unittest.TestCase):
@classmethod
def setUpClass(cls):
t.sleep(1)
@classmethod
def tearDownClass(cls):
pass
def getHeaders(self):
return {
'Parkingwang-Client-Source':'ParkingWangAPIClientWeb',
'Content-Type':'application/json;charset=UTF-8'}
def test_login_001(self):
'''
登录业务:登录成功
'''
r=requests.post(
url=getUrl(1),
json=getData(1),
headers=self.getHeaders())
self.assertEqual(r.status_code,200)
self.assertEqual(r.json()['status'],0)
with open('token','w') as f:
f.write(r.json()['data']['token'])
def getToken(self):
with open('token','r') as f:
return f.read()
def test_login_002(self):
'''
登录业务:查看用户信息
'''
r=requests.post(
url=getUrl(2),
json=getData(2),
headers=self.getHeaders())
print(r.text)
self.assertEqual(r.status_code,200)
self.assertEqual(r.json()['status'],0)
if __name__ == '__main__':
unittest.main(verbosity=2)
数据分离后,维护数据统一是在excel中,第二个接口这些成功后,直接失败,见失败信息:
问题在于数据分离后,test_login_002的测试用例请求数据与登录成功后的token不一致,导致了错误,那么如何对这些动态参数进行处理了,处理的思路是:
从excel中读取数据
对如token这些动态参数再次进行赋值
返回赋值后的数据
调用赋值后的数据
依据如上的思路,对getToken方法进行修改,对token再次进行赋值,新增setToken方法,见修改后的该方法代码:
def getToken(self):
'''读取token文件里面的内容'''
with open('token','r') as f:
return f.read()
def setToken(self,rowx):
''' 对动态参数token进行赋值
:parameter rowx:在excel中的行数
''' dict1=getData(rowx)
#对tokek赋值
dict1['token']=self.getToken()
return dict1
在test_login_002的接口用例中,调用请求参数直接调用setToken方法,这样就不会出现错误了,见完整的代码:
#!/usr/bin/env python
#-*-coding:utf-8-*-
#author:wuya
import os
import xlrd
import json
import unittest
import time as t
import requests
def readExcel(rowx, filePath='data.xlsx'):
''' 读取excel中数据并且返回
:parameter filePath:xlsx文件名称
:parameter rowx:在excel中的行数
'''
book = xlrd.open_workbook(filePath)
sheet = book.sheet_by_index(0)
return sheet.row_values(rowx)
def getUrl(rowx):
''' 获取请求URL
:parameter rowx:在excel中的行数
'''
return readExcel(rowx)[1]
def getData(rowx):
'''
获取请求参数
:parameter rowx:在excel中的行数
'''
return json.loads(readExcel(rowx)[2])
class ApiTest(unittest.TestCase):
@classmethod
def setUpClass(cls):
t.sleep(1)
@classmethod
def tearDownClass(cls):
pass
def getHeaders(self):
return {
'Parkingwang-Client-Source':'ParkingWangAPIClientWeb',
'Content-Type':'application/json;charset=UTF-8'}
def test_login_001(self):
'''登录业务:登录成功'''
r=requests.post(
url=getUrl(1),
json=getData(1),
headers=self.getHeaders())
self.assertEqual(r.status_code,200)
self.assertEqual(r.json()['status'],0)
with open('token','w') as f:
f.write(r.json()['data']['token'])
def getToken(self):
'''读取token文件里面的内容'''
with open('token','r') as f:
return f.read()
def setToken(self,rowx):
'''
对动态参数token进行赋值
:parameter rowx:在excel中的行数
'''
dict1=getData(rowx)
#对tokek赋值
dict1['token']=self.getToken()
return dict1
def test_login_002(self):
'''登录业务:查看用户信息'''
r=requests.post(
url=getUrl(2),json=self.setToken(2),headers=self.getHeaders())
self.assertEqual(r.status_code,200)
self.assertEqual(r.json()['status'],0)
if __name__ == '__main__':
unittest.main(verbosity=2)
相关推荐
- 安卓模拟器电脑版(安卓模拟器电脑版下载)
-
BlueStacks安卓模拟器 是一款十分好用的安卓模拟器。该软件非常的不错,采用了LayerCake技术可使用一些ARM特殊指令集,而且使用它能够让大部分的安卓应...
-
- 靠比较好的软件下载网站(靠比较好的软件下载网站动漫)
-
官网下载最好通过官网下载,最大的好处是能够保证软件的原汁原味,不怕病毒。其安装程序不会被恶意篡改,保证了应用过程中的安全性。但是缺点也是存在的。一些软件通过官网下载的时候速度非常慢,尤其对于Office、VisualStudio等国外的主...
-
2026-01-08 06:51 off999
- 大白菜一键重装系统步骤(大白菜重装系统详细步骤)
-
1.登录大白菜官网【www.winbaicai.com】,下载最新版的大白菜U盘启动盘制作...2.解压并打开大白菜U盘启动盘制作工具,点击切换至【一键还原】界面3.进入一键还原界面之后,选择【我要重...
- 怎么提升电脑配置(如何升级电脑配置提高电脑运行速度)
-
升级电脑配置可以通过以下几个方面来实现。首先,可以更换更快的处理器和更大的内存条,这将提升计算速度和多任务处理能力。其次,更换较新的显卡可以提升图形处理性能,使游戏和图形应用更流畅。此外,更换更大容量...
- 重启就好了(重启就好了吗)
-
一、路由器工作时间过长,热量散发不出去引起的断网很多用户在使用路由器的时候并没有过多的去在意过它的“感受”,会让它处在24小时的工作状态下,其实在路由器长时间工作的情况下,其内部会产生大量的热量,又因...
- 电脑麦克风没声音是什么原因
-
电脑麦克风没有声音可能有多种原因,以下是一些常见的排查步骤:1.检查麦克风连接:确保麦克风正确连接到电脑的麦克风插孔上。如果是通过USB连接的麦克风,也要确保USB连接正常。2.调整麦克风音量:在...
-
- 安全浏览器免费下载(安全刘览器下载)
-
1、打开运行qq浏览器。 2、点击右上方菜单按钮,在弹出的菜单中点击“qq浏览器设置”。? 3、进入“安全与隐私”类目,然后勾选“开启安全网址认证”确定即可。?1.首先打开浏览器,点击左上角的三个点。2.然后在弹出的页面点击“设置”选项...
-
2026-01-08 04:03 off999
- bios无法设置u盘启动(bios无法设置legacy)
-
需要准备的工具:电脑,Bios设置界面。1、以戴尔电脑为例,直接按启动快捷键F12进入启动菜单选择u盘即可,进入BIOS设置。2、进入BIOS设置之后。找到”USBStorageLegacySuppo...
- 电脑重装win7系统后怎么设置
-
1.首先在win7桌面空白处,点击右键弹出菜单,选择个性化。2.调出个性化设置窗口后,我们切换至开始选项卡,然后点击右侧下方的“选择哪些文件夹显示在开始屏幕上”。3.此时一般正常情况下,可以看到设置选...
- 简单常用的dos命令(常见dos命令总结)
-
一些常用的DOS命令包括:1.dir:列出当前目录中的文件和子目录。2.cd:更改当前目录。3.md:创建一个新的目录。4.rd:删除一个目录。5.copy:将文件从一个位置复制到另一个位置...
- 421事件全文免费阅读(421事件文档全文免费阅读)
-
对于421事件的真实性,目前没有确凿的官方消息。关于421事件的真实性,有以下几种观点:1.有人认为421事件总体上是真实的,认为其中的污秽和混乱超过了大多数人的认知,涉及到的封建迷信内容对于一些人...
- 英伟达所有显卡型号(英伟达显卡型号含义)
-
amdcpu搭配英伟达的显卡,显卡性能不会受到影响的。性能不会受到影响,AMD说配三A平台稳定性最强,而且恢复自动超频一点点,制其实那只是AMD的广告而已,没那回事,AMDCPU配英伟达的显卡也没...
- windows无法连接到这个网络(windows无法连接到这个网络 笔记本)
-
有可能是因为无线网络的密码变了,也有可能是系统自身的问题,解决方法:1、右键计算机图标。2、点开服务和应用程序,然后点击下面的服务。3、打开服务后找到WLANAutoConfig无线网络服务。4、W...
- 电脑装机平台(电脑装机城)
-
网上装机京东比较靠谱。要想在网上组装一台靠谱的电脑,真的需要一双慧眼。笔者认为相对靠谱的还是某东自营店,某宝甚至某猫都是满地坑。如果某东也看不上的话,其实到线下实体店购买也是不错的选择,现在线上线下价...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
