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

问题解释

很多人在使用 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.再次运行你的测试脚本

现象截图

修改前
修改前

修改后
修改后

其他

从截图中可以明显的看到错误信息显示出界,没有折行,该问题也在解决中。


↙↙↙阅读原文可查看相关链接,并与作者交流