mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-03 22:56:33 +02:00
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>
This commit is contained in:
parent
92b601fcee
commit
6720f1343a
12 changed files with 895 additions and 1 deletions
28
tests/tpm2dtests/unimportable.scm
Normal file
28
tests/tpm2dtests/unimportable.scm
Normal file
|
@ -0,0 +1,28 @@
|
|||
#!/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)
|
Loading…
Add table
Add a link
Reference in a new issue