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

news2025/1/15 22:56:51

大家在接口测试的过程中,很多时候会用到对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...")

 r = 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...")

 r = 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是测试开发不容错过的利器之一。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Connect to 127.0.0.1:1080 [/127.0.0.1] failed: Connection refused: connect

报错信息 A problem occurred configuring root project CourseSelection. > Could not resolve all artifacts for configuration :classpath.> Could not resolve com.android.tools.build:gradle:3.6.1.Required by:project :> Could not resolve com.android.tool…

力扣第101题 c++ 递归 迭代 双方法 +注释 ~

题目 101. 对称二叉树 简单 给你一个二叉树的根节点 root , 检查它是否轴对称。 示例 1: 输入:root [1,2,2,3,4,4,3] 输出:true示例 2: 输入:root [1,2,2,null,3,null,3] 输出:false提示&a…

点读笔背后的神秘力量,究竟是如何实现即时识别的?

点读笔是一种智能学习工具,通过与印刷物或电子设备配合使用,将文字、图片或声音转化为可听、可读、可学习的内容。它的核心功能是识别并解析特定标识(如二维码、条形码)或区域内的信息,并提供相应的语音、文字或图像反…

docker swarm安装指导

SWARM部署DOCKER集群 1. 简介............................................................................................................................ 3 2. 部署准备.........................................................................................…

15040-2021 工作测光标准灯泡 学习记录

声明 本文是学习GB-T 15040-2021 工作测光标准灯泡.pdf而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本文件规定了工作测光标准灯(下文在不会引起误解时简称为"标准灯”或“灯")的分类、 一般要求、 技术要求和试验方法&#xff…

详解链表oJ<反转链表,链表的中间节点及链表的回文>

hello,大家好,这里是Dark FlameMaster,今天和大家分享的是有关数据结构链表的几道题目,链表的中间节点,反转链表及判断链表是否为回文结构,放在一起讲解会印象更加深刻。 文章目录 一,链表的中间节点二&…

C#,数值计算——数据建模FGauss的计算方法与源程序

1 文本格式 using System; namespace Legalsoft.Truffer { public class FGauss : MultiFuncd { public void funk(double x, double[] a, ref double y, double[] dyda) { int na a.Length; y 0.0; for (int …

吃鸡达人专享!提高战斗力,分享干货,查询装备皮肤,保护账号安全!

大家好!作为专业吃鸡行家,我将为您带来一些热门话题和实用内容,帮助您提升游戏战斗力,分享顶级游戏作战干货,并提供便捷的作图工具和查询服务。让我们一起享受吃鸡的乐趣! 首先,我要推荐一款绝地…

CleanMyMacX 永久版下载激活码破解版

CleanMyMac X最新破解版V4.9.2是一款出色的Mac 系统垃圾清理程序。 该软件具有强大的垃圾清理功能,可以释放数 GB 的空间,让您的 Mac 焕然一新。 带有激活码的完整破解版 CleanmyMac 可加速您的 Mac 设备。 此外,cleanmymac还能帮助您从 Mac…

2023最新ICP备案查询系统源码 附教程 Thinkphp框架

2023最新ICP备案查询系统源码 附教程 thinkphp框架 本系统支持网址备案,小程序备案,APP备案查询,快应用备案查询 优势: 响应速度快,没有延迟,没有缓存,数据与官方同步 源码下载:ht…

Puppeteer基础知识(一)

Puppeteer基础知识(一) Puppeteer基础知识(一)一、简介二、其他一些自动化测试工具三、Puppeteer常用命令四、常见问题解决: 一、简介 Puppeteer 是一个强大而灵活的工具,可以用于网页爬虫、自动化测试、性…

大数据Doris(六):编译 Doris遇到的问题

文章目录 编译 Doris遇到的问题 一、js_generator.cc:(.text+0xfc3c): undefined reference to `well_known_types_js’

华为云新开源低代码引擎 TinyEngine

在当今数字化飞速发展的时代,企业对高效、敏捷的应用程序需求日益旺盛。为了满足这一需求,越来越多的低代码开发平台开始涌现。这些平台通过提供简单易用的开发工具和优化后的开发流程,帮助开发者快速构建高质量、可重复使用的应用程序&#…

Suricata + Wireshark离线流量日志分析

Suricata 环境搭建:基于Ubuntu坏境下的Suricata坏境搭建_奈何@_@的博客-CSDN博客 suricata:监控日志 wireshark:监控流量 同时使用需要降噪,因为规则有许多重叠 题目及要求我打包上传了,有需要的同学自…

十一工具箱流量主小程序源码

无授权,去过滤机制版本 看到网上发布的都是要授权的 朋友叫我把他去授权,能用就行 就把过滤去了 这样就不用授权 可以免费使用 白嫖党专属 一切接口可用,无需担心不能用 授权者不关站一直可以用 源码下载:https://download.csdn.…

彻底理解浏览器cookie策略

cookie介绍 为什么存在cookie? (1)cookie存在的原因 因为http请求是无状态的,同一个用户从浏览器向A服务器发送两次请求,A服务器无法判断这两次请求是否是同一个用户。所以,浏览器提供了客户端携带cooki…

threejs 透明贴图,模型透明,白边

问题 使用Threejs加载模型时,模型出现了上面的问题。模型边缘部分白边,或者模型出现透明问题。 原因 出现这种问题是模型制作时使用了透明贴图。threejs无法直接处理贴图。 解决 场景一 模型有多个贴图时(一个透贴和其他贴图&#xff0…

互联网Java工程师面试题·Redis篇·第一弹

目录 1、什么是 Redis? 2、Redis 优势 3、Redis 与其他 key-value 存储有什么不同? 4、Redis 的数据类型? 5、使用 Redis 有哪些好处? 6、Redis 相比 Memcached 有哪些优势? 7、Memcache 与 Redis 的区别都有哪些&#xf…

MyBatisPlus(十四)主键策略

说明 MyBatis Plus 集成了多种主键策略,帮助用户快速生成主键。 雪花算法ID(默认策略)(推荐)UUID自增ID用户输入ID(必须用户每次插入数据时,手动传入ID) 雪花算法ID:I…

ModelScope-agent体验

7月在魔搭社区hackathon的时候就了解到了魔搭在做的这件事,前段时间开源了,去体验一 本文写的很浅,没有做深入尝试 一.在线体验 体验地址:https://modelscope.cn/studios/damo/ModelScopeGPT/summary 效果还是挺惊艳的 二.部署…