如何用PyTest报告与断言相同数量的测试用例?
当前,在我的测试框架中,1个测试函数可以包含多个断言,这些断言属于JIRA中的不同测试用例。
# A simple use-case of what I want to achieve
def test_one(request):
assert 1 == 1 # QA-1234 Passed
assert 2 == 1 # QA-4567 Failed
我尝试使用pytest.fixture
解决此问题,但是当断言数量增加时,它不是可扩展的解决方案。如下面的代码片段所示,我将不得不继续为每个断言创建不同的pytest测试函数。
value1 = 10
value2 = "golden"
value3 = None
@pytest.fixture()
def check_value1_value2_value3():
testcase_ids = {}
testcase_ids['QA-1234'] = value1 == 10
testcase_ids['QA-5678'] = value2 == 'silver'
testcase_ids['QA-6789'] = value3 is not None
def test_value1(check_value1_value2_value3):
testcases = check_value1_value2_value3
assert testcases['QA-1234'] == True
def test_value2(check_value1_value2_value3):
testcases = check_value1_value2_value3
assert testcases['QA-5678'] == True
def test_value3(check_value1_value2_value3):
testcases = check_value1_value2_value3
assert testcases['QA-6789'] == False
以下是我已经尝试过的解决方案:
我已经尝试了很多方法(用多个Jira ID标记测试用例(在参数化的情况下效果很好,但我无法解决此问题。如果有人可以提出解决该问题的更好方法,我将非常感激。< / p>
答案 0 :(得分:0)
尽管这个问题对我来说还不清楚。让我具体了解所提供的问题说明
您可以尝试使用此pytest插件https://pypi.org/project/pytest-jira/0.2.3/ 这应该可以解决您要针对jira问题标记测试用例的目的
一个测试用例可以有'n'个断言,但是不建议针对布尔型断言-而是以dict形式返回每个断言的状态并简化您的断言
< / li>