• 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
    喜时之言,多失信;怒时之言,多失体
  • 相关阅读:
    A. Ivan the Fool and the Probability Theory
    C2. Good Numbers (hard version)
    C. p-binary
    H. Happy Birthday
    idea使用goeasy实现webSocket
    idea新建一个maven项目
    FreeMaker入门介绍
    mui预加载
    mui底部选项卡切换实现
    BootStrap 学习笔记一
  • 原文地址:https://www.cnblogs.com/xiaohuboke/p/13530802.html
Copyright © 2020-2023  润新知