aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIgor Gnatenko <i.gnatenko.brain@gmail.com>2015-03-25 22:44:01 +0300
committerIgor Gnatenko <i.gnatenko.brain@gmail.com>2015-03-25 22:44:01 +0300
commite0ba9ba2b9c9433d35bfde8695c43a46a1a0c23b (patch)
tree59a7a1ff413abcbf3d42d0173d5f7abd30363842
parentb723be2640ac2b049d9e4982f56c1cf10657fd53 (diff)
downloadmeson-e0ba9ba2b9c9433d35bfde8695c43a46a1a0c23b.zip
meson-e0ba9ba2b9c9433d35bfde8695c43a46a1a0c23b.tar.gz
meson-e0ba9ba2b9c9433d35bfde8695c43a46a1a0c23b.tar.bz2
tests: add skipped tests
Signed-off-by: Igor Gnatenko <i.gnatenko.brain@gmail.com>
-rwxr-xr-xrun_tests.py72
1 files changed, 30 insertions, 42 deletions
diff --git a/run_tests.py b/run_tests.py
index c789fb9..fb85f51 100755
--- a/run_tests.py
+++ b/run_tests.py
@@ -26,6 +26,7 @@ from meson import backendlist
passing_tests = 0
failing_tests = 0
+skipped_tests = 0
print_debug = 'MESON_PRINT_TEST_OUTPUT' in os.environ
test_build_dir = 'work area'
@@ -196,44 +197,23 @@ def gather_tests(testdir):
def detect_tests_to_run():
all_tests = []
- all_tests.append(('common', gather_tests('test cases/common')))
- all_tests.append(('failing', gather_tests('test cases/failing')))
- all_tests.append(('prebuilt object', gather_tests('test cases/prebuilt object')))
+ all_tests.append(('common', gather_tests('test cases/common'), False))
+ all_tests.append(('failing', gather_tests('test cases/failing'), False))
+ all_tests.append(('prebuilt object', gather_tests('test cases/prebuilt object'), False))
if mesonlib.is_osx():
- all_tests.append(('platform', gather_tests('test cases/osx')))
+ all_tests.append(('platform', gather_tests('test cases/osx'), False))
elif mesonlib.is_windows():
- all_tests.append(('platform', gather_tests('test cases/windows')))
+ all_tests.append(('platform', gather_tests('test cases/windows'), False))
else:
- all_tests.append(('platform', gather_tests('test cases/linuxlike')))
- if not mesonlib.is_osx() and not mesonlib.is_windows():
- all_tests.append(('framework', gather_tests('test cases/frameworks')))
- else:
- all_tests.append(('framework', []))
- if not mesonlib.is_osx() and shutil.which('javac'):
- all_tests.append(('java', gather_tests('test cases/java')))
- else:
- all_tests.append(('java', []))
- if shutil.which('mcs'):
- all_tests.append(('C#', gather_tests('test cases/csharp')))
- else:
- all_tests.append(('C#', []))
- if shutil.which('valac'):
- all_tests.append(('vala', gather_tests('test cases/vala')))
- else:
- all_tests.append(('vala', []))
- if shutil.which('rustc'):
- all_tests.append(('rust', gather_tests('test cases/rust')))
- else:
- all_tests.append(('rust', []))
- if not mesonlib.is_windows():
- all_tests.append(('objective c', gather_tests('test cases/objc')))
- else:
- all_tests.append(('objective c', []))
- if shutil.which('gfortran'):
- all_tests.append(('fortran', gather_tests('test cases/fortran')))
- else:
- all_tests.append(('fortran', []))
+ all_tests.append(('platform', gather_tests('test cases/linuxlike'), False))
+ all_tests.append(('framework', gather_tests('test cases/frameworks'), False if not mesonlib.is_osx() and not mesonlib.is_windows() else True))
+ all_tests.append(('java', gather_tests('test cases/java'), False if not mesonlib.is_osx() and shutil.which('javac') else True))
+ all_tests.append(('C#', gather_tests('test cases/csharp'), False if shutil.which('mcs') else True))
+ all_tests.append(('vala', gather_tests('test cases/vala'), False if shutil.which('valac') else True))
+ all_tests.append(('rust', gather_tests('test cases/rust'), False if shutil.which('rustc') else True))
+ all_tests.append(('objective c', gather_tests('test cases/objc'), False if not mesonlib.is_windows() else True))
+ all_tests.append(('fortran', gather_tests('test cases/fortran'), False if shutil.which('gfortran') else True))
return all_tests
def run_tests():
@@ -249,21 +229,28 @@ def run_tests():
except OSError:
pass
- for name, test_cases in all_tests:
- if len(test_cases) == 0:
+ for name, test_cases, skipped in all_tests:
+ current_suite = ET.SubElement(junit_root, 'testsuite', {'name' : name, 'tests' : str(len(test_cases))})
+ if skipped:
print('\nNot running %s tests.\n' % name)
else:
- current_suite = ET.SubElement(junit_root, 'testsuite', {'name' : name, 'tests' : str(len(test_cases))})
print('\nRunning %s tests.\n' % name)
- for t in test_cases:
+ for t in test_cases:
+ # Jenkins screws us over by automatically sorting test cases by name
+ # and getting it wrong by not doing logical number sorting.
+ (testnum, testbase) = os.path.split(t)[-1].split(' ', 1)
+ testname = '%.3d %s' % (int(testnum), testbase)
+ if skipped:
+ current_test = ET.SubElement(current_suite, 'testcase', {'name' : testname,
+ 'classname' : name})
+ ET.SubElement(current_test, 'skipped', {})
+ global skipped_tests
+ skipped_tests += 1
+ else:
ts = time.time()
(msg, stdo, stde) = run_test(t, name != 'failing')
te = time.time()
log_text_file(logfile, t, msg, stdo, stde)
- # Jenkins screws us over by automatically sorting test cases by name
- # and getting it wrong by not doing logical number sorting.
- (testnum, testbase) = os.path.split(t)[-1].split(' ', 1)
- testname = '%.3d %s' % (int(testnum), testbase)
current_test = ET.SubElement(current_suite, 'testcase', {'name' : testname,
'classname' : name,
'time' : '%.3f' % (te - ts)})
@@ -327,5 +314,6 @@ if __name__ == '__main__':
os.unlink(pbfile)
print('\nTotal passed tests:', passing_tests)
print('Total failed tests:', failing_tests)
+ print('Total skipped tests:', skipped_tests)
sys.exit(failing_tests)