zoukankan      html  css  js  c++  java
  • pytest扫盲9--parametrize之ids中文id时,控制台输出出现编码问题

    问题:在验证 parametrize 源码的时候,发现传入 ids 中文 id 后,出现如下编码问题:

    # File  : test_demo_10.py
    # IDE   : PyCharm
    
    import pytest
    
    def division(a, b):
        return int(a / b)
    
    @pytest.mark.parametrize('a, b, c', [(4, 2, 2), (0, 2, 0), (1, 0, 0), (6, 8, 0)], ids=['整除', '被除数为0', '除数为0', '非整除'])
    def test_1(a, b, c):
        res = division(a, b)
        assert res == c
    >>> 执行后中发现文字符编码有问题
    test_demo_10.py::test_1[u6574u9664] test_demo_10.py::test_1[u88abu9664u6570u4e3a0] test_demo_10.py::test_1[u9664u6570u4e3a0] test_demo_10.py::test_1[u975eu6574u9664] ..F.

    解决方法:

      在当前目录 conftest.py 文件中写入 pytest_collection_modifyitems(items) 函数

    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")
            print(item.nodeid)

    再次运行后解决问题>>>

    collecting ... test_demo_10.py::test_1[整除]
    test_demo_10.py::test_1[被除数为0]
    test_demo_10.py::test_1[除数为0]
    test_demo_10.py::test_1[非整除]
    collected 4 items
    喜时之言,多失信;怒时之言,多失体
  • 相关阅读:
    socket.io笔记
    node express+socket.io实现聊天室
    socket.io中 connect与connection的区别
    css clip-path的polygon属性绘制多边形
    vue 3.0
    angular
    项目总结61:IDEA远程调试linux下的tomcat
    Java深入学习28:Redisson分布式锁的使用
    Java深入学习27:Java反射
    Java深入学习28:Runnable和Callable
  • 原文地址:https://www.cnblogs.com/xiaohuboke/p/13530802.html
Copyright © 2011-2022 走看看