Python+Selenium之HTMLTestRunner

Stella981
• 阅读 734

下载 HTMLTestRunner 模块

下载地址:http://tungwaiyip.info/software/HTMLTestRunner.html

保存路径:将下载的HTMLTestRunner.py文件复制到Python安装路径下的Lib目录

验证:在Python交互模式下引入HTMLTestRunner模块,如系统没有报错,则说明添加成功

Python+Selenium之HTMLTestRunner

修改HTMLTestRunner(针对Python3)

因为HTMLTestRunner是基于Python2开发的,如果在Python3环境下使用,需要对其部分内容进行修改。使用notepad++打开HTMLTestRunner.py文件,修改如下内容: 

第94行,将 import StringIO修改成import io

第539行,将 self.outputBuffer = StringIO.StringIO()修改成self.outputBuffer= io.StringIO()

第631行,将 print >> sys.stderr, ‘\nTime Elapsed: %s‘  %(self.stopTime-self.startTime)修改成print(sys.stderr, ‘\nTimeElapsed: %s‘ % (self.stopTime-self.startTime))

第642行,将 if not rmap.has_key(cls):修改成 if not cls in rmap:

第766行,将 uo = o.decode(‘latin-1‘)修改成 uo = e

第772行,将 ue = e.decode(‘latin-1‘)修改成 ue = e 

一个简单的例子

# -*- coding: utf-8 -*-
from selenium import webdriver from HTMLTestRunner import HTMLTestRunner #导入HTMLTestRunner模块 import unittest,time class BaiduIdeTest(unittest.TestCase): #三引号表示doc string类型注释,用来描述函数、类和方法 '''baidu search testing'''  def setUp(self): self.driver = webdriver.Firefox() self.driver.implicitly_wait(30) self.base_url = "https://www.baidu.com/" def test_baidu_ide(self): '''Search Keyword''' driver = self.driver driver.get(self.base_url) driver.find_element_by_id("kw").clear() driver.find_element_by_id("kw").send_keys("HTMLTestRunner") driver.find_element_by_id("su").click() time.sleep(5) self.assertEqual(u"HTMLTestRunner_百度搜索", driver.title) def tearDown(self): self.driver.quit() if __name__ == "__main__": #构造测试套件  testsuit = unittest.TestSuite() testsuit.addTest(BaiduIdeTest("test_baidu_ide")) #按照一定格式获取当前时间,%Y表示带世纪的年(2019),%y表示不带世纪的年(19),time.strftime()表示获得当前时间并格式化字符串    now = time.strftime("%Y%m%d_%H%M%S")    #将当前时间加入到报告文件名称中    filename = './'+now+'result.html' #定义测试报告存放路径,通过open()方法以二进制写模式('wb')打开当前目录下的result.heml,如果没有,则自动创建。  fp = open('./result.html','wb') #定义测试报告,调用HTMLTestRunner模块下的HTMLTestRunner类,stream 指定测试报告文件,title 定义测试报告的标题,description 定义测试报告的副标题 runner = HTMLTestRunner(stream=fp,title='自动化测试报告',description='用例执行情况:')  #通过HTMLTestRunner的run()方法来运行测试套件中的测试用例 runner.run(testsuit) #关闭测试报告  fp.close()

Python+Selenium之HTMLTestRunner 你可以根据测试需要添加多个测试,例如再新加一个类以及测试方法,然后通过 testsuit.addTest 把类和方法加进去,如果需要添加的测试比较多,可以通过discover方法,例子如下:

from unittest import defaultTestLoader

case_path = './TestCases'

def get_allcase(): discover = unittest.defaultTestLoader.discover(case_path, pattern="test_Create_GL_Indicative_Quoted.py") testsuite = unittest.TestSuite() testsuite.addTest(discover) return testsuiteif __name__ == "__main__": now = time.strftime("%Y%m%d_%H%M%S") filename = 'C:\MIG_Portal_Automation\TestReports/' + now + 'result.html' fp = open(filename, 'wb') runner = HTMLTestRunner(stream=fp, title='automation report', description='case execution status') runner.run(get_allcase()) fp.close()
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
3年前
Python 环境搭建
pythonbug集目录\toc\00python模块下载地址pyhton模块下载地址(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fwww.lfd.uci.edu%2F%7Egohlke%2Fpythonlibs%2F)01pythonpip
Wesley13 Wesley13
3年前
Python使用TestLoader、TestSuite、HTMLTestRunner组织测试用例实例
HTMLTestRunner.py:http://tungwaiyip.info/software/HTMLTestRunner.html(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Ftungwaiyip.info%2Fsoftware%2FHTMLTestRunner.html)
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这