python中什么是数据驱动_利用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。

流程如下图 ☟

201851194007953.jpg?201841194017

3、实现

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

csv 读写CSV文件

json

requests 发起请求,获取响应结果

unittest 测试用例调度

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

201851194044944.jpg?201841194344

3、reader_CSV函数代码示例

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个方法)

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函数示例

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函数示例

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函数示例

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(本示例中的测试结果请忽略)

201851194909447.jpg?201841194934

总结

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

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

本文标题: 利用Python如何实现数据驱动的接口自动化测试

本文地址: http://www.cppcns.com/jiaoben/python/227724.html

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

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

相关文章

密码锁 java接口_从synchronized和lock区别入手聊聊java锁机制

写这篇文章之前,我去百度了一下啥叫锁,百度百科上写道:置于可启闭的器物上,以钥匙或暗码开启。确实我们一般理解的锁就是门锁,密码锁,但是在计算机科学中,锁又是啥,说实话&#xff0…

lua 给userdata设置元表_lua学习之复习汇总篇

第六日笔记1. 基础概念程序块定义在 lua 中任何一个源代码文件或在交互模式中输入的一行代码程序块可以是任意大小的程序块可以是一连串语句或一条命令也可由函数定义构成,一般将函数定义写在文件中,然后用解释器执行这个文件换行在代码中不起任何作用&a…

集群服务负载均衡------LVS

个人的理解,以一种通俗易懂的方式讲述出来,如果有哪些地方说的不正确的话,希望大家留言指出来。笔者会非是常的感谢! Cluster服务器集群,直接理解为一些单一的服务器的集合通过某种方式组合起来,为客户端提…

tomcat jsp导入java_[导入]Tomcat JSP Web 开发中的乱码问题小姐

1. 静态页面的乱码问题文件的编码和浏览器要显示的编码不一致。1) 检查文件原始的编码, 可以用记事本打开, 然后选择另存为来看;2) 给当前页面加入一个指令来建议浏览器用指定的编码来显示文件字符内容.3) 如果系统是英文XP,没装东亚字符集支持, 也会显示乱码.2. JSP 页面的乱码…

四大开源分布式存储_ipfs分布式存储行业面临着四大主要风险,你知道是哪些吗?...

为了响应国家号召、推动分布式存储技术落地、防御行业风险,中国分布式存储产业联盟启动,全国从事IPFS以及分布式存储从业者对行业风险及联盟成立的必要性达成了高度共识,目前有36家以上的IPFS分布式存储行业企业填写了联盟申请表。几位国内知…

pjsua帮助手册(中文)

原文地址 : http://www.pjsip.org/pjsua.htm 介绍 PJSUA是一个开源的命令行SIP用户代理(软电话),用PJSIP协议,PJNATH,和PJMEDIA实现。 它虽然只有很简单的命令行界面,但是功能齐全。 SIP功能: 多…

js date转成 时间字符串_秋招快要开始了,前端笔试中的坑位-JS隐式转换问题

我们在写笔试题的时候,经常碰到涉及隐式转换的题目,例如"1" 2 obj 1 [] ![] [null] false 和 叫做严格运算符,对象类型指向地址相同或原始类型( 数值、字符串、布尔值)值相同;叫做相等运算…

Java中快速处理集合_简洁又快速地处理集合——Java8 Stream(上)

作者:Howie_Y,系原创投稿主页:www.jianshu.com/u/79638e5f0743Java 8 发布至今也已经好几年过去,如今 Java 也已经向 11 迈去,但是 Java 8 作出的改变可以说是革命性的,影响足够深远,学习 Java …

eclipse编译java项目class文件_动态编译 Java 代码以及生成 Jar 文件

导读: 最近在看 Flink 源码的时候发现到一段实用的代码,该代码实现了 java 动态编译以及生成 jar 文件。将其进行改进后可以应用到我们的平台上,实现在平台页面上编写 java 代码语句,提交后由后台进行编译和打成 Jar 包再上传到指…

Dx11DemoBase 基类(三) 实例应用 【已实现】【附带源码】

现在我已经到哪了? 读书时,尤其是技术知识书籍, 我一般会担忧自己是否陷得太深, 细节关注得太多, 而忘了整体的过程; 一直以来对Direct3D 很畏惧, 因为太多函数和细节;现在我必须暂缓下&#x…

修改 decimal 默认值为0.00 sql_被经理邀请去“爬山”,只是因为我写错了一条SQL语句?...

作者:isysc1链接:https://juejin.im/post/5f06a2156fb9a07e5f5180df来源:掘金前戏SQL 写的妙,涨薪呱呱叫!新来的实习生小杨写了一条 SQL 语句SELECT wx_id from user WHERE wx_id 2当小杨迫不及待准备下班回家的时候&…

JS中关于clientWidth、offsetWidth、scrollWidth

网页可见区域宽: document.body.clientWidth;网页可见区域高: document.body.clientHeight;网页可见区域宽: document.body.offsetWidth (包括边线的宽);网页可见区域高: document.body.offsetHeight (包括边线的宽);网页正文全…

shell 执行失败重试_Uipath 机器人总是运行失败怎么办?

要知道为什么RPA机器人容易失败,首先了解下它和常规的应用系统有哪些区别。常规应用系统,就像程序员自己创造了一个世界、一个域,在这个世界里创造它的人就是主宰。出现BUG的风险是相对可控的,顶多是功能用不了。而RPA项目&#x…

c mysql安装教程视频_MySQL安装教程 - Windows安装MySQL教程 - 小白式安装MySQL教程 - 青衫慧博客...

版权声明本文转发自旧站点萧瑟云日志,近期考虑准备将旧站进行关闭(没有精力维护),部分文章将会迁移至本站。文章发表于:2017-10-28 12:32:03前言上次给大家带来了SQL Server的小白式安装教程,这次再次带来一个MySQL的小白式安装教…

PJSIP UA分析(1)--PJSUA主函数

1 intmain(intargc, char*argv[])2 {3 do{4 app_restart PJ_FALSE; //PJ_FALSE是一个宏,一旦用户调用pjsua可执行文件进入该循环,那么默认只执行一次退出5 //如果需要再次循环,那么在下面函数中…

锁定表头和固定列(Fixed table head and columns)

前段时间需要这个功能,但是找了很多都不能完美的实现,不是只能锁定表头,就是浏览器兼容问题什么的,在此就自己做了一个锁定表头和列的js方法,依赖于JQuery。 因为方法很简单,就未封装成插件的形式&#xff…

游戏详细设计说明书_宜家的说明书设计脑洞太大了!

平常我们看到的说明书是像这样纯文字解说的或者是规范的文字配图这些说明书一般都是注重文字的上表达而大家熟悉的家居品牌宜家将说明书创意玩出了新境界!↓↓↓这不,最近由于全球疫情严峻期间宜家的全新说明书手册搜罗了各种纸上游戏意为帮助大家打发无…

centos删除php_centos如何卸载php

查看php版本php -v查看php相关软件包#rpm -qa|grep php(视频教程推荐:linux视频教程)提示如下:#php-pdo-5.1.6-27.el5_5.3#php-mysql-5.1.6-27.el5_5.3#php-xml-5.1.6-27.el5_5.3#php-cli-5.1.6-27.el5_5.3#php-common-5.1.6-27.el5_5.3#php-gd-5.1.6-27…

cgblib 代理接口原理_Java开发者你还不知道?告诉你Dubbo 的底层原理,面试不再怕...

前言平常我们在构建分布式系统的时候,一般都是基于 Dubbo 技术栈或者是SpringCloud 技术栈来做。早期其实最先比较流行的是Dubbo,我记得我们当时有个部分的老大就是用的是Dubbo 来构建的一个系统,到后面才出来的 SpringCloud,由于…

包含对流环热,热流边界,等温边界的稳态热传导方程的FEM求解。

以下面的问题为例:对于如图所示的平面传热问题, 若上端有给定的热流-2W/m2,即从下往上传输热量,结构下端有确定的温度100,周围介质温度为20,在两侧有换热,换热系数为α100W/㎡/K,热导…