『心善渊』Selenium3.0基础 — 29、使用HTMLTestRunner生成unittest的HTML报告
1、HTMLTestRunner介绍
HTMLTestRunner是一个基于unittest单元测试框架生成HTML报告的第三库。
2、HTMLTestRunner的使用
- 将下载好的HTMLTestRunner解压,把
HTMLTestRunner.py
放入Python安装目录的Lib
文件下,
如:F:\DevInstall\envs\python\python377\Lib
(推荐)
或者F:\DevInstall\envs\python\python377\Lib\site-packages
都可以。
(注:如果你有自己封装的测试框架,也可以放在框架中,当作工具类应引入也行。) - 将HTMLTestRunner模块用
import
导入测试脚本文件中。 - 通过
open()
方法以二进制写模式'wb'
打开当前目录下的测试报告.html
,如果没有,则自动创建。 - 调用HTMLTestRunner模块下的HTMLTestRunner类,参数说明如下:
stream
:指定测试报告文件title
:定义测试报告的标题description
:定义测试报告的副标题verbosity
:报告的详细程度,只有0、1、2
,2
为最详细。
- 通过HTMLTestRunner的
run()
方法来运行测试套件中的测试用例.
3、测试报告示例
"""
run_case.py
1.将需要执行的测试用例,添加到测试套件中
2.将用例执行结果生成HTML格式的测试报告
HTMLTestRunner.py文件放置在python安装目录中的Lib目录中
备注:
运行结果三种:
ok 表示用例执行通过
F 表示用例执行失败
E 表示代码错误
"""
import os
import unittest
import HTMLTestRunner
import time
# 1.确定测试用例存放路径
case_path = "./testcase"
# 2.将测试文件夹中的测试用例添加到测试套件中
discover = unittest.defaultTestLoader.discover(case_path, pattern="test*.py")
# 3.执行测试用例并生成测试报告
# 3.1 确定测试报告存放路径
report_path = "./report"
# 3.2 确定测试报告名称
now = time.strftime("%Y_%m_%d %H-%M-%S")
# 测试报告文件名
report_file = report_path + "/" + now + "report.html"
# 打开文件并写入数据
with open(report_file, "wb") as fp:
# 实例化
"""
title:报告的标题
description:报告的描述
stream:执行结果全部卸载该文件纵
verbosity:报告的详细程度,0.1.2 ,2为最详细
retry:重试,这个功能是坏的,不能用。
"""
runner = HTMLTestRunner.HTMLTestRunner(
title="ECShop项目web自动化测试报告",
description="ECShop登录功能",
verbosity=2,
stream=fp
)
runner.run(discover)
4、封装成模块
# coding=utf-8
import time
import os
import unittest
import HTMLTestRunner
# 定位测试用例目录(可以再封装)
project_dir = os.path.abspath(os.path.dirname(os.path.abspath(__file__)) + '\..')
testcase_dir = project_dir + r"\testcase"
def creatsuite():
'''获取测试集'''
# 搜索测试用例
testcases = unittest.defaultTestLoader.discover(testcase_dir, pattern="test*.py", top_level_dir=None)
return testcases
def run(title=u'自动化测试报告', description=u'环境配置等信息'):
"""执行测试并生成报告"""
# 如果没有测试报告目录自动创建
for filename in os.listdir(project_dir):
if filename == "reports":
break
else:
os.mkdir(project_dir + r'\reports')
# 执行测试用例并生成测试报告
# 1 确定测试报告存放路径
report_path = project_dir + r'\reports'
print(report_path)
# 2 确定测试报告名称
now = time.strftime("%Y_%m_%d_%H-%M-%S")
report_file = report_path + "\\" + now + "report.html" # 测试报告文件名
# 打开文件并写入
with open(report_file, "wb") as fp:
# 实例化
"""
title:报告的标题
description:报告的描述
stream:执行结果全部卸载该文件纵
verbosity:报告的详细程度,0.1.2 ,2为最详细
retry:重试,这个是坏的,不能用
"""
runner = HTMLTestRunner.HTMLTestRunner(
title=title,
description=description,
verbosity=2,
stream=fp
)
runner.run(creatsuite())
if __name__ == '__main__':
run()
"""
封装成目录,如果需要生成报告的测试,
直接调用该模块中的run()方法即可。
例如:
# 引入模块
from util import TestRunnerReport
# 执行测试用例
TestRunnerReport.run(title='ewr',description='123131')
注意:这里只是提供一种封装的思路,仅供参考,
可以根据自己的情况按需封装。
"""
『心善渊』Selenium3.0基础 — 29、使用HTMLTestRunner生成unittest的HTML报告的更多相关文章
- 『心善渊』Selenium3.0基础 — 24、Selenium的expected_conditions模块详细介绍
目录 1.EC模块介绍 2.EC模块常用类 3.EC模块的使用 4.EC模块综合使用 (1)title_is(title)示例 (2)presence_of_element_located(locat ...
- 『心善渊』Selenium3.0基础 — 11、Selenium对元素常用操作
目录 1.Selenium对元素常用操作 2.Selenium对元素的其他操作 1.Selenium对元素常用操作 操作 说明 click() 单击元素 send_keys() 模拟输入 clear( ...
- 『心善渊』Selenium3.0基础 — 12、Selenium操作鼠标和键盘事件
目录 (一)对鼠标的操作 1.鼠标事件介绍 2.ActionChains 类鼠标操作的常用方法 3.perform()方法 4.鼠标事件操作步骤 5.示例 (1)右键单击.左键双击 (2)鼠标拖拽动作 ...
- 『心善渊』Selenium3.0基础 — 1、Selenium自动化测试框架介绍
目录 1.Selenium介绍 2.Selenium的特点 3.Selenium版本说明 4.拓展:WebDriver与Selenium RC的区别 5.Webdriver工作原理 1.Seleniu ...
- 『心善渊』Selenium3.0基础 — 2、Selenium测试框架环境搭建(Windows)
目录 1.浏览器安装 2.浏览器驱动下载 (1)ChromeDriver for Chrome (2)Geckodriver for Firefox (3)IEDriverServer for IE ...
- 『心善渊』Selenium3.0基础 — 3、使用Selenium操作浏览器对象的基础API
目录 1.导入Selenium库 2.创建浏览器对象 3.浏览器窗口大小设置 4.浏览器位置设置 5.请求访问网址 6.浏览器页面前进.后退和刷新 7.关闭浏览器 相比于高大上的各种Selenium进 ...
- 『心善渊』Selenium3.0基础 — 4、Selenium基础元素定位详解
目录 1.什么是元素定位 2.Selenium元素定位常用API (1)By_id 定位 (2)by_name 定位 (3)by_class_name 定位 (4)by_tag_name 定位 (5) ...
- 『心善渊』Selenium3.0基础 — 19、使用Selenium操作文件的上传和下载
目录 1.Selenium实现文件上传 (1)页面中的文件上传说明 (2)文件上传示例 (3)总结 2.Selenium实现文件下载 (1)Firefox浏览器文件下载 1)操作步骤: 2)文件下载示 ...
- 『心善渊』Selenium3.0基础 — 20、Selenium对Cookie的操作
目录 1.Cookie介绍 2.Session介绍 3.Cookie工作原理图解 4.Cookie内容参数说明 5.Selenium操作Cookie的API 6.Selenium操作Cookie的示例 ...
随机推荐
- 对狂神说的MybatisPlus的学习总结
1.什么是MybatisPlus? 需要的基础:spring,spring mvc,mybatis 作用:可以节省大量的工作时间,所有的CRUD代码都可以自动完成,简化Mybatis MyBatis- ...
- synchronized使用及java中的原子性问题
1.Synchronized关键字使用 class X { // 修饰非静态方法 synchronized void foo() { // 临界区 } // 修饰静态方法 synchronized s ...
- ADAS摄像头图像环视拼接算法
ADAS摄像头图像环视拼接算法 输入输出接口 Input: (1)4个摄像头采集的图像视频分辨率 (整型int) (2)4个摄像头采集的图像视频格式 (RGB,YUV,MP4等) (3)摄像头标定参数 ...
- Gbps接口面向汽车应用
Gbps接口面向汽车应用 Gbps interfaces target automotive appications 巴黎--不久前,移动通信行业是一个领着芯片商的领头羊,命令坐着,脚跟着,然后翻身. ...
- 【Android编程实战】源码级免杀_Dex动态加载技术_Metasploit安卓载荷傀儡机代码复现
/文章作者:MG193.7 CNBLOG博客ID:ALDYS4 QQ:3496925334/ 在读者阅读本文章前,建议先阅读笔者之前写的一篇对安卓载荷的分析文章 [逆向&编程实战]Metasp ...
- 【NX二次开发】缝合片体例子UF_MODL_create_sew
缝合片体,没有成功缝合的片体涂绿色. 效果: 源码: extern DllExport void ufusr(char *param, int *returnCode, int rlen) { UF ...
- Java课程设计-算术运算测试(D级) 齐鲁工业大学 计科20-1 王瀚垠 202003010033
Java课程设计-算术运算测试(D级) 齐鲁工业大学 计科20-1 王瀚垠 202003010033 目录 1.项目简介 2.项目采用技术 3.功能需求分析 4.项目亮点 5.项目功能架构图和UML类 ...
- 聚类算法K-Means算法和Mean Shift算法介绍及实现
Question:什么是聚类算法 1.聚类算法是一种非监督学习算法 2.聚类是在没有给定划分类别的情况下,根据数据相似度进行样本分组的一种方法 3.理论上,相同的组的数据之间有相同的属性或者是特征,不 ...
- 源码学习之void 0
今天看源码的时候看到 void 0 这样的写法,平时在业务代码里基本没有这样的写法,于是学习了一下. 在控制台运行了一下void 0,得到返回值是undefined. 在MDN上搜了一下void,了解 ...
- 【NLP学习其一】什么是命名实体识别NER?
命名实体识别 概念 命名实体识别(Named Entity Recognition,简称NER) , 是指识别文本中具有特定意义的词(实体),主要包括人名.地名.机构名.专有名词等等,并把我们需要识别 ...