利用Python如何实现数据驱动的接口自动化测试

前言

大家在接口测试的过程中,很多时候会用到对CSV的读取操作,本文主要说明Python3对CSV的写入和读取。下面话不多说了,来一起看看详细的介绍吧。

1、需求

某API,GET方法,token,mobile,email三个参数

  • token为必填项
  • mobile,email 必填其中1项
  • mobile为手机号,email为email格式

2、方案

针对上面的API,在做接口测试时,需要的测试用例动辄会多达10+, 这个时候采用数据驱动的方式将共性的内容写入配置文件或许会更合适。

这里考虑把API、参数、以及预期结果预行在格式化的CSV里保存,利用csv组件从CSV里读取URL、参数以及预期结果,Requests组件发起请求,将响应结果与预期结果进行比对,最后把比对结果写到结果CSV。

流程如下图 ☟

3、实现

1、在上代码之前,先安装好如下几个组件:

  • csv  读写CSV文件
  • json
  • requests  发起请求,获取响应结果
  • unittest    测试用例调度

2、data.csv(本示例选取部分用例)

3、reader_CSV函数代码示例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

import csv

import json

import requests

import time

import unittest

def readCSV(self,filename):

 '''

 :param filename: 需要读取的数据文件

 :return: [{data1},{data2}...]

 '''

 datas = []

 try:

 #以DictReader的方式读取数据文件,方便与json互做转换

 with open(filename,'r') as csvfile :

 #从文件里读取到的数据转换成字典列表的格式

 reader = csv.DictReader(csvfile)

 for row in reader:

 data = {}

 data['id'= row['id']

 data['url'= row['url']

 data['token'= str(row['token'])

 data['mobile'= row['mobile']

 data['email'= row['email']

 data['expect'= json.dumps(row['expect']) \

 if isinstance(row['expect'],dict) \

 else row['expect'#如果expect读取出来的不是json则取其原值,否则转为json格式保存到result里

 datas.append(data)

 return datas

 #如果文件找不到,返回空的datas

 except FileNotFoundError:

 print("文件不存在",filename)

 return datas

4、request_URL函数示例(包含GET请求和POST请求2个方法)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

def get_request(self,url,params):

 '''

 通用的调用GET接口方法

 :param url:string 接口路径

 :param params:{"":"","":""} 需要传入的参数

 :return: response响应体

 '''

 print("调用API...")

 = requests.get(url,params=params)

 print(r.text)

 return r

def post_request(self,url,params):

 '''

 通用的调用POST接口方法

 :param url: string 接口路径

 :param params: {"":"","":""} 需要传入的参数

 :return:response响应体

 '''

 print("调用API...")

 = requests.post(url,params=json.dumps(params)) #post的方法必须用json.dumps()转化成json格式

 print(r.text)

 return r

5、assert_Result函数示例

1

2

3

4

5

6

7

8

9

def assertResult(self,except_value,real_value):

 '''

 校验样本字符串中是否包含指定字符串

 :param except_value: string 指定字符串

 :param real_value: string 样本字符串

 :return: Boolean 样本中包含指定字符串返回True,否则返回False

 '''

 ifsuccess = except_value in str(real_value)

 return ifsuccess

6、write_CSV函数示例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

def writeCSV(self,filename,results):

 '''

 写入csv文件指定内容

 :param filename: string 需要写入的文件名称

 :param results: [{data1},{data2},...] 写入的内容

 :return: 无

 '''

 print("写文件:",filename)

 #以DictWriter的方式写文件

 with open(filename,'w+') as csvfile:

 headers="id,url,token,mobile,email,expect,real_value,assert_value".split(",")

 writer = csv.DictWriter(csvfile,fieldnames=headers)

 #写表头

 writer.writeheader()

 #写数据

 if results.__len__() > 0 :

 for result in results:

 writer.writerow(result)

 csvfile.close()

7、test_interface1函数示例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

def test_interface1(self):

 #指定读取的数据文件名称

 data_file = "../data/data.csv"

 #指定最终结果生成的数据文件名称

 result_file = "../data/result_{}.csv".format(str(time.time()).split(".")[0])

 #读取指定文件的数据

 datas = self.readCSV(data_file)

 #数据文件有内容则调用接口,否则直接测试结束

 if datas.__len__() > 0:

 results =[]

 #获取数据文件里的每一行

 for testcase in datas :

 result = {}

 result["id"= testcase["id"]

 result["url"= testcase["url"]

 result["token"= testcase["token"]

 result["mobile"= testcase["mobile"]

 result["email"= testcase["email"]

 result["expect"= testcase["expect"]

 #组装参数

 params = {

 "token":result["token"],

 "mobile":result["mobile"],

 "email":result["email"]

 }

 #调用API接口,获取响应结果

 real_value = self.get_request(result["url"],params)

 #调用assert方法,检查预期结果是否在响应结果中存在

 assert_value = self.assertResult(result["expect"],real_value.text)

 result["real_value"= real_value.text

 result["assert_value"= assert_value

 #获取每一行里的所有字段以及实际结果和验证结果

 results.append(result)

 #执行完所有记录后,将所有结果写入result.csv

 self.writeCSV(result_file,results) #写入csv文件

 print("测试结束")

8、result_1523956055.csv(本示例中的测试结果请忽略)

总结

python封装了很多方法,对于测试来说开发速度相对较快,接口自动化测试如果采用CSV管理的数据驱动方式,使用csv+requests是测试开发不容错过的利器之一。

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

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

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/476339.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【项目】基于YOLOv8和RotNet实现圆形滑块验证码(拼图)自动识别(通过识别中间圆形的角度实现)

TOC 一、引言 1.1 实现目标 要达到的效果是使用算法预测中间圆形的角度,返回给服务器,实现自动完成验证码的问题。要实现的内容如下图所示。 1.2 实现思路 思路1(效果较差):以RotNet要实现的验证码识别为灵感&…

微信小程序(五十九)使用鉴权组件时原页面js自动加载解决方法(24/3/14)

注释很详细,直接上代码 上一篇 新增内容: 1.使用覆盖函数的方法阻止原页面的自动执行方法 2.使用判断实现只有当未登录时才进行方法覆盖 源码: app.json {"pages": ["pages/index/index","pages/logs/logs"],…

python中如何生成词云

大家好,我是雄雄,欢迎关注微信公众号:雄雄的小课堂 今天给大家看看,如何使用python实现根据记录创建生成词云 首先我们看下效果图。 一个是生成了新闻的词云,另一个是生成了聊天记录的词云。下面是代码: …

Java学习笔记(19)

双列集合 键值对 一一对应 键值对对象 entry Map Put第一次给不存在的key,会把键值对添加到map中,返回null Put给同一个key是会覆盖value的,返回被覆盖的值value Remove根据key删除键值对,返回被删除的值value Map遍历 键找值 …

python语法踩坑 | list的append操作如何从in-place改为out-of-place

背景 博主写python遇到一个问题,需要把对list添加元素改为非原地操作,即不修改原list。 但是由于列表中的元素是字典类型,无法直接用运算符。 于是写出了下面这行代码 query_list message_list.copy().append(one_question) 其中message…

Anaconda安装 (windowsLinux)

文章目录 Anaconda简介设置国内源pip || conda 一、Anaconda (Windows系统)1.1 下载及安装1.2 虚拟环境创建1.3 在Pycharm中配置conda的环境 二、Anaconda(Linux系统) Anaconda简介 conda是一个开源的包、环境管理器,可…

探索 Atlassian 云平台:组织、站点、产品架构解析

我们通常访问的是 Atlassian 的某个云站点,比如填空题-中国站点为:cloze-cn.atlassian.net。当我们访问该站点内的具体产品时,只需在该站点的 URL 后添加相应产品的缩写,例如: Confluence: cloze-cn.atlassian.net/wi…

12.电子产品拆解分析-LED T8_16W灯管

12.电子产品拆解分析~LED_T8_16W家用灯管 一、功能介绍二、电路分析以及器件作用一、功能介绍 ①无需使用镇流器(启辉器),只需接到220V即可点亮使用;②节能省电 透光性强 无可视频闪;二、电路分析以及器件作用 220V交流电经过MB10F桥式整流出300V脉动直流电,然后经过6.8u…

某J 集成 cas5.3res api登录

在学习一个开源项目是时集成了cas,但文档过于简单,研究了两天这次记录做个补充 1.下载cas项目 GitHub - apereo/cas-overlay-template at 5.3 2.编译 解压zip,命令行进去,执行mvn clean package 结束之后会出现 target 文件夹&…

Android14 - Framework- Configuration的创建和更新

本文描述从启动一个新进程的Activity起,Framwork层Configuration的创建和传导过程。 首先,我们知道所有的Window容器都继承于WindowContainer,而WindowContainer本身是ConfigurationContainer的子类。于此同时,WindowProcessContr…

[NOIP1998 提高组] 拼数

[NOIP1998 提高组] 拼数 题目描述 设有 n n n 个正整数 a 1 … a n a_1 \dots a_n a1​…an​,将它们联接成一排,相邻数字首尾相接,组成一个最大的整数。 输入格式 第一行有一个整数,表示数字个数 n n n。 第二行有 n n …

【Vue3遇见的问题】创建vue3的项目使用vscode打开后项目的app.vue里面存在爆红

出现的问题 直接上上问题:问题的图片如下: 解决方法 解决效果 补充 因为vetur的插件禁用了 所以需要一个新插件来 这里发现的官网推荐的插件 也就是volar 他两是一样的

各位老板,你需要的工厂数字孪生可视化库在这

各位老板是不是很喜欢下面这种有逼格的大屏,下面介绍一下怎么实现的,保证有所收获。 Cesium是一个开源的WebGL JavaScript库,用于创建高性能的三维地球、地图和虚拟环境。它支持在浏览器中实现高质量的地球模拟,同时提供了丰富的功能特点,使得…

【Linux进程的状态】

目录 看Linux源码中的说法 如何查看进程状态? 各个状态的关系 僵尸进程 举个栗子 现象 僵尸进程的危害 孤儿进程 举个栗子 现象 进程的优先级 基本概念 为什么要有进程优先级? 查看系统进程 进程的大致属性 进程优先级vs进程的权限 Linu…

AI基础知识(4)--贝叶斯分类器

1.什么是贝叶斯判定准则(Bayes decision rule)?什么是贝叶斯最优分类器(Bayes optimal classifier)? 贝叶斯判定准则:为最小化总体风险,只需在每个样本上选择那个能使条件风险最小的…

用 Open-Sora 高效创作视频,让创意触手可及

近年来,视频内容以爆炸式增长席卷了我们的生活。从短视频平台到直播带货,视频正成为人们获取信息和娱乐的主要方式。然而,传统视频制作流程往往耗时费力,对于普通用户来说门槛较高。 为了降低视频创作门槛,让更多人享…

Git的 .gitignore文件及标签使用

Git的 .gitignore文件及标签使用 什么是.gitignoregit check-ignore -v 文件名 查看.gitignore里面什么内容忽略了该文件 git add -f [filename] 强制添加把指定文件排除在 .gitignore 规则外的写法给命令配置别名标签创建标签git tag [name] 创建标签git tag 列出所有标签git …

RESNET的复现pytorch版本

RESNET的复现pytorch版本 使用的数据为Object_102_CaDataset,可以在网上下载,也可以在评论区问。 RESNET模型的亮点 1.提出了残差模块。 2.使用Batch Normalization加速训练 3.残差网络:易于收敛,很好的解决了退化问题&#…

真实数据!一张切片实现101种蛋白的超多重空间单细胞原位成像

头颈鳞状细胞癌 (HNSCC) 是第七大常见癌症。免疫检查点抑制剂 (ICIs) 在治疗复发/转移病例方面显示出良好前景,约30%的患者可获得持久获益。但是目前反映HNSCC肿瘤微环境 (TME) 特征的生物标志物有限,需要更深入的组织表征分析。因此,需要新的…

linux查看cpu/内存/磁盘利用率

1、cpu 命令: top 2、内存 命令: free -h 3、磁盘 命令: df -h