3 ;; Copyright (C) 2016 g10 Code GmbH
5 ;; This file is part of GnuPG.
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.
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.
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/>.
20 (load (with-path "common.scm"))
22 (catch (skip "gpgtar not built")
23 (call-check `(,GPGTAR --help)))
25 (define src-tarball (in-srcdir "from-classic.tar.asc"))
28 (untar-armored src-tarball)
29 (setenv "GNUPGHOME" (getcwd) #t))
31 (define (trigger-migration)
32 (call-check `(,@GPG --list-secret-keys)))
34 (define (assert-migrated)
35 (unless (file-exists? ".gpg-v21-migrated")
36 (error "Not migrated"))
40 (catch (error "Key not found:" keyid)
41 (call-check `(,@GPG --list-secret-keys ,keyid))))
42 '("D74C5F22" "C40FDECF" "ECABF51D")))
44 (info "Testing a clean migration ...")
45 (with-temporary-working-directory
50 (info "Testing a migration with existing private-keys-v1.d ...")
51 (with-temporary-working-directory
53 (mkdir "private-keys-v1.d" "-rwx")
57 (info "Testing a migration with existing but weird private-keys-v1.d ...")
58 (with-temporary-working-directory
60 (mkdir "private-keys-v1.d" "")
64 ;; XXX Check a case where the migration fails.