python调用HTMLTestRunner+unittest实现一次执行多个测试类,并生成与每个测试类对应的测试报告,具体看代码,附上整个project代码
python自动化框架雏形,根据自己需要封装:ui自动化,接口自动化均可适用,python版本为python3.x,不要问我为什么不用python2.x,附上整个project代码:http://files.cnblogs.com/files/zw520ly/Python3.rar
测试类1:
# coding=UTF-8
import unittest
import os
import configparser
from Lib.ReaderFile import ReaderFile
from Lib.SendRepuest import SendRequest class RyTest(unittest.TestCase):
"""
在被测试的类中,这三个属性是固定的:
classNmae(一般与当前类名相同,用作测试报告的名称)
title(测试报告的主标题)
description(对整个被测试类测试流程的描述)
"""
className = 'RyTest';
title = '容易网大运营后台测试集';
description = '主要测试流程为金融事业部支付流程' def setUp(self):
#构造excel的文件读取对象
self.excelData = ReaderFile();
#构造发送http请求的client对象
self.ryLogin = SendRequest();
#当前工程的路径
self.parentPath = os.path.dirname(os.getcwd());
#构造配置文件的读取对象
self.config = configparser.ConfigParser()
#读取配置文件内容
self.config.read(self.parentPath + '/DataFile/config.conf');
print('数据初始化完成!!!') def tearDown(self):
print('测试完成!!!') """
大运营后台登录
""" def testLogin(self):
# 声明全局变量cookie,供后面的case调用
global cookie;
# 从excel获取参数
dataList = self.excelData.getExcelValue(self.parentPath + '/DataFile/Rytest.xlsx', 'ryLogin');
#配置文件中读取host及url信息
url = self.config.get('host', 'ry_host') + self.config.get('url', 'login_url');
for item in range(0, len(dataList)):
#获取excel参数
data = dataList[item]['paramer'];
headers = eval(dataList[item]['headers']);
cookieKey = dataList[item]['cookieKey'];
# 发送请求并获取cookie
cookie = self.ryLogin.GetCookie(url, data, headers, cookieKey)
print(cookie); """
大运营后台更新交易通道状态
""" def testUpdate(self):
# 从excel获取参数
dataList = self.excelData.getExcelValue(self.parentPath + '/DataFile/Rytest.xlsx', 'ryUpdate');
# 配置文件中读取host及url信息
url = self.config.get('host','ryfe_host')+self.config.get('url','updateChannelStatus_url');
for item in range(0, len(dataList)):
# 获取excel参数
data = dataList[item]['paramer'];
headers = eval(dataList[item]['headers']);
expectedResult = dataList[item]['expectedResult'];
# 发送请求并获取返回结果
response = self.ryLogin.doPost(url, data, headers, cookie);
print('请求参数:' + data)
print('期望结果:' + expectedResult)
print("实际返回结果:" + response)
print('对比结果:' + str(expectedResult == response)) 测试类2:
# coding=UTF-8
import unittest
import os from Lib.ReaderFile import ReaderFile class TestReaderFile(unittest.TestCase):
"""
在被测试的类中,这三个属性是固定的:
classNmae(一般与当前类名相同,用作测试报告的名称)
title(测试报告的主标题)
description(对整个被测试类测试流程的描述)
"""
className = 'TestReaderFile'
title = '文件读取测试流程'
description = '主要测试csv文件和excel文件的读取' # 初始化参数,从csv文件中读取数据,返回的是list[dict],testcase调用
def setUp(self):
# 构造文件读取器对象
self.reader = ReaderFile();
# 获取当前.py文件的上级目录
self.dataFile = os.path.dirname(os.getcwd())
print('测试数据初始化完成!!!') def tearDown(self):
print('测试结束!!!') def testReadCsvFile(self):
# 获取csv文件的数据,值为dict类型的list
csvList = self.reader.getCsvValue(self.dataFile + '/DataFile/csvData.csv');
# 遍历list中的所有dict,进行逻辑覆盖
for item in range(0, len(csvList)):
# 获取csv数据源中的某列
csvDict = csvList[item];
# 将csv参数初始化dict对象
prama = dict(name=csvDict['name'], age=csvDict['age'], sex=csvDict['sex']);
# 将csv文件中的期望结果中的";"替换成","
expectedStr = csvDict['expectedResult'].replace(';', ',');
# 将形如dict的字符串转换成dict
expectedDict = eval(expectedStr);
print('请求参数:' + str(prama));
print('期望结果:' + str(expectedStr))
# 对比期望结果与实际结果
print('对比结果:' + str(prama == expectedDict)); def testReadExcelFile(self):
# 获取excel文件sheet名称为'表格一'的全部内容,值为dict类型的list
excelList = self.reader.getExcelValue(self.dataFile + '/DataFile/excelFile.xlsx', '表格一');
# 遍历list中的所有dict,进行逻辑覆盖
for item in range(0, len(excelList)):
excelDict = excelList[item];
name = excelDict['name'];
age = excelDict['age'];
sex = excelDict['sex'];
expectedStr = eval(excelDict['expectedResult']);
prama = dict(name=name, age=age, sex=sex);
print('请求参数:' + str(prama))
print('期望结果:' + str(expectedStr))
# 对比期望结果与实际结果
print('对比结果:' + str(prama == expectedStr)); 测试入口封装类:
import HTMLTestRunner
import unittest
import os class HtmlReport:
"""
使用HTMLTestRunner+unittest去执行testcase并生成相应的HTML页面的测试报告
""" def reportTemple(self, classList):
# 遍历testCase(被测试类)的list集,一次执行多个testCase
for item in range(0, len(classList)):
#要执行的testCase
suite = unittest.makeSuite(classList[item]);
# 测试报告名称
filename = os.path.dirname(os.getcwd()) + '/Report/' + classList[item].className + '.html';
#向测试报告中写入测试结果
fp = open(filename, 'wb');
#运行testCase
runner = HTMLTestRunner.HTMLTestRunner(fp, title=classList[item].title,
description=classList[item].description);
runner.run(suite); 实际测试入口:
from Lib.HtmlReport import HtmlReport
from Service.RyTest import RyTest
from Service.TestReaderFile import TestReaderFile """
testCase的入口,调用htmlReport类下的reportTemple方法,传入被测试的test类的list即可,支持多个测试类测试,并生成与之对应的测试报告
"""
if __name__ == '__main__':
classList = [RyTest, TestReaderFile];
htmlReport = HtmlReport();
htmlReport.reportTemple(classList);
python调用HTMLTestRunner+unittest实现一次执行多个测试类,并生成与每个测试类对应的测试报告,具体看代码,附上整个project代码的更多相关文章
- python+request+HTMLTestRunner+unittest接口自动化测试框架
转自https://my.oschina.net/u/3041656/blog/820023 正在调研使用python进行自动化测试,在网上发现一篇比较好的博文,作者使用的是python3,但目前自己 ...
- Pycharm上python运行和unittest运行两种执行方式解析
前言 经常有人在群里反馈,明明代码一样的啊,为什么别人的能出报告,我的出不了报告,为什么别人运行结果跟我的不一样啊... 这种问题先检查代码,确定是一样的,那就是运行姿势不对了,一旦导入unittes ...
- python接口自动化测试二十五:执行所有用例,并生成HTML测试报告
import requestsimport unittest class TestQQ(unittest.TestCase): '''测试QQ号接口''' # 此注释将展示到测 ...
- unittest如何在循环遍历一条用例时生成多个测试结果
引用自:http://blog.csdn.net/kaku21/article/details/42124593 参考网址:http://programmaticallyspeaking.com/te ...
- Python调用ffpmeg和ffprobe处理视频文件
需求: 运营有若干批次的视频.有上千个,视频文件,有mp4格式的,有ts格式的 现在有需要去掉视频文件片头和片尾的批量操作需求. 比如 文件夹A下面的视频去掉片尾10秒 文件夹B下面的视频去掉片头6秒 ...
- python调用小豆机器人实现自己的机器人!
大家好,人工智能是不是很酷呢? 今天我们用python调用小豆机器人实现自己的机器人(可以结合往期的语音识别更酷哦) 好,废话不多说直接上代码 import requests i=input(&quo ...
- 第二个UI脚本--Python+selenium之unittest+HTMLtestRunner及python的继承
前面有一篇对于常见元素的识别和操作的python自动化脚本,这一篇就接着聊下python的类继承,已经它的第三款unittest框架,和报告收集包HTMLtestRunner的应用. 还是直接上代码吧 ...
- python基础===利用unittest进行测试用例执行的几种方式
利用python进行测试时,测试用例的加载方式有2种: 一种是通过unittest.main()来启动所需测试的测试模块: 一种是添加到testsuite集合中再加载所有的被测试对象,而tests ...
- Python单元测试框架unittest之生成测试报告(HTMLTestRunner)
前言 批量执行完用例后,生成的测试报告是文本形式的,不够直观,为了更好的展示测试报告,最好是生成HTML格式的. unittest里面是不能生成html格式报告的,需要导入一个第三方的模块:HTMLT ...
随机推荐
- MyBatis3_[tp-26-27]_映射文件_select_返回List_记录封装Map:返回单个元素的Map或者整体Map集合
笔记要点出错分析与总结工程组织 1.定义接口 public interface EmployeeMapper { //多条记录封装到一个map中: Map<Integer,Employee> ...
- 看完100篇Python技术精华文章,平均涨薪30%!
一个以技术为立身根基的教育机构做出来的微信号,干货程度会有多高? 马哥Linux运维公众号运营五年,从一开始的定位就是给技术人分享加薪干货的地方.这五年里,公众号运营最重的任务就是做内容.内容并不好做 ...
- Selenium(十五)cookie
有时候我们需要验证浏览器中是否存在某个 cookie,因为基于真实的 cookie 的测试是无法通过集成测试完成的.WebDriver 提供了操作 Cookie 的相关方法可以读取.添加和删除 coo ...
- P2P system: FastTrack and BitTorrent
FastTrack FastTrack来源于Gnutella,是Gnutella 和 Napster的杂交体 有些node承担了更重要的责任,这些nodes称为supernodes,因为这些改进,它比 ...
- Javascript基础(1)
1 Javascript介绍 1.1 js是一款运行在客户端的网页编程语言 1.2 组成部分 (1)ECMAScript:ECMAScript不是一门语言,而是一个标准.符合这个标准的比较常见的有:J ...
- STM32F10XX学习笔记的石墨连接
https://shimo.im/docs/QHGRrWxbeb0NiBm9/ <STM32F10X系列笔记>,可复制链接后用石墨文档 App 打开
- 微信公众号开发--微信JS-SDK分享到朋友圈和分享给朋友
之前写过一篇使用微信JS-SDK来实现扫一扫功能的博客 微信公众号开发–微信JS-SDK扫一扫功能 在该博客里介绍了微信JS-SDK的基本用法,其中包括以下几个步骤 还详细介绍了通过config接口注 ...
- Centos 安装JDK(最最最最最方便的方法)
1.下载rpm安装文件,链接:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 2 ...
- DOM事件监听和触发
EventTargetAPI定义了DOM事件(mouse事件等)的监听和触发方法,所有的DOM节点都部署了这个接口. 这个接口有三个方法:addEventListener, removeEventLi ...
- Neo4j 快速清除数据库数据
在开发过程中,很多时候需要快(简)速(单)清(粗)除(暴)Neo4j中存在的海量数据节点和关系数据.在这种情况下,delete和detach从性能上都已力不从心.Neo4j官方推荐清库方法,即删除gr ...