diff options
Diffstat (limited to '')
| -rw-r--r-- | lang/python/Makefile.am | 18 | ||||
| -rw-r--r-- | lang/python/tests/Makefile.am | 23 | ||||
| -rw-r--r-- | lang/python/tests/run-tests.py | 90 | 
3 files changed, 122 insertions, 9 deletions
| diff --git a/lang/python/Makefile.am b/lang/python/Makefile.am index 8e18dab3..9ec9c4aa 100644 --- a/lang/python/Makefile.am +++ b/lang/python/Makefile.am @@ -54,8 +54,10 @@ copystamp: $(COPY_FILES) $(COPY_FILES_PYME)  	touch $@  all-local: copystamp -	CFLAGS="$(CFLAGS) -I$(top_srcdir)" \ -	  $(PYTHON) setup.py build --verbose +	for PYTHON in $(PYTHONS); do \ +	  CFLAGS="$(CFLAGS) -I$(top_srcdir)" \ +	    $$PYTHON setup.py build --verbose ; \ +	done  dist/pyme3-$(VERSION).tar.gz dist/pyme3-$(VERSION).tar.gz.asc: copystamp  	CFLAGS="$(CFLAGS) -I$(top_srcdir)" \ @@ -87,10 +89,16 @@ clean-local:  	fi  install-exec-local: -	$(PYTHON) setup.py install \ +	rm -f install_files.txt +	for PYTHON in $(PYTHONS); do \ +	  $$PYTHON setup.py install \  	  --prefix $(DESTDIR)$(prefix) \ -	  --record $(DESTDIR)$(pythondir)/pyme/install_files.txt \ -	  --verbose +	  --record files.txt \ +	  --verbose ; \ +	  cat files.txt >> install_files.txt ; \ +	  rm files.txt ; \ +	done +	mv install_files.txt $(DESTDIR)$(pythondir)/pyme  uninstall-local:  	xargs <$(DESTDIR)$(pythondir)/pyme/install_files.txt -- rm -rf -- diff --git a/lang/python/tests/Makefile.am b/lang/python/tests/Makefile.am index 83c4d8e0..6a315d7c 100644 --- a/lang/python/tests/Makefile.am +++ b/lang/python/tests/Makefile.am @@ -26,8 +26,8 @@ test_srcdir = $(top_srcdir)/tests/gpg  TESTS_ENVIRONMENT = GNUPGHOME=$(abs_builddir) \  	LC_ALL=C GPG_AGENT_INFO= \  	top_srcdir=$(top_srcdir) \ -	LD_LIBRARY_PATH="../../../src/.libs:$(LD_LIBRARY_PATH)" \ -	PYTHONPATH=`echo $(abs_builddir)/../build/lib.*` +	srcdir=$(srcdir) \ +	LD_LIBRARY_PATH="../../../src/.libs:$(LD_LIBRARY_PATH)"  py_tests = t-wrapper.py \  	t-callbacks.py \ @@ -52,8 +52,23 @@ py_tests = t-wrapper.py \  	t-idiomatic.py \  	t-protocol-assuan.py -TESTS = initial.py $(py_tests) final.py -EXTRA_DIST = support.py $(TESTS) encrypt-only.asc sign-only.asc +XTESTS = initial.py $(py_tests) final.py +EXTRA_DIST = support.py $(XTESTS) encrypt-only.asc sign-only.asc \ +             run-tests.py + +# XXX: Currently, one cannot override automake's 'check' target.  As a +# workaround, we avoid defining 'TESTS', thus automake will not emit +# the 'check' target.  For extra robustness, we merely define a +# dependency on 'xcheck', so this hack should also work even if +# automake would emit the 'check' target, as adding dependencies to +# targets is okay. +check: xcheck + +.PHONY: xcheck +xcheck: +	$(TESTS_ENVIRONMENT) $(PYTHON) $(srcdir)/run-tests.py \ +	  --interpreters="$(PYTHONS)" --srcdir=$(srcdir) $(TESTFLAGS) \ +	  $(XTESTS)  CLEANFILES = secring.gpg pubring.gpg pubring.kbx trustdb.gpg dirmngr.conf \  	gpg-agent.conf pubring.kbx~ gpg.conf pubring.gpg~ \ diff --git a/lang/python/tests/run-tests.py b/lang/python/tests/run-tests.py new file mode 100644 index 00000000..55d3f116 --- /dev/null +++ b/lang/python/tests/run-tests.py @@ -0,0 +1,90 @@ +#!/usr/bin/env python + +# Copyright (C) 2016 g10 Code GmbH +# +# This file is part of GPGME. +# +# GPGME is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# GPGME is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY +# or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General +# Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this program; if not, see <http://www.gnu.org/licenses/>. + +from __future__ import absolute_import +from __future__ import division +from __future__ import print_function +from __future__ import unicode_literals + +import argparse +import glob +import os +import subprocess +import sys + +class SplitAndAccumulate(argparse.Action): +    def __call__(self, parser, namespace, values, option_string=None): +        current = getattr(namespace, self.dest, list()) +        current.extend(values.split()) +        setattr(namespace, self.dest, current) + +parser = argparse.ArgumentParser(description='Run tests.') +parser.add_argument('tests', metavar='TEST', type=str, nargs='+', +                    help='A test to run') +parser.add_argument('-v', '--verbose', action="store_true", default=False, +                    help='Be verbose.') +parser.add_argument('--interpreters', metavar='PYTHON', type=str, +                    default=[], action=SplitAndAccumulate, +                    help='Use these interpreters to run the tests, ' + +                    'separated by spaces.') +parser.add_argument('--srcdir', type=str, +                    default=os.environ.get("srcdir", ""), +                    help='Location of the tests.') +parser.add_argument('--builddir', type=str, +                    default=os.environ.get("abs_builddir", ""), +                    help='Location of the tests.') + +args = parser.parse_args() +if not args.interpreters: +    args.interpreters = [sys.executable] + +out = sys.stdout if args.verbose else None +err = sys.stderr if args.verbose else None + +def status_to_str(code): +    return {0: "PASS", 77: "SKIP", 99: "ERROR"}.get(code, "FAIL") + +results = list() +for interpreter in args.interpreters: +    version = subprocess.check_output( +        [interpreter, "-c", "import sys; print('{0}.{1}'.format(sys.version_info[0], sys.version_info[1]))"]).strip().decode() + +    builddirs = glob.glob(os.path.join(args.builddir, "..", "build", +                                       "lib*"+version)) +    assert len(builddirs) == 1, \ +        "Expected one build directory, got {0}".format(builddirs) +    env = dict(os.environ) +    env["PYTHONPATH"] = builddirs[0] + +    print("Running tests using {0} ({1})...".format(interpreter, version)) +    for test in args.tests: +        status = subprocess.call( +            [interpreter, os.path.join(args.srcdir, test)], +            env=env, stdout=out, stderr=err) +        print("{0}: {1}".format(status_to_str(status), test)) +        results.append(status) + +def count(status): +    return len(list(filter(lambda x: x == status, results))) +def failed(): +    return len(list(filter(lambda x: x not in (0, 77, 99), results))) + +print("{0} tests run, {1} succeeded, {2} failed, {3} skipped.".format( +    len(results), count(0), failed(), count(77))) +sys.exit(len(results) - count(0)) | 
