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!!!
原文地址:https://www.cnblogs.com/canglongdao/p/13418305.html