首页 > 其他分享 >如何解决pytest参数化时出现的Unicode编码问题?

如何解决pytest参数化时出现的Unicode编码问题?

时间:2023-08-04 10:03:43浏览次数:58  
标签:编码 中文 测试报告 Pytest IDs item pytest Unicode

如何解决pytest参数化时出现的Unicode编码问题?_ico

前言

Pytest是一个广泛使用的Python测试框架,通过参数化测试(Parameterized Testing)功能,可以轻松地为测试用例提供多组输入数据。然而,当我们尝试在参数化测试中使用中文作为测试用例的IDs时,有时会遇到Unicode编码问题,导致测试报告中显示的是乱码。本文将详细解释这个问题的原因,并提供解决方案,确保测试报告中正确显示中文IDs。

问题描述

在Pytest中,我们可以使用@pytest.mark.parametrize装饰器来参数化测试用例,并为每组数据提供一个ID,以便在测试报告中区分不同的输入组合。例如:

import pytest

@pytest.mark.parametrize("input, expected", [
    (1, 2),
    (3, 6),
    (0, 0)
], ids=["结果1", "结果2", "结果3"])
def test_multiply(input, expected):
    assert input * 2 == expected

在pycharm里运行代码之后,我们可以看到测试通过,但是ids的输出出现了异常,如下图:

如何解决pytest参数化时出现的Unicode编码问题?_ico_02

我们可以看到 ids 参数用例描述有中文时,显示unicode编码,中文不能正常显示。

问题原因

这个问题的原因是Pytest默认将IDs视为ASCII字符串,并在测试报告中按原样显示。由于中文字符不属于ASCII字符范围,因此Pytest会将其转换为Unicode编码表示。

解决方案

  1. 我们可以在pytest.ini文件中加上如下配置:
disable_test_id_escaping_and_forfeit_all_rights_to_community_support = True

再次运行脚本,结果如下:

如何解决pytest参数化时出现的Unicode编码问题?_ico_03

我们可以看到,中文已经正常输出。

  1. conftest.py中利用pytest提供的hook函数pytest_collection_modifyitems解决unicode编码问题,具体方法如下:
def pytest_collection_modifyitems(items):
    """
    测试用例收集完成时,将收集到的item的name和nodeid的中文显示在控制台上
    """
    for item in items:
        item.name = item.name.encode("utf-8").decode("unicode_escape")
        item._nodeid = item.nodeid.encode("utf-8").decode("unicode_escape")

再次运行脚本,结果如下:

如何解决pytest参数化时出现的Unicode编码问题?_测试用例_04

总结

在Pytest的参数化测试中,使用中文作为测试用例的IDs时,可能会遇到Unicode编码问题,导致测试报告中显示的是乱码。为了解决这个问题,我们可以通过在pytest.ini文件中添加配置项或者在conftest.py文件中添加函数来解决问题,这样,我们就能够获得清晰可读的中文IDs,提高测试报告的可理解性和可维护性。

通过以上解决方案,我们可以在Pytest中正确显示中文IDs,并确保测试报告的准确性和可读性。这将有助于团队成员更好地理解和分析测试结果,提高测试效率和质量。

标签:编码,中文,测试报告,Pytest,IDs,item,pytest,Unicode
From: https://blog.51cto.com/u_15640304/6957264

相关文章

  • 配置文件pytest.ini的详细使用
    使用pytest.ini定制化和管理pytest测试框架的配置前言在使用pytest进行测试时,我们经常需要根据项目的需求进行定制化配置。pytest提供了丰富的配置选项,使我们可以灵活地调整测试框架的行为。其中,pytest.ini文件是一种方便的方式来定义和管理pytest的配置。本文将详细介绍......
  • pytest-xdist分布式测试原理浅析
    pytest-xdist执行流程:解析命令行参数:pytest-xdist会解析命令行参数,获取用户指定的分发模式、进程数、主机列表等信息。加载测试用例:pytest-xdist会加载所有的pytest测试用例,包括在当前目录和子目录下的所有测试文件和测试函数。分发测试用例:根据用户指定的分发模式,py......
  • tlflearn 编码解码器 ——数据降维用
     #-*-coding:utf-8-*-"""AutoEncoderExample.UsinganautoencoderonMNISThandwrittendigits.References:Y.LeCun,L.Bottou,Y.Bengio,andP.Haffner."Gradient-basedlearningappliedtodocumentrecognition."......
  • python coding style guide 的快速落地实践——业内python 编码风格就pep8和谷歌可以
    pythoncodingstyleguide的快速落地实践机器和人各有所长,如codingstyle检查这种可自动化的工作理应交给机器去完成,故发此文帮助你在几分钟内实现codingstyle的自动检查。1.有哪些著名的PythonCodingStyleGuidePEP8https://www.python.org/dev/peps/pep-0008/发明Python语言......
  • 读excel测试用例;登录;做pytest 请求
    1.从excel中读数据 返回【{字典}{字典}】;当传参数时,可以获得对应单元格内容importxlrdimportjsonfromconfigs.configsimportHOSTfromutils.md5importget_md5#在创建excel时,将登录接口的返回结果粘贴到excel时需要“只粘贴文本”#将excel实例化defget_exce......
  • pytest -k 参数 从多个py文件中 指定要运行的方法
    #D:\pythonProject0726\test_case\test_one.pyimporttimedefsetup_module():print('准备测试数据')defteardown_module():print('清理测试数据')deftest_oneone():ex=1real=1time.sleep(3)print('1==1')asse......
  • C#调用Java MD5加密 转换成base64编码
    publicbyte[]GetUTF8(stringcontent){byte[]bytes=Encoding.UTF8.GetBytes(content);returnbytes;}publicbyte[]GetHash(byte[]sources){MD5CryptoServiceProviderMD5CSP=newMD5CryptoS......
  • pytest 中添加线程
    #D:\pythonProject0726\test_case\test_one.pyimporttimedefsetup_module():print('准备测试数据')defteardown_module():print('清理测试数据')deftest_one():ex=1real=1time.sleep(3)print('1==1')assert......
  • RPA开发复杂流程-为什么使用编码自动化而不是低代码?
    答:编码自动化可以让任何熟悉编码或脚本的人都能体验到更高的生产力、更好的复杂性管理、更高的协作和可审查性、改进的可读性和更高的性能。 ......
  • 【HMS Core】位置服务逆地理编码请求错误问题
    【关键字】HMS、位置服务、逆地理编码【问题描述】有开发者反馈在集成位置服务-逆地理编码时,出现了请求报错的问题。后端请求逆地理编码错误{   "returnCode":"010010",   "returnDesc":"INVALID_REQUEST"}【问题分析】1、一开始认为是cp的请求参数有误,缺少了必选的参数。......