chiark / gitweb /
gnupg2 (2.1.17-3) unstable; urgency=medium
[gnupg2.git] / tests / openpgp / signencrypt-dsa.scm
1 #!/usr/bin/env gpgscm
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 (with-path "defs.scm"))
21 (setup-legacy-environment)
22
23 (for-each-p
24  "Checking signing and encryption using DSA"
25  (lambda (source)
26    (tr:do
27     (tr:open source)
28     (tr:gpg usrpass1 `(--yes --passphrase-fd "0" -se
29                              -u ,dsa-usrname1
30                              --recipient ,dsa-usrname2))
31     (tr:gpg "" '(--yes))
32     (tr:assert-identity source)))
33  (append plain-files data-files))
34
35 (define algos (if (have-hash-algo? "RIPEMD160")
36                   '("SHA1" "RIPEMD160")
37                   '("SHA1")))
38 (for-each-p
39  "Checking signing and encryption using DSA with a specific hash algorithm"
40  (lambda (hash)
41    (tr:do
42     (tr:open (car plain-files))
43     (tr:gpg usrpass1 `(--yes --passphrase-fd "0" -se
44                              -u ,dsa-usrname1
45                              --recipient ,dsa-usrname2
46                              --digest-algo ,hash))
47     (tr:gpg "" '(--yes))
48     (tr:assert-identity (car plain-files))))
49  algos)