使用自定义 id 函数进行 pytest 参数化测试

Gau*_*hah 10 python fixtures pytest python-2.7

我有一个参数化测试,它接受str, 和dict作为参数,因此如果我允许 pytest 生成 ids,那么这个名称看起来很奇怪。

我想使用函数生成自定义 id,但它似乎没有按预期工作。

def id_func(param):
    if isinstance(param, str):
        return param


@pytest.mark.parametrize(argnames=('date', 'category_value'),
                         argvalues=[("2017.01", {"bills": "0,10", "shopping": "100,90", "Summe": "101,00"}),
                                    ("2017.02", {"bills": "20,00", "shopping": "10,00", "Summe": "30,00"})],
                         ids=id_func)
def test_demo(date, category_value):
    pass
Run Code Online (Sandbox Code Playgroud)

我以为它会返回这样的东西

test_file.py::test_demo[2017.01] PASSED
test_file.py::test_demo[2017.02] PASSED
Run Code Online (Sandbox Code Playgroud)

但它正在返回这个。

test_file.py::test_demo[2017.01-category_value0] PASSED
test_file.py::test_demo[2017.02-category_value1] PASSED
Run Code Online (Sandbox Code Playgroud)

有人可以告诉我这有什么问题,或者有什么方法可以实现这一目标吗?

更新:

我意识到问题是什么,将为每个参数调用 if_func ,如果我不返回str任何参数,将调用默认函数。我已经修复了,但这也很难看。

def id_func(param):
    if isinstance(param, str):
        return param
    return " "
Run Code Online (Sandbox Code Playgroud)

现在它返回这样的东西,

test_file.py::test_demo[2017.01- ] PASSED
test_file.py::test_demo[2017.02- ] PASSED
Run Code Online (Sandbox Code Playgroud)

问题是,即使我返回空字符串(即return ""),它也会采用默认表示形式。有人可以告诉我为什么吗?

kch*_*ski 8

一种方法是将您移动argvalues到另一个变量并像这样编写测试:

import pytest


my_args = [
      ("2017.01", {"bills": "0,10", "shopping": "100,90", "Summe": "101,00"}),
      ("2017.02", {"bills": "20,00", "shopping": "10,00", "Summe": "30,00"})
]


@pytest.mark.parametrize(
    argnames=('date', 'category_value'), argvalues=my_args,
    ids=[i[0] for i in my_args]
)
def test_demo(date, category_value):
    pass
Run Code Online (Sandbox Code Playgroud)

测试执行:

$ pytest -v tests.py 
================= test session starts =================
platform linux2 -- Python 2.7.12, pytest-3.2.1, py-1.4.34, pluggy-0.4.0 -- /home/kris/.virtualenvs/2/bin/python2
cachedir: .cache
rootdir: /home/kris/projects/tmp, inifile:
collected 2 items                                      

tests.py::test_demo[2017.01] PASSED
tests.py::test_demo[2017.02] PASSED

============== 2 passed in 0.00 seconds ===============
Run Code Online (Sandbox Code Playgroud)

我认为使用函数(在您的情况下)是不可能的idfn,因为如果它没有为对象生成标签,则使用默认的 pytest 表示。
检查pytest 网站了解详细信息。