我爱编程

python-生成HTMLTestRunner测试报告

2018-03-22  本文已影响0人  倔强_2722

在CSDN上面看到一篇文章,是web自动化测试例子,用的是selenium python,这个里面元素的定位我还不太了解,但是自动化思维是一致的,誊抄下来,留着以后用。

一、安装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 包,如果没有报错,则说明添加成功,如下图: 

HTMLtestrunner安装

之后是给出了alltest.py执行测试套件,并且生成测试报告,然后给出了百度搜索和搜狗搜索的testcase,如下:

二、代码

all_tests.py

#coding=utf-8'''

Created on 2017-6-14

@author: 灵枢

Project:通过测试套件执行多个测试用例,并生成报告

'''import HTMLTestRunnerimport unittestimport os,time

listaa = "E:\\selenium_python2\\test_case"defcreatesuite1():    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

classBaiduTest(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

搜狗搜索类似百度搜索的操作,不再重复复制。

三、运行

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

上一篇 下一篇

猜你喜欢

热点阅读