f118642015ee12b7087e2089921ad3a0f27a76fb
[gnupg.git] / tests / gpgsm / gpgsm-defs.scm
1 ;; Common definitions for the GPGSM test scripts.
2 ;;
3 ;; Copyright (C) 2016 g10 Code GmbH
4 ;;
5 ;; This file is part of GnuPG.
6 ;;
7 ;; GnuPG is free software; you can redistribute it and/or modify
8 ;; it under the terms of the GNU General Public License as published by
9 ;; the Free Software Foundation; either version 3 of the License, or
10 ;; (at your option) any later version.
11 ;;
12 ;; GnuPG is distributed in the hope that it will be useful,
13 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
14 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 ;; GNU General Public License for more details.
16 ;;
17 ;; You should have received a copy of the GNU General Public License
18 ;; along with this program; if not, see <http://www.gnu.org/licenses/>.
19
20 (load (in-srcdir "tests" "openpgp" "defs.scm"))
21
22 ;; This is the list of certificates that we install in the test
23 ;; environment.
24 (define certs
25   (package
26    (define (new fpr issuer-fpr uid)
27      (package))
28    (define (new-uid CN OU O L C)
29      (package))
30    (define test-1 (new "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E"
31                        "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E"
32                        (new-uid "test cert 1"
33                                 "Aegypten Project"
34                                 "g10 Code GmbH"
35                                 "Düsseldorf"
36                                 "DE")))))
37 (define all-certs (list certs::test-1))
38
39 (define gpgsm `(,(tool 'gpgsm) --yes)) ;; more/less options
40
41 (define (tr:gpgsm input args)
42   (tr:spawn input `(,@gpgsm --output **out** ,@args **in**)))
43
44 (define (pipe:gpgsm args)
45   (pipe:spawn `(,@gpgsm --output - ,@args -)))
46
47 (define (gpgsm-with-colons args)
48   (let ((s (call-popen `(,@gpgsm --with-colons ,@args) "")))
49     (map (lambda (line) (string-split line #\:))
50          (string-split-newlines s))))
51
52 (define (sm-have-public-key? key)
53   (catch #f
54          (pair? (filter (lambda (l) (and (equal? 'fpr (:type l))
55                                          (equal? key::fpr (:fpr l))))
56                         (gpgsm-with-colons `(--list-keys ,key::fpr))))))
57
58 (define (sm-have-secret-key? key)
59   (catch #f
60          (pair? (filter (lambda (l) (and (equal? 'fpr (:type l))
61                                          (equal? key::fpr (:fpr l))))
62                         (gpgsm-with-colons `(--list-secret-keys ,key::fpr))))))
63
64 (define (create-gpgsmhome)
65   (create-file "gpgsm.conf"
66                "disable-crl-checks"
67                "faked-system-time 1008241200")
68   (create-file "gpg-agent.conf"
69                (string-append "pinentry-program " (tool 'pinentry))
70                (if (assoc "scdaemon" gpg-components)
71                    (string-append "scdaemon-program " (tool 'scdaemon))
72                    "# No scdaemon available")
73                )
74   (start-agent)
75   (create-file
76    "trustlist.txt"
77    "32100C27173EF6E9C4E9A25D3D69F86D37A4F939"
78    "# CN=test cert 1,OU=Aegypten Project,O=g10 Code GmbH,L=Düsseldorf,C=DE"
79    "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E S")
80
81   (log "Storing private keys")
82   (for-each
83    (lambda (name)
84      (file-copy (in-srcdir "tests" "gpgsm" name)
85                 (path-join "private-keys-v1.d"
86                            (string-append name ".key"))))
87    '("32100C27173EF6E9C4E9A25D3D69F86D37A4F939"))
88
89   (log "Importing public demo and test keys")
90   (call-check `(,@gpgsm --import ,(in-srcdir "tests" "gpgsm" "cert_g10code_test1.der")))
91
92   (create-sample-files)
93   (stop-agent))
94
95 ;; Initialize the test environment, install appropriate configuration
96 ;; and start the agent, with the keys from the legacy test suite.
97 (define (setup-gpgsm-environment)
98   (if (member "--unpack-tarball" *args*)
99       (call-check `(,(tool 'gpgtar) --extract --directory=. ,(cadr *args*)))
100       (create-gpgsm-gpghome))
101   (start-agent))
102
103 (define (setup-gpgsm-environment-no-atexit)
104   (if (member "--unpack-tarball" *args*)
105       (call-check `(,(tool 'gpgtar) --extract --directory=. ,(cadr *args*)))
106       (create-gpgsm-gpghome))
107   (start-agent #t))