From: Petteri Aimonen Date: Sun, 20 Jul 2014 11:55:47 +0000 (+0300) Subject: Add support for inverted patterns in test framework. X-Git-Tag: 3.99.1~14^2~219 X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=commitdiff_plain;h=5749606f5d2f0a0c64cb6e021b7bd40b74ce45ee;p=apps%2Flow-level-can-service.git Add support for inverted patterns in test framework. --- diff --git a/tests/site_scons/site_init.py b/tests/site_scons/site_init.py index 5fb06d6..da5f6d6 100644 --- a/tests/site_scons/site_init.py +++ b/tests/site_scons/site_init.py @@ -85,9 +85,20 @@ def add_nanopb_builders(env): data = open(str(source[0]), 'rU').read() patterns = open(str(source[1])) for pattern in patterns: - if pattern.strip() and not re.search(pattern.strip(), data, re.MULTILINE): - print '\033[31m[FAIL]\033[0m Pattern not found in ' + str(source[0]) + ': ' + pattern - return 1 + if pattern.strip(): + invert = False + if pattern.startswith('! '): + invert = True + pattern = pattern[2:] + + status = re.search(pattern.strip(), data, re.MULTILINE) + + if not status and not invert: + print '\033[31m[FAIL]\033[0m Pattern not found in ' + str(source[0]) + ': ' + pattern + return 1 + elif status and invert: + print '\033[31m[FAIL]\033[0m Pattern should not exist, but does in ' + str(source[0]) + ': ' + pattern + return 1 else: print '\033[32m[ OK ]\033[0m All patterns found in ' + str(source[0]) return 0