From: Martin Pitt Date: Tue, 20 Jan 2015 19:50:35 +0000 (+0100) Subject: test: simplify rules-test.sh wrapper X-Git-Tag: v219~411 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=e8015e6e28fe7d287fc1d5d8bfd82ca65c51326c test: simplify rules-test.sh wrapper Drop globbing of rules/*.rules in the rules-test.sh wrapper and move that logic into the actual test rule-syntax-check.py. This can still be called with individual rules files, but when being called without arguments it will now process all top_builddir/rules/*.rules. Preparation for dropping the shell wrappers altogether. --- diff --git a/test/rule-syntax-check.py b/test/rule-syntax-check.py index 8c0180bd3..80bbe65be 100644 --- a/test/rule-syntax-check.py +++ b/test/rule-syntax-check.py @@ -18,10 +18,20 @@ import re import sys +import os +from glob import glob -if len(sys.argv) < 2: - sys.stderr.write('Usage: %s [...]\n' % sys.argv[0]) - sys.exit(2) +if len(sys.argv) > 1: + # explicit rule file list + rules_files = sys.argv[1:] +else: + # take them from the build dir + root_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) + rules_dir = os.path.join(os.environ.get('top_srcdir', root_dir), 'rules') + if not os.path.isdir(rules_dir): + sys.stderr.write('No rules files given, and %s does not exist, aborting' % rules_dir) + sys.exit(2) + rules_files = glob(os.path.join(rules_dir, '*.rules')) no_args_tests = re.compile('(ACTION|DEVPATH|KERNELS?|NAME|SYMLINK|SUBSYSTEMS?|DRIVERS?|TAG|RESULT|TEST)\s*(?:=|!)=\s*"([^"]*)"$') args_tests = re.compile('(ATTRS?|ENV|TEST){([a-zA-Z0-9/_.*%-]+)}\s*(?:=|!)=\s*"([^"]*)"$') @@ -30,7 +40,7 @@ args_assign = re.compile('(ATTR|ENV|IMPORT|RUN){([a-zA-Z0-9/_.*%-]+)}\s*(=|\+=)\ result = 0 buffer = '' -for path in sys.argv[1:]: +for path in rules_files: lineno = 0 for line in open(path): lineno += 1 diff --git a/test/rules-test.sh b/test/rules-test.sh index 219575360..50b83a3e9 100755 --- a/test/rules-test.sh +++ b/test/rules-test.sh @@ -17,12 +17,10 @@ # You should have received a copy of the GNU Lesser General Public License # along with systemd; If not, see . -[ -n "$srcdir" ] || srcdir=`dirname $0`/.. - # skip if we don't have python type ${PYTHON:-python} >/dev/null 2>&1 || { echo "$0: No $PYTHON installed, skipping udev rule syntax check" exit 0 } -$PYTHON $srcdir/test/rule-syntax-check.py `find $srcdir/rules -name '*.rules'` +$PYTHON $srcdir/test/rule-syntax-check.py