『心善渊』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的示例 ...
随机推荐
- 使用BeautifulSoup高效解析网页,再也不用担心睡不着觉了
BeautifulSoup是一个可以从 HTML 或 XML 文件中提取数据的 Python 库 那需要怎么使用呢? 首先我们要安装一下这个库 1.pip install beautifulsoup4 ...
- Celery 架构组成
Celery 是一个强大的 分布式任务队列 的 异步处理框架,它可以让任务的执行完全脱离主程序,甚至可以被分配到其他主机上运行.我们通常使用它来实现异步任务(async task)和定时任务(cron ...
- Nginx 配置实例-配置动静分离
Nginx 配置实例-配置动静分离 1. 静态资源的创建 2. nginx 动静分离的配置 3. 验证 1. 静态资源的创建 这里使用的静态资源主要为 HTML 静态文件和图片. mkdir -vp ...
- Go基础结构与类型03---标准输入与输出
package main import ( "fmt" "strconv" ) //每次接收一个用户输入 func main031() { //定义a, b两个 ...
- TensorFlow XLA加速编译器
TensorFlow XLA加速编译器 加速线性代数器(Accelerated linear algebra,XLA)是线性代数领域的专用编译器.根据 https://www.tensorflow.o ...
- 相机自动对焦AF原理
相机自动对焦AF原理 AF性能是判断相机好坏的重要指标,主要从准确度和速度两个方面来进行考察,本文将介绍自动对焦的几种方式. 一.凸透镜成像原理 二.三种对焦方法 有公式在手,只要给相机安个测距仪就好 ...
- 英特尔Intel® Arria® 10 FPGA加速器设计
英特尔Intel Arria 10 FPGA加速器设计 Introducing the Intel Vision Accelerator Design with Intel Arria 10 FPGA ...
- 反应式系统实现MQTT客户机
反应式系统实现MQTT客户机 Implementing an MQTT client for reactive systems MQTT Reactive是从LiamBindle的MQTT-C库派生的 ...
- 在spring配置文件中引入外部properties配置文件 context:property-placeholder
在spring的配置文件中,有时我们需要注入很多属性值,这些属性全都写在spring的配置文件中的话,后期管理起来会非常麻烦.所以我们可以把某一类的属性抽取到一个外部配置文件中,使用时通用spring ...
- python+requests接口用例
本实例通过请求接口登录系统,获取了配置项的ID,并最终实现了对配置项的默认值进行修改 使用到的接口请求方法有:get(查询) ,post(新增),put(修改) 遇到的阻碍点见下面具体代码处的详解 编 ...