1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-04 12:21:31 +01:00
gnupg/tests/tpm2dtests/unimportable.scm
James Bottomley 6720f1343a
tpm2d: add tests for the tpm2daemon
* configure.ac: Detect TPM emulator and enable tests.
* tests/tpm2dtests/: New test suite.
* tests/Makefile.am: Run tests.

--
Add a set of tests that exercise tpm2daemon handling of keys and
verify compatibility with non-tpm based keys.

Running this test infrastructure requires a tpm emulator, which is
tested for during configuration.  If an emulator is not found, the
tests won't be run since they require the presence of a TPM (although
the TPM handling code will still be built).

Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>

- Fixed tests/Makefile.am for make distcheck.

Signed-off-by: Werner Koch <wk@gnupg.org>
2021-03-10 14:29:50 +01:00

29 lines
870 B
Scheme

#!/usr/bin/env gpgscm
;; Copyright (C) 2021 James.Bottomley@HansenPartnership.com
;;
;; SPDX-License-Identifier: GPL-3.0-or-later
;;
(load (in-srcdir "tests" "tpm2dtests" "defs.scm"))
(setup-environment)
(setenv "PINENTRY_USER_DATA" "this is a password" #t)
;;
;; Tries to import a selection of keys with no TPM representation
;; and verifies it fails. There are many unimportable keys, so
;; save time by only choosing one EC and one RSA one
;;
(define key-list '("ed25519" "rsa4096"))
(for-each
(lambda(algo)
(info "Checking failure to import" algo)
(define name algo "<ecc" algo "@example.com>")
(call-check `(,@GPG --quick-generate-key ,name ,algo))
(let ((result (call-with-io `(,@GPG --command-fd=0 --edit-key ,name "key 0" keytotpm) "y\n")))
(if (= 0 (:retcode result))
(throw "Importing Key succeeded")
(:stderr result))))
key-list)