您的位置:首页 > Web前端 > HTML

解决 HTMLTestRunner 中文显示乱码的问题

2014-10-14 20:24 441 查看
转载地址:http://testerhome.com/topics/1468


问题解释

很多人在使用Python做自动化测试时都会用到Unittest测试框架,同时也会使用HTMLTestRunner来生成HTML格式的测试报告,但在生成的测试报告中如果存在中文时,会出现中文显示为乱码的现象,这是由于编码格式不一致所导致的问题。


解决方法

在Google中搜索了一会儿,没有发现与该问题相关的信息,Github上也没有相关的Issues和Pull requests,我觉得可能有四种情况,一是用的人报告中没有出现中文,二是遇到了并解决了但没有记录或分享出来,三是遇到了但未解决,最后还有一种可能是我的搜索方式不够好,以至于没搜到,总之现在可以通过下面的方法来解决该问题。

1.在自己的测试脚本中加入下面的代码并保存:
import sys
reload(sys)
sys.setdefaultencoding('utf-8')


2.打开HTMLTestRunner.py(基于Github上最新的代码),修改其中的第777行和第783行,将其中的编码“latin-1”修改为“utf-8”后保存,具体如下所示:
if isinstance(o,str):
# TODO: some problem with 'string_escape': it escape \n and mess up formating
# uo = unicode(o.encode('string_escape'))
uo = o.decode('utf-8')
else:
uo = o
if isinstance(e,str):
# TODO: some problem with 'string_escape': it escape \n and mess up formating
# ue = unicode(e.encode('string_escape'))
ue = e.decode('utf-8')
else:
ue = e


3.再次运行你的测试脚本


现象截图

修改前






修改后







其他

从截图中可以明显的看到错误信息显示出界,没有折行,该问题也在解决中。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: