[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.再次运行你的测试脚本
修改前
修改后
从截图中可以明显的看到错误信息显示出界,没有折行,该问题也在解决中。