如何使用 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 的标记并更新 HTML 报告
我已经尝试了很多东西(用多个 Jira ID 标记测试用例(在参数的情况下工作正常我无法解决这个问题。如果有人能提出更好的方法来解决这个问题,我将不胜感激。