Merge branch 'master' into STABLE-BRANCH-2-2
[gnupg.git] / tests / openpgp / conventional-mdc.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
22 (define s2k '--s2k-count=65536)
23 (define passphrase "Hier spricht HAL")
24
25 (define (file-copy-n from to n)
26   (catch '() (unlink to))
27   (letfd ((source (open from (logior O_RDONLY O_BINARY)))
28           (sink (open to (logior O_WRONLY O_CREAT O_BINARY) #o600)))
29     (splice source sink n)))
30
31 (define test-files
32   (map (lambda (size)
33          (let ((tmp (make-temporary-file
34                      (string-append "data-80000-" (number->string size)))))
35            (file-copy-n "data-80000" tmp size)
36            tmp))
37        '(0 1 2 3 9 10 11 19 20 21 22 23 39 40 41 8192 32000)))
38
39 (for-each-p
40  "Checking conventional encryption with MDC"
41  (lambda (algo)
42    (for-each-p
43     ""
44     (lambda (source)
45       (tr:do
46        (tr:open source)
47        (tr:gpg passphrase `(--yes --passphrase-fd "0" ,s2k
48                                   --force-mdc -c
49                                   --cipher-algo ,algo))
50        (tr:gpg passphrase `(--yes --passphrase-fd "0" ,s2k))
51        (tr:assert-identity source)))
52     test-files))
53  all-cipher-algos)
54
55 (for-each remove-temporary-file test-files)
56
57 (for-each-p
58  "Checking sign+symencrypt"
59  (lambda (source)
60    (tr:do
61     (tr:open source)
62      (tr:gpg passphrase `(--yes --passphrase-fd "0" ,s2k -cs))
63      (tr:gpg passphrase `(--yes --passphrase-fd "0" ,s2k))
64      (tr:assert-identity source)))
65  (append plain-files data-files))