HTMLTestRunner 是 Python 标准库的 unittest 模块的一个扩展,它可以生成 HTML的 测试报告。
首先要下 HTMLTestRunner.py 文件,将下载的文件放入…\python\Lib目录下
python2版下载地址:http://tungwaiyip.info/software/HTMLTestRunner.html
python3版下载地址:http://pan.baidu.com/s/1dEZQ0pz
在IDLE里引入 HTMLTestRunner 包,如果没有报错,则说明添加成功,如下图:
#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内容写进测试报告文件
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()