HTMLTestRunner生成的测试报告为空且用python run 执行程序时报错问题的解决办法

本文主要是介绍HTMLTestRunner生成的测试报告为空且用python run 执行程序时报错问题的解决办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

(1)首先我们要知道HTMLTestRunner是什么用来做什么的。HTMLTestRunner说白了就是一个.py文件,我们安装的python是没有自带的,需要我们手动下载来放到python的库里。放进去以后我们就可以通过这个文件来生成我们的自动化测试报告。
(2)其次我们要知道用python unit-test执行程序时是不执行HTMLTestRunner生成测试报告的,要生成测试报告可以对unittest框架稍作改动或是直接用python run执行即可。
(3)最后我们要知道为什么就算我们用python run 执行程序后程序依旧会报错且生成的测试报告为空。

解疑答惑

(一)HTMLTestRunner的下载

下载地址为:http://tungwaiyip.info/software/HTMLTestRunner.html
如果界面点击下载是直接打开一个浏览器界面显示一篇代码时,那就把它全部复制下来,新建一个txt文档粘贴进去并将文档名字改为HTMLTestRunner的.py文件。

(二)HTMLTestRunner的安装

将该文件放到python安装路径下的Lib下,如…\Python38\Lib 。需要使用时import HTMLTestRunner即可

(三)为什么就算我们用python run 执行程序后程序依旧会报错且生成的测试报告为空的解决办法

(1)为什么会报错呢?
原因一:那是因为HTMLTestRunner是基于python2写的,python3现阶段并没有现成的HTMLTestRunner.py文件。我们将下载下的HTMLTestRunner,py直接使用就会引起一系列的报错
(2)为什么生成的报告为空呢?
原因一:由于上诉报错引起
原因二:文件没有关闭

报错解决办法:将下载的HTMLTestRunner.py文件进行下面项的修改
第94行,将import StringIO修改成import io
第539行,将self.outputBuffer = StringIO.StringIO()修改成self.outputBuffer = io.StringIO()
第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(网络上很多这句是没写的,遗漏了。这句不改会有提示错误且测试报告无法生成)
第774行,将ue = e.decode(‘latin-1’)修改成ue = e(网络上写的是775行是错误的,应该为774行)
第631行,将print >> sys.stderr, ‘\nTime Elapsed: %s’ % (self.stopTime-self.startTime)修改成print(sys.stderr, ‘\nTime Elapsed: %s’ % (self.stopTime-self.startTime))

文件没有关闭导致测试报告为空的解决办法: 代码结尾加一个fp.close()如下所示

if __name__ == "__main__":
#测试套件testunit=unittest.TestSuite()
#添加测试用例到测试套件中testunit.addTest(Baidu("test_baidu_search"))
#定义个报告存放路径filename = 'D:\\report\\result.html'fp =open(filename,'wb')
#定义测试报告runner =HTMLTestRunner.HTMLTestRunner(stream=fp,title=u'百度搜索测试报告',description=u'用例执行情况:')
#运行测试用例runner.run(testunit)
#关闭报告文件fp.close()

生成的测试报告效果图
在这里插入图片描述

这篇关于HTMLTestRunner生成的测试报告为空且用python run 执行程序时报错问题的解决办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/687845

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,