add new feature: parameters

This commit is contained in:
debugtalk
2018-12-14 17:53:17 +08:00
parent 9f1fb62cd1
commit 5beb25470f
5 changed files with 79 additions and 68 deletions

View File

@@ -841,7 +841,7 @@ def __get_parsed_testsuite_testcases(testcases, testsuite_config, project_mappin
""" override testscases with testsuite config variables, base_url and verify.
variables priority:
testsuite config > testcase config > testcase_def config > testcase_def tests > api
parameters > testsuite config > testcase config > testcase_def config > testcase_def tests > api
Args:
testcases (dict):
@@ -883,9 +883,6 @@ def __get_parsed_testsuite_testcases(testcases, testsuite_config, project_mappin
for testcase_name, testcase in testcases.items():
# TODO: add parameterize
# parameters = testcase.get("parameters")
parsed_testcase = testcase.pop("testcase_def")
parsed_testcase.setdefault("config", {})
parsed_testcase["path"] = testcase["testcase"]
@@ -921,8 +918,28 @@ def __get_parsed_testsuite_testcases(testcases, testsuite_config, project_mappin
if parsed_config_variables:
parsed_testcase["config"]["variables"] = parsed_config_variables
_parse_testcase(parsed_testcase, project_mapping)
parsed_testcase_list.append(parsed_testcase)
# parse parameters
if "parameters" in testcase:
cartesian_product_parameters = parse_parameters(
testcase["parameters"],
parsed_config_variables,
functions
)
for parameter_variables in cartesian_product_parameters:
# deepcopy to avoid influence between parameters
parsed_testcase_copied = utils.deepcopy_dict(parsed_testcase)
parsed_config_variables_copied = utils.deepcopy_dict(parsed_config_variables)
parsed_testcase_copied["config"]["variables"] = utils.extend_variables(
parsed_config_variables_copied,
parameter_variables
)
_parse_testcase(parsed_testcase_copied, project_mapping)
parsed_testcase_list.append(parsed_testcase_copied)
else:
_parse_testcase(parsed_testcase, project_mapping)
parsed_testcase_list.append(parsed_testcase)
return parsed_testcase_list

View File

@@ -310,11 +310,11 @@ def ensure_mapping_format(variables):
"""
if isinstance(variables, list):
variables_ordered_dict = {}
variables_dict = {}
for map_dict in variables:
variables_ordered_dict.update(map_dict)
variables_dict.update(map_dict)
return variables_ordered_dict
return variables_dict
elif isinstance(variables, dict):
return variables

View File

@@ -334,61 +334,36 @@ class TestHttpRunner(ApiServerUnittest):
def test_run_testcase_with_parameters(self):
testcase_file_path = os.path.join(
os.getcwd(), 'tests/data/demo_parameters.yml')
os.getcwd(), 'tests/testsuites/create_users_with_parameters.yml')
self.runner.run(testcase_file_path)
summary = self.runner.summary
# TODO: add parameterize
# self.assertEqual(
# summary["details"][0]["in_out"]["in"]["user_agent"],
# "iOS/10.1"
# )
# self.assertEqual(
# summary["details"][2]["in_out"]["in"]["user_agent"],
# "iOS/10.2"
# )
# self.assertEqual(
# summary["details"][4]["in_out"]["in"]["user_agent"],
# "iOS/10.3"
# )
self.assertTrue(summary["success"])
self.assertEqual(len(summary["details"]), 1)
# self.assertEqual(len(summary["details"]), 3 * 2)
# self.assertEqual(summary["stat"]["testsRun"], 3 * 2)
self.assertIn("in", summary["details"][0]["in_out"])
self.assertIn("out", summary["details"][0]["in_out"])
def test_run_testcase_with_parameters_name(self):
testcase_file_path = os.path.join(
os.getcwd(), 'tests/data/demo_parameters.yml')
tests_mapping = loader.load_tests(testcase_file_path)
parsed_tests_mapping = parser.parse_tests(tests_mapping)
test_suite = self.runner._add_tests(parsed_tests_mapping)
self.assertEqual(len(summary["details"]), 3 * 2)
self.assertEqual(summary["stat"]["testsRun"], 3 * 2 * 4)
self.assertEqual(
test_suite._tests[0].teststeps[0]['name'],
'get token with iOS/10.1 and test1'
summary["details"][0]["name"],
"create user 101 and check result for TESTSUITE_X1."
)
self.assertEqual(
summary["details"][5]["name"],
"create user 103 and check result for TESTSUITE_X2."
)
self.assertEqual(
summary["details"][0]["stat"]["testsRun"],
4
)
self.assertEqual(
summary["details"][0]["records"][2]["name"],
"create user 101 for TESTSUITE_X1"
)
self.assertEqual(
summary["details"][3]["records"][2]["name"],
"create user 102 for TESTSUITE_X2"
)
self.assertEqual(
summary["details"][5]["records"][2]["name"],
"create user 103 for TESTSUITE_X2"
)
# TODO: add parameterize
# self.assertEqual(
# test_suite._tests[1].tests[0]['name'],
# 'get token with iOS/10.1 and test2'
# )
# self.assertEqual(
# test_suite._tests[2].tests[0]['name'],
# 'get token with iOS/10.2 and test1'
# )
# self.assertEqual(
# test_suite._tests[3].tests[0]['name'],
# 'get token with iOS/10.2 and test2'
# )
# self.assertEqual(
# test_suite._tests[4].tests[0]['name'],
# 'get token with iOS/10.3 and test1'
# )
# self.assertEqual(
# test_suite._tests[5].tests[0]['name'],
# 'get token with iOS/10.3 and test2'
# )
# def test_validate_response_content(self):
# # TODO: fix compatibility with Python 2.7
@@ -478,7 +453,7 @@ class TestApi(ApiServerUnittest):
results = tests_results[0][1]
self.assertEqual(
results.records[0]["name"],
"setup and reset all (override)."
"setup and reset all (override) for TESTCASE_CREATE_XXX."
)
self.assertEqual(
results.records[1]["name"],
@@ -512,7 +487,10 @@ class TestApi(ApiServerUnittest):
self.assertIsInstance(testcase_tests["testcase_def"], dict)
self.assertEqual(testcase_tests["testcase_def"]["config"]["name"], "create user and check result.")
self.assertEqual(len(testcase_tests["testcase_def"]["teststeps"]), 4)
self.assertEqual(testcase_tests["testcase_def"]["teststeps"][0]["name"], "setup and reset all (override).")
self.assertEqual(
testcase_tests["testcase_def"]["teststeps"][0]["name"],
"setup and reset all (override) for $device_sn."
)
def test_testsuite_parser(self):
testcase_path = "tests/testsuites/create_users.yml"
@@ -525,7 +503,7 @@ class TestApi(ApiServerUnittest):
self.assertEqual(len(parsed_testcases[0]["teststeps"]), 4)
testcase1 = parsed_testcases[0]["teststeps"][0]
self.assertEqual(testcase1["config"]["name"], "setup and reset all (override).")
self.assertIn("setup and reset all (override)", testcase1["config"]["name"])
self.assertNotIn("testcase_def", testcase1)
self.assertEqual(len(testcase1["teststeps"]), 2)
self.assertEqual(
@@ -544,7 +522,7 @@ class TestApi(ApiServerUnittest):
self.assertEqual(len(test_suite._tests), 2)
tests = test_suite._tests[0].teststeps
self.assertEqual(tests[0]["config"]["name"], "setup and reset all (override).")
self.assertIn("setup and reset all (override)", tests[0]["config"]["name"])
def test_testsuite_run_suite(self):
testcase_path = "tests/testsuites/create_users.yml"
@@ -559,9 +537,9 @@ class TestApi(ApiServerUnittest):
self.assertEqual(len(tests_results[0][1].records), 4)
results = tests_results[0][1]
self.assertEqual(
results.records[0]["name"],
"setup and reset all (override)."
self.assertIn(
"setup and reset all (override)",
results.records[0]["name"]
)
self.assertIn(
results.records[1]["name"],

View File

@@ -8,7 +8,7 @@
base_url: "http://127.0.0.1:5000"
- test:
name: setup and reset all (override).
name: setup and reset all (override) for $device_sn.
testcase: testcases/setup.yml
output:
- token
@@ -24,7 +24,7 @@
- eq: ["content.success", false]
- test:
name: create user $uid
name: create user $uid for $device_sn
api: api/create_user.yml
variables:
user_name: "user1"

View File

@@ -0,0 +1,16 @@
config:
name: create users with uid
variables:
device_sn: ${gen_random_string(15)}
base_url: "http://127.0.0.1:5000"
testcases:
create user $uid and check result for $device_sn.:
testcase: testcases/create_and_check.yml
weight: 2
variables:
uid: 1000
device_sn: TESTSUITE_XXX
parameters:
uid: [101, 102, 103]
device_sn: [TESTSUITE_X1, TESTSUITE_X2]