因为小白,这2天研究了好久才算是搞好。先附上一个测试完成后邮件的截图:

上一篇有提到:

unittest中实际运行了一个接口的很多条用例,而报告中只会有一条记录。这是因为unittest test case中我只写了一个test方法,循环测试数据。这样写用例更简单,目前在想是从报告中处理,还是测试用例读取部分进行处理。

而且这个问题会导致后续写test case出错几率大,而且耗时较多。经过几天的思考,写了个简易的解决办法。思路:轻微修改excel读取通过excel名/sheet名/用例id名来返回数据,那我们就可以在一个unittest case中固化test_开头的测试方法,如10条(我们约定excel中每个sheet最多写10条用例)。 这里我们在excel中添加一个“是否执行用例”字段,unittest中启动skipIf方法来确认是否跳过该用例,即可完美解决上一篇的问题。

excel用例数据截图:(增加runselect字段 YES代表执行用例,No代表不执行)

那我们的OperateExcel方法也做轻微修改:

def Readexcelrow_of_sheet(filename,sheet_name,row):
'''返回某个sheet中某一行数据的列表'''
folder = "C:\\Users\\LENOVO\\PycharmProjects\\Apiautotest-master\\testdata\\"
fullfilename = folder + filename
rb = xlrd.open_workbook(fullfilename)
sheet = rb.sheet_by_name(sheet_name)
datalist = []
for i in range(10):
if sheet.cell_value(row,9) =="YES":
try:
data = sheet.cell_value(row,i)
datalist.append(data)
except TypeError as f:
break
#print (datalist)
return datalist def Readexcelalldata_of_sheet(filename,sheet_name):
'''返回整个sheet的内容的列表'''
datalistlist =[]
for i in range(1,100):
try:
data = Readexcelrow_of_sheet(filename,sheet_name,i)
datalistlist.append(data)
except IndexError as e:
break
#print(datalistlist)
return datalistlist

这里我们增加一个数据处理DataProcess方法,把excel读取的整个sheet数据(是一个列表,它的元素也是列表),我们用这个方法,根据行号返回一个json数据,也就是我们每条用例所要测试请求的数据。

import json

def DataProcess(datalist,myindex):
'''datalist是一个列表,列表的元素也是列表,是从excel读到的指定sheet全部数据,根据index返回一个标准化的dict'''
data = datalist[myindex]
caseid = data[0]
casename = data[1]
method = data[2]
url = data[3]
payload = data[4].encode('utf-8')
expectedcode = data[5]
expectedmsg = data[6]
expecteddata = data[7]
headers = json.loads(data[8])
runselect = data[9] newdict = {"runselect":runselect,
"method":method,
"caseid":caseid,
"url":url,
"data":payload,
"headers":headers,
"expectedcode":expectedcode,
"expectedmsg":expectedmsg,
"expecteddata":expecteddata} return newdict

  

我们的test case样子如下:每个test方法除了一个数据处理的入参不一样,其他完全一致,无需更改。 而且我们可以做到所有的测试用例都按这个模板来撰写。

class LoginTest(unittest.TestCase):
''' ''' def setUp(self):
self.logname = logname
self.mylog = AddLog.AddLog(self.logname).getlog()
self.testcaseinfo = OperateExcel.Readexcelalldata_of_sheet(Excelname,Sheetname)
self.result = {}
global caseid
caseid += 1 def tearDown(self):
self.mylog.info("case:%d completed" % caseid) @unittest.skipIf((max_testcaseid < 1) or (0 in indexlist),"用例最大id<1或用例标记为'不执行'")
def test_caseid_1(self):
testdata = DataProcess.DataProcess(self.testcaseinfo,0)
headers= {"Content-Type": "application/json"}
self.result = RunRequest.RunRequests(testdata["method"],
testdata["url"],
testdata["data"],
testdata['headers']).run()
self.myassert = AssertResult.AssertResult(self.logname, testdata, self.result)
self.myassert.AssertEqualResult() @unittest.skipIf((max_testcaseid < 2) or (1 in indexlist),"用例最大id<2或用例标记为'不执行'")
def test_caseid_2(self):
testdata = DataProcess.DataProcess(self.testcaseinfo, 1)
self.result = RunRequest.RunRequests(testdata["method"],
testdata["url"],
testdata["data"],
testdata['headers']).run()
self.myassert = AssertResult.AssertResult(self.logname,testdata,self.result)
self.myassert.AssertEqualResult() @unittest.skipIf((max_testcaseid < 3) or (2 in indexlist),"用例最大id<3或用例标记为'不执行'")
def test_caseid_3(self):
testdata = DataProcess.DataProcess(self.testcaseinfo, 2)
self.result = RunRequest.RunRequests(testdata["method"],
testdata["url"],
testdata["data"],
testdata['headers']).run()
self.myassert = AssertResult.AssertResult(self.logname,testdata,self.result)
self.myassert.AssertEqualResult() @unittest.skipIf((max_testcaseid < 4) or (3 in indexlist), "用例最大id<4或用例标记为'不执行'")
def test_caseid_4(self):
testdata = DataProcess.DataProcess(self.testcaseinfo, 3)
self.result = RunRequest.RunRequests(testdata["method"],
testdata["url"],
testdata["data"],
testdata['headers']).run()
self.myassert = AssertResult.AssertResult(self.logname,testdata,self.result)
self.myassert.AssertEqualResult()

  因为要用到不同请求方式,我们把他封装在一起了。

#coding = utf-8
import requests
import json class RunRequests(object): def __init__(self,method,url,data,headers): self.url = url self.method = method self.data = data self.headers = headers self.result = "" def run(self): if self.method == "POST": if self.headers != "No": self.result = requests.post(self.url, data = self.data, headers = self.headers) else:
self.result = requests.post(self.url, data = self.data) elif self.method == "GET": if self.headers != "No": self.result = requests.get(self.url, data=self.data) print("暂未处理headers") else:
self.result = requests.get(self.url,data = self.data) elif self.method == "PUT": self.result = 1 elif self.method == "DELETE": self.result = 1 elif self.method == "HEAD": self.result = 1 else: self.result = 1 return self.result.json()

  

这些都完成后,想到测试完成后需要日志和邮件功能。也添加进来。

写完后整个框架就如下这个样子:

如果有朋友看到,觉得可以学习练练手,有需要源码可以留言,看到会及时回复。

Python+Excel+Unittest+HTMLTestRunner实现数据驱动接口自动化测试(二)的更多相关文章

  1. Python+Excel+Unittest+HTMLTestRunner实现数据驱动接口自动化测试(一)

    整个流程: 使用HTMLTestRunner的Run方法执行用例,用例调用Excel读取方法,将测试数据导入到unittest用例中执行,测试结果返回给HTMLTestRunner. 因为刚接触接口自 ...

  2. 接口自动化 基于python实现的http+json协议接口自动化测试框架源码(实用改进版)

    基于python实现的http+json协议接口自动化测试框架(实用改进版)   by:授客 QQ:1033553122 欢迎加入软件性能测试交流QQ群:7156436     目录 1.      ...

  3. python接口自动化测试二十七:密码MD5加密 ''' MD5加密 ''' # 由于MD5模块在python3中被移除 # 在python3中使用hashlib模块进行md5操作 import hashlib # 待加密信息 str = 'asdas89799,.//plrmf' # 创建md5对象 hl = hashlib.md5() # Tips # 此处必须声明encode # 若写法为

    python接口自动化测试二十七:密码MD5加密   ''' MD5加密 '''# 由于MD5模块在python3中被移除# 在python3中使用hashlib模块进行md5操作import has ...

  4. python+unittest+requests+HTMLRunner编写接口自动化测试集

    问题描述:搭建接口测试框架,执行用例请求多个不同请求方式的接口 实现步骤: ① 创建配置文件config.ini,写入部分公用参数,如接口的基本url.测试报告文件路径.测试数据文件路径等配置项 [D ...

  5. Python+Selenium+Unittest+HTMLTestRunner生成测试报告+发送至邮箱,记一次完整的cnblog登录测试示例,

    测试思路:单个测试集.单个测试汇成多个测试集.运行测试集.生成测试报告.发送至邮箱. 第一步:建立单个测试集,以cnblog登录为例. 测试用例: cnblog的登录测试,简单分下面几种情况:(1)用 ...

  6. python接口自动化测试二十五:执行所有用例,并生成HTML测试报告

        import requestsimport unittest class TestQQ(unittest.TestCase):    '''测试QQ号接口'''      # 此注释将展示到测 ...

  7. Python 基于python实现的http+json协议接口自动化测试框架源码(实用改进版)

    目录 1.      写在前面 2.      开发环境 3.      大致流程 4.      框架简介 5.      运行结果展示 6.      文件与配置 7.      测试接口实例 n ...

  8. ant +jmeter+jenkins接口自动化测试二

    [Jmeter篇]Jmeter+Ant+Jenkins接口自动化测试集成之半路逆转(二) 橙子探索测试发表于橙子探索测试订阅 72 [Jmeter篇]jmeter+Ant+Jenkins接口自动化测试 ...

  9. Python Selenium unittest+HTMLTestRunner实现 自动化测试及发送测试报告邮件

    1.UI测试框架搭建-目录结构 2. 文件介绍 2.1.baseinfo->__init__.py 配置文件定义基础参数 #-*-coding:utf-8-*- #测试用例配置参数 base_u ...

随机推荐

  1. PostgreSQL使用笔记

    下载并安装 注意安装图形界面 pgAdmin 需要输入缺省用户 postgres 的密码 在 Windows 下安装之后注意把 bin文件夹加到 Path 环境变量中. 重置密码 使用管理员权限打开 ...

  2. 数据库设计,表与表的关系,多对多。Many-To-Many(3)

    多对多:两个数据表里的每条记录都可以和另一个表里的任意数量的记录(或者没记录)相关. 多对多关系是关系数据库中两个表之间的一种关系, 该关系中第一个表中的一个行可以与第二个表中的一个或多个行相关.第二 ...

  3. MySQL 8.0 新增SQL语法对窗口函数和CTE的支持

    尝试了一下MySQL 8.0的部分新特性. 如果用过MSSQL或者是Oracle中的窗口函数(Oracle中叫分析函数), 然后再使用MySQL 8.0之前的时候,就知道需要在使用窗口函数处理逻辑的痛 ...

  4. Halcon示例:bottlet.hdev 光学字符识别(创建OCR)

    * * Training of the OCR* The font is used in "bottle.hdev"* * * Step 0: PreparationsFontNa ...

  5. springboot读取配置注解@ConfiguratioinProperties和@Value的区别

  6. [leetcode]265. Paint House II粉刷房子(K色可选)

    There are a row of n houses, each house can be painted with one of the k colors. The cost of paintin ...

  7. Linux的php-fpm优化心得-php-fpm进程占用内存大和不释放内存问题(转)

    原文地址:https://wzfou.com/php-fpm/ 最近发现博客的内存老是隔三差五地被“吃掉”了,登录到后台后偶尔会出卡顿的情况,一开始怀疑是Swap不够导致的,于是给VPS主机增加了几个 ...

  8. python基础之Day15

    一.函数递归 什么是函数递归: 函数递归调用是一种特殊的嵌套调用,在调用一个函数的过程中,又直接或间接地调用了该函数本身. 其中,函数的递归有明确的结束条件,不能无限制的调用,否则会撑破内存,在Pyt ...

  9. mybatis电子商务平台b2b2c

    技术解决方案 开发语言: java.j2ee 数据库:mysql JDK支持版本: JDK1.6.JDK1.7.JDK1.8版本 核心技术:分布式.云服务.微服务.服务编排等. 核心架构: 使用Spr ...

  10. 分布式协议学习笔记(三) Raft 选举自编写代码练习

    由于时间安排上的原因,这次的代码写的稍微有些简略,只能算是自己对RAFT协议的一个巩固. 实现定义2个节点,使用读取配置文件来获取IP和端口以及节点ID 网络使用boost同步流程 一个线程收 一个线 ...