1、HTMLTestRunner介绍

HTMLTestRunner是一个基于unittest单元测试框架生成HTML报告的第三库。

2、HTMLTestRunner的使用

  1. 将下载好的HTMLTestRunner解压,把HTMLTestRunner.py放入Python安装目录的Lib文件下,

    如:F:\DevInstall\envs\python\python377\Lib(推荐)

    或者F:\DevInstall\envs\python\python377\Lib\site-packages都可以。

    (注:如果你有自己封装的测试框架,也可以放在框架中,当作工具类应引入也行。)
  2. 将HTMLTestRunner模块用import导入测试脚本文件中。
  3. 通过open()方法以二进制写模式'wb'打开当前目录下的测试报告.html,如果没有,则自动创建。
  4. 调用HTMLTestRunner模块下的HTMLTestRunner类,参数说明如下:
    • stream:指定测试报告文件
    • title:定义测试报告的标题
    • description:定义测试报告的副标题
    • verbosity:报告的详细程度,只有0、1、22为最详细。
  5. 通过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报告的更多相关文章

  1. 『心善渊』Selenium3.0基础 — 24、Selenium的expected_conditions模块详细介绍

    目录 1.EC模块介绍 2.EC模块常用类 3.EC模块的使用 4.EC模块综合使用 (1)title_is(title)示例 (2)presence_of_element_located(locat ...

  2. 『心善渊』Selenium3.0基础 — 11、Selenium对元素常用操作

    目录 1.Selenium对元素常用操作 2.Selenium对元素的其他操作 1.Selenium对元素常用操作 操作 说明 click() 单击元素 send_keys() 模拟输入 clear( ...

  3. 『心善渊』Selenium3.0基础 — 12、Selenium操作鼠标和键盘事件

    目录 (一)对鼠标的操作 1.鼠标事件介绍 2.ActionChains 类鼠标操作的常用方法 3.perform()方法 4.鼠标事件操作步骤 5.示例 (1)右键单击.左键双击 (2)鼠标拖拽动作 ...

  4. 『心善渊』Selenium3.0基础 — 1、Selenium自动化测试框架介绍

    目录 1.Selenium介绍 2.Selenium的特点 3.Selenium版本说明 4.拓展:WebDriver与Selenium RC的区别 5.Webdriver工作原理 1.Seleniu ...

  5. 『心善渊』Selenium3.0基础 — 2、Selenium测试框架环境搭建(Windows)

    目录 1.浏览器安装 2.浏览器驱动下载 (1)ChromeDriver for Chrome (2)Geckodriver for Firefox (3)IEDriverServer for IE ...

  6. 『心善渊』Selenium3.0基础 — 3、使用Selenium操作浏览器对象的基础API

    目录 1.导入Selenium库 2.创建浏览器对象 3.浏览器窗口大小设置 4.浏览器位置设置 5.请求访问网址 6.浏览器页面前进.后退和刷新 7.关闭浏览器 相比于高大上的各种Selenium进 ...

  7. 『心善渊』Selenium3.0基础 — 4、Selenium基础元素定位详解

    目录 1.什么是元素定位 2.Selenium元素定位常用API (1)By_id 定位 (2)by_name 定位 (3)by_class_name 定位 (4)by_tag_name 定位 (5) ...

  8. 『心善渊』Selenium3.0基础 — 19、使用Selenium操作文件的上传和下载

    目录 1.Selenium实现文件上传 (1)页面中的文件上传说明 (2)文件上传示例 (3)总结 2.Selenium实现文件下载 (1)Firefox浏览器文件下载 1)操作步骤: 2)文件下载示 ...

  9. 『心善渊』Selenium3.0基础 — 20、Selenium对Cookie的操作

    目录 1.Cookie介绍 2.Session介绍 3.Cookie工作原理图解 4.Cookie内容参数说明 5.Selenium操作Cookie的API 6.Selenium操作Cookie的示例 ...

随机推荐

  1. RedisPool

    class RedisPool(object): instance = None def __init__(self, host='192.168.2.129', port=7000, passwor ...

  2. 五、SVM推导过程

    SVM 时间复杂度一般为O(N³) 最重要的是推导过程 NIPS(机器学习顶级会议) 如果给定一个训练集,我们的目标是给定一个边界(一条线),离他最近的训练集样本路越宽越好 下面的几张图反映了SVM的 ...

  3. Structured Streaming编程 Programming Guide

    Structured Streaming编程 Programming Guide Overview Quick Example Programming Model Basic Concepts Han ...

  4. 面部表情视频中进行远程心率测量:ICCV2019论文解析

    面部表情视频中进行远程心率测量:ICCV2019论文解析 Remote Heart Rate Measurement from Highly Compressed Facial Videos: an ...

  5. 三、Nginx设置用户认证

    要求:通过nginx服务端配置实现以下目标 访问web页面需要进行用户认证. 用户名为:tom,密码:123456 操作步骤, 更改配置文件 [root@client ~]# vim /usr/loc ...

  6. Java IO学习笔记六:NIO到多路复用

    作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...

  7. 【NX二次开发】Block UI 集列表

    属性说明 属性   类型   描述   常规           BlockID    String    控件ID    Enable    Logical    是否可操作    Group    ...

  8. 【NX二次开发】批量数字签名的方法,解决自己电脑编译的dll在用户正版NX无法使用的问题

    在UG5.0开始,所有开发的DLL都要"签名"后才能被客户端上正版的NX调用. 1. 如果是基于c++开发的dll,使用如下方法可以顺利签名成功(这里借用网上现有的文字和图片) 1 ...

  9. 一文带你了解 Redis 的发布与订阅的底层原理

    01.前言 发布订阅系统在我们日常的工作中经常会使用到,这种场景大部分情况我们都是使用消息队列的,常用的消息队列有 Kafka,RocketMQ,RabbitMQ,每一种消息队列都有其特性,关于 Ka ...

  10. 树莓派FRP内网穿透及自启动

    内网穿透的步骤和文件存档 实验室在远方部署了电脑主机来采集数据和图片,每次去调试会很麻烦,因而使用FRP内网穿透使得我们可以在实验室访问主机. 主要功能 实现远程可访问和开机自启FRP程序服务 安装和 ...