pytest(三十六)--参数化ids用例描述为中文时,控制台输出unicode编码问题(pytest_collection_modifyitems)
前言
使用pytest.mark.parametrize参数化的时候,加ids参数用例描述有中文时,在控制台输出会显示unicode编码,中文不能正常显示。
使用pytest_collection_modifyitems钩子函数,对输出的item.name和item.nodeid重写编码。
问题描述
参数化ids用例描述有中文
#test_a.py
import pytest
def login(uname,pwd):
return {"code":0,"msg":"success"}
test_datas=[
({"username":"admin1","password":"123456"},"success"),
({"username":"admin2","password":"888888"},"fail")
]
@pytest.mark.parametrize("user,expect",test_datas,
ids=["输入正确账号、密码,登录成功",
"输入错误账号、密码,登录失败"])
def test_login(user,expect):
rs=login(user["username"],user["password"])
assert rs["msg"]==expect
cmd终端运行 pytest

如上图箭头指向的位置,这种不叫乱码,这叫unicode编码
pytest_collection_modifyitems
在项目的根目录写个conftest.py文件,加以下代码
def pytest_collection_modifyitems(items):
"""
测试用例收集完成时,将收集到的name和nodeid的中文显示在控制台上
"""
for i in items:
i.name=i.name.encode("utf-8").decode("unicode_escape")
print(i.nodeid)
i._nodeid=i.nodeid.encode("utf-8").decode("unicode_escape")
cmd控制台重新运行

越努力,越幸运!!!
good good study,day day up!!!
浙公网安备 33010602011771号