python-生成HTMLTestRunner测试报告

前提是你 提交于 2019-12-06 15:52:37

一、安装HTMLTestRunner

HTMLTestRunner 是 Python 标准库的 unittest 模块的一个扩展,它可以生成 HTML的 测试报告。
首先要下 HTMLTestRunner.py 文件,将下载的文件放入…\python\Lib目录下
python2版下载地址:http://tungwaiyip.info/software/HTMLTestRunner.html
python3版下载地址:http://pan.baidu.com/s/1dEZQ0pz

在IDLE里引入 HTMLTestRunner 包,如果没有报错,则说明添加成功,如下图:
这里写图片描述

二、代码

all_tests.py

#coding=utf-8
'''
Created on 2017-6-14
@author: 灵枢
Project:通过测试套件执行多个测试用例,并生成报告
'''
import HTMLTestRunner
import unittest
import os,time


listaa = "E:\\selenium_python2\\test_case"
def createsuite1():
    testunit=unittest.TestSuite()
    discover=unittest.defaultTestLoader.discover(listaa,pattern='start_*.py',top_level_dir=None)
    for test_suite in discover:
        for test_case in test_suite:
            testunit.addTests(test_case)
            print(testunit)
    return testunit

now = time.strftime("%Y-%m-%d %H_%M_%S",time.localtime())
filename="E:\\selenium_python2\\report\\"+now+"_result.html"
fp=open(filename,'wb')

runner=HTMLTestRunner.HTMLTestRunner(
    stream=fp,
    title=u'搜索功能测试报告',
    description=u'用例执行情况:')

runner.run(createsuite1())

#关闭文件流,不关的话生成的报告是空的
fp.close()

代码分析

import HTMLTestRunner:要使用 HTMLTestRunner 首先要导入模块

unittest.TestSuite():TestSuite()可以看作成一个容器 ,可通过 addTests 方法把要执行的用例添加到该容器里

defaultTestLoader:测试用例加载器,其包括多个加载测试用例的方法。返回一个测试套件

discover(listaa,pattern=’start*.py’,top_level_dir=None):找到指定目录listaa下所有测试模块;递归查到子目录下名称以start开头的测试用例,只有匹配到文件名才能被加载;如果启动的不是顶层目录,那么顶层目录必须要单独指定,如果没有顶层目录,默认为None

time.strftime(“%Y-%m-%d %H_%M_%S”,time.localtime()):获取当前时间,第一个参数设置时间格式,第二个参数是得到struct_time 形式的当前时间

filename=”E:\selenium_python2\report\”+now+”_result.html”:测试报告的存放路径及文件名,文件名中加了当前时间以便每次生成不同的测试报告

fp=open(filename,’wb’):创测试报告的html文件,此时还是个空文件

runner=HTMLTestRunner.HTMLTestRunner(stream=fp,title=u’搜索功能测试报告’,description=u’用例执行情况:’) :定义 HTMLTestRunner 测试报告,stream 定义报告所写入的文件;title 为报告的标题;description 为报告的说明与描述

runner.run(createsuite1()):运行测试容器中的用例,并将结果写入的报告中

fp.close():关闭文件流,将HTML内容写进测试报告文件

listaa目录下的测试用例:

start_baidu.py
# coding=utf-8
'''
Created on 2017-6-14
@author: 灵枢
Project:登录百度测试用例
'''
from selenium import webdriver
import unittest, time

class BaiduTest(unittest.TestCase):
    def setUp(self):
        self.driver = webdriver.Chrome()
        self.driver.implicitly_wait(30) #隐性等待时间为30秒
        self.base_url = "https://www.baidu.com"

    def test_baidu_search(self):
        u"""百度搜索"""
        driver = self.driver
        driver.get(self.base_url + "/")
        driver.find_element_by_id("kw").clear()
        driver.find_element_by_id("kw").send_keys("unittest")
        driver.find_element_by_id("su").click()
        time.sleep(3)
        title=driver.title
        self.assertEqual(title, u"unittest_百度搜索")

    def test_baidu_set(self):
        u"""百度设置"""
        driver=self.driver
        driver.get(self.base_url+"/gaoji/preferences.html")
        m=driver.find_element_by_name("NR")
        time.sleep(1)
        m.find_element_by_xpath("//option[@value='50']").click()
        time.sleep(1)

    def tearDown(self):
        self.driver.quit()

if __name__ == "__main__":
    unittest.main()
start_sogou.py
# coding=utf-8
'''
Created on 2017-6-14
@author: 灵枢
Project:搜狗搜索测试用例
'''
from selenium import webdriver
import unittest, time

class SogouTest(unittest.TestCase):
    def setUp(self):
        self.driver = webdriver.Chrome()
        self.driver.implicitly_wait(30) #隐性等待时间为30秒
        self.base_url = "http://www.sogou.com"

    def test_sogou(self):
        u"""搜狗搜索"""
        driver = self.driver
        driver.get(self.base_url + "/")
        driver.find_element_by_id("query").clear()
        driver.find_element_by_id("query").send_keys(u"python3")
        driver.find_element_by_id("query").submit()
        time.sleep(3)
        title = driver.title
        self.assertEqual(title, u"python2 - 搜狗搜索")

    def tearDown(self):
        self.driver.quit()

if __name__ == "__main__":
    unittest.main()

三、运行

运行all_tests.py,生成的报告如下:

这里写图片描述

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!