• pytest参数化使用ids当测试用例描述有中文时控制台及报告中用例标题输出为Unicode编码问题(钩子函数:pytest_collection_modifyitems)


      当我们对测试用例进行参数化时,使用@pytest.mark.parametrize的ids参数自定义测试用例的标题,当标题中有中文时,控制台和测试报告中会出现Unicode编码问题,这看起来特别像乱码,我们想让中文正常展示出来,需要用到pytest框架的钩子函数pytest_collection_modifyitems。

    先看问题:

    # file_name: test_parametrize.py
    
    
    import pytest
    
    
    def return_user():
        return [('lwjnicole', '12345'), ('nicole', '123111')]
    
    
    class Test_D:
    
        @pytest.mark.parametrize("username,password",
                                 return_user(),
                                 ids=[
                                     "输入正确的用户名、密码,登录成功",
                                     "输入错误的用户名、密码,登录失败"
                                 ])
        def test_login(self, username, password):
            print("username = {}, password = {}".format(username, password))
            assert username == "lwjnicole"
    
    
    if __name__ == '__main__':
        pytest.main(['-s', 'test_parametrize.py'])

    编辑器中运行上面代码的结果:

    从上面的结果中可以看到用例的标题中文展示为Unicode编码。

    使用钩子函数pytest_collection_modifyitems解决:

    在项目的根目录下,新建conftest.py文件,然后添加如下代码:

    # file_name: conftest.py
    
    
    def pytest_collection_modifyitems(items):
        """
        测试用例收集完成时,将收集到的item的name和nodeid的中文显示在控制台上
        :return:
        """
        for item in items:
            item.name = item.name.encode("utf-8").decode("unicode_escape")
            item._nodeid = item.nodeid.encode("utf-8").decode("unicode_escape")

    然后再次执行下测试用例,运行结果:

     从上面的结果中可以看到用例的标题以中文正常展示了,问题得到解决。

  • 相关阅读:
    kubernetes 在pod内无法ping通servicename和ClusterIP的解决方法
    最小安装的服务器怎么使用nm-connection-editor
    CentOS 系统升级系统内核版本
    kubernetes学习资料
    Docker学习笔记--(超详细)
    Cheat Engine 注入++: (密码=31337157)
    Jupyter-Notebook开机自启动
    kali远程桌面-krdp
    Win10 快捷方式小箭头及小盾牌如何替换
    NumPy学习心得(二)
  • 原文地址:https://www.cnblogs.com/lwjnicole/p/14444898.html
Copyright © 2020-2023  润新知