前言
使用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控制台重新运行