python: Support the Assuan engine.
[gpgme.git] / lang / python / tests / Makefile.am
1 # Makefile.am for the tests of the Python bindings.
2 # Copyright (C) 2016 g10 Code GmbH
3 #
4 # This file is part of GPGME.
5 #
6 # GPGME is free software; you can redistribute it and/or modify it
7 # under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 2 of the License, or
9 # (at your option) any later version.
10 #
11 # GPGME is distributed in the hope that it will be useful, but WITHOUT
12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 # or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General
14 # Public License for more details.
15 #
16 # You should have received a copy of the GNU Lesser General Public
17 # License along with this program; if not, see <http://www.gnu.org/licenses/>.
18
19 GPG = gpg
20 GPG_AGENT = gpg-agent
21 export GNUPGHOME := $(abs_builddir)
22 export GPG_AGENT_INFO :=
23
24 test_srcdir = $(top_srcdir)/tests/gpg
25
26 TESTS_ENVIRONMENT = GNUPGHOME=$(abs_builddir) \
27         LC_ALL=C GPG_AGENT_INFO= \
28         top_srcdir=$(top_srcdir) \
29         LD_LIBRARY_PATH="../../../src/.libs" \
30         PYTHONPATH=`echo $(abs_builddir)/../build/lib.*`
31
32 py_tests = t-wrapper.py \
33         t-callbacks.py \
34         t-data.py \
35         t-encrypt.py \
36         t-encrypt-sym.py \
37         t-encrypt-sign.py \
38         t-sign.py \
39         t-signers.py \
40         t-decrypt.py \
41         t-verify.py \
42         t-decrypt-verify.py \
43         t-sig-notation.py \
44         t-export.py \
45         t-import.py \
46         t-trustlist.py \
47         t-edit.py \
48         t-keylist.py \
49         t-wait.py \
50         t-encrypt-large.py \
51         t-file-name.py \
52         t-idiomatic.py \
53         t-protocol-assuan.py
54
55 TESTS = initial.py $(py_tests) final.py
56 EXTRA_DIST = support.py $(TESTS) encrypt-only.asc sign-only.asc
57
58 CLEANFILES = secring.gpg pubring.gpg pubring.kbx trustdb.gpg dirmngr.conf \
59         gpg-agent.conf pubring.kbx~ gpg.conf pubring.gpg~ \
60         random_seed .gpg-v21-migrated pubring-stamp
61
62 private_keys = \
63         $(test_srcdir)/13CD0F3BDF24BE53FE192D62F18737256FF6E4FD \
64         $(test_srcdir)/76F7E2B35832976B50A27A282D9B87E44577EB66 \
65         $(test_srcdir)/A0747D5F9425E6664F4FFBEED20FBCA79FDED2BD \
66         $(test_srcdir)/13CBE3758AFE42B5E5E2AE4CED27AFA455E3F87F \
67         $(test_srcdir)/7A030357C0F253A5BBCD282FFC4E521B37558F5C
68
69 clean-local:
70         -$(top_srcdir)/tests/start-stop-agent --stop
71         -rm -fR -- private-keys-v1.d openpgp-revocs.d S.gpg-agent sshcontrol
72
73 check-local: ./gpg.conf ./gpg-agent.conf ./pubring-stamp \
74            ./private-keys-v1.d/gpg-sample.stamp
75
76 # To guarantee that check-local is run before any tests we
77 # add this dependency:
78 initial.py: check-local
79
80 ./private-keys-v1.d/gpg-sample.stamp: $(private_keys)
81         test -d ./private-keys-v1.d || mkdir ./private-keys-v1.d
82         for k in $(private_keys); do \
83           cp $$k private-keys-v1.d/`basename $$k`.key; \
84         done
85         echo x > ./private-keys-v1.d/gpg-sample.stamp
86
87 ./pubring-stamp: $(test_srcdir)/pubdemo.asc
88         $(GPG) --no-permission-warning \
89                --import $(test_srcdir)/pubdemo.asc
90         -$(GPG) --no-permission-warning \
91                 --import $(test_srcdir)/secdemo.asc
92         touch ./pubring-stamp
93
94 ./gpg.conf:
95 # This is required for t-sig-notations.
96         echo no-force-v3-sigs > ./gpg.conf
97
98 ./gpg-agent.conf:
99 # This is required for gpg2, which does not support command fd.
100         echo pinentry-program $(abs_top_srcdir)/tests/gpg/pinentry >$@
101         echo allow-loopback-pinentry >>$@