mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 18:53:23 -03:00
test: allow excluding func test by name and arg
Can now specify test_runner.py --exclude "rpc_bind.py --ipv6" and have only that test variant excluded
This commit is contained in:
parent
aa6b876e01
commit
c4762b0aa0
1 changed files with 15 additions and 7 deletions
|
@ -510,14 +510,22 @@ def main():
|
||||||
|
|
||||||
# Remove the test cases that the user has explicitly asked to exclude.
|
# Remove the test cases that the user has explicitly asked to exclude.
|
||||||
if args.exclude:
|
if args.exclude:
|
||||||
exclude_tests = [test.split('.py')[0] for test in args.exclude.split(',')]
|
def print_warning_missing_test(test_name):
|
||||||
|
print("{}WARNING!{} Test '{}' not found in current test list.".format(BOLD[1], BOLD[0], test_name))
|
||||||
|
exclude_tests = [test.strip() for test in args.exclude.split(",")]
|
||||||
for exclude_test in exclude_tests:
|
for exclude_test in exclude_tests:
|
||||||
# Remove <test_name>.py and <test_name>.py --arg from the test list
|
if exclude_test.endswith('.py'):
|
||||||
exclude_list = [test for test in test_list if test.split('.py')[0] == exclude_test]
|
# Remove <test_name>.py and <test_name>.py --arg from the test list
|
||||||
for exclude_item in exclude_list:
|
exclude_list = [test for test in test_list if test.split('.py')[0] == exclude_test.split('.py')[0]]
|
||||||
test_list.remove(exclude_item)
|
if not exclude_list:
|
||||||
if not exclude_list:
|
print_warning_missing_test(exclude_test)
|
||||||
print("{}WARNING!{} Test '{}' not found in current test list.".format(BOLD[1], BOLD[0], exclude_test))
|
for exclude_item in exclude_list:
|
||||||
|
test_list.remove(exclude_item)
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
test_list.remove(exclude_test)
|
||||||
|
except ValueError:
|
||||||
|
print_warning_missing_test(exclude_test)
|
||||||
|
|
||||||
if args.filter:
|
if args.filter:
|
||||||
test_list = list(filter(re.compile(args.filter).search, test_list))
|
test_list = list(filter(re.compile(args.filter).search, test_list))
|
||||||
|
|
Loading…
Add table
Reference in a new issue