mirror of
https://git.yoctoproject.org/meta-security
synced 2026-05-06 04:41:06 +00:00
oeqa/cases/tpm2: fix and enhance test suite
local.conf TEST_SUITES = "ssh ping tpm2" IMAGE_INSTALL:append = " swtpm tpm2-pkcs11" RESULTS: RESULTS - ping.PingTest.test_ping: PASSED (0.05s) RESULTS - ssh.SSHTest.test_ssh: PASSED (2.19s) RESULTS - tpm2.Tpm2Test.test_tpm2_pcrread: PASSED (1.06s) RESULTS - tpm2.Tpm2Test.test_tpm2_pkcs11: PASSED (1.17s) RESULTS - tpm2.Tpm2Test.test_tpm2_swtpm_reset: PASSED (0.59s) RESULTS - tpm2.Tpm2Test.test_tpm2_swtpm_socket: PASSED (307.72s) Signed-off-by: Armin Kuster <akuster808@gmail.com>
This commit is contained in:
@@ -16,28 +16,45 @@ class Tpm2Test(OERuntimeTestCase):
|
||||
if expected_endlines:
|
||||
self.fail('Missing expected line endings:\n %s' % '\n '.join(expected_endlines))
|
||||
|
||||
@OEHasPackage(['tpm2-tss'])
|
||||
@OEHasPackage(['tpm2-abrmd'])
|
||||
@OEHasPackage(['tpm2-tools'])
|
||||
@OEHasPackage(['ibmswtpm2'])
|
||||
@OEHasPackage(['tpm2-abrmd'])
|
||||
@OEHasPackage(['swtpm'])
|
||||
@OETestDepends(['ssh.SSHTest.test_ssh'])
|
||||
def test_tpm2_sim(self):
|
||||
def test_tpm2_swtpm_socket(self):
|
||||
cmds = [
|
||||
'tpm_server &',
|
||||
'tpm2-abrmd --allow-root --tcti=mssim &'
|
||||
'mkdir /tmp/myvtpm',
|
||||
'swtpm socket --tpmstate dir=/tmp/myvtpm --tpm2 --ctrl type=tcp,port=2322 --server type=tcp,port=2321 --flags not-need-init &',
|
||||
'export TPM2TOOLS_TCTI="swtpm:port=2321"',
|
||||
'tpm2_startup -c'
|
||||
]
|
||||
|
||||
for cmd in cmds:
|
||||
status, output = self.target.run(cmd)
|
||||
self.assertEqual(status, 0, msg='\n'.join([cmd, output]))
|
||||
|
||||
@OETestDepends(['tpm2.Tpm2Test.test_tpm2_sim'])
|
||||
def test_tpm2(self):
|
||||
(status, output) = self.target.run('tpm2_pcrlist')
|
||||
@OETestDepends(['tpm2.Tpm2Test.test_tpm2_swtpm_socket'])
|
||||
def test_tpm2_pcrread(self):
|
||||
(status, output) = self.target.run('tpm2_pcrread')
|
||||
expected_endlines = []
|
||||
expected_endlines.append('sha1 :')
|
||||
expected_endlines.append(' 0 : 0000000000000000000000000000000000000003')
|
||||
expected_endlines.append(' 1 : 0000000000000000000000000000000000000000')
|
||||
expected_endlines.append(' sha1:')
|
||||
expected_endlines.append(' 0 : 0x0000000000000000000000000000000000000000')
|
||||
expected_endlines.append(' 1 : 0x0000000000000000000000000000000000000000')
|
||||
expected_endlines.append(' sha256:')
|
||||
expected_endlines.append(' 0 : 0x0000000000000000000000000000000000000000000000000000000000000000')
|
||||
expected_endlines.append(' 1 : 0x0000000000000000000000000000000000000000000000000000000000000000')
|
||||
|
||||
|
||||
self.check_endlines(output, expected_endlines)
|
||||
|
||||
|
||||
@OEHasPackage(['p11-kit'])
|
||||
@OEHasPackage(['tpm2-pkcs11'])
|
||||
@OETestDepends(['tpm2.Tpm2Test.test_tpm2_swtpm_socket'])
|
||||
def test_tpm2_pkcs11(self):
|
||||
(status, output) = self.target.run('p11-kit list-modules -v')
|
||||
self.assertEqual(status, 0, msg="Modules missing: %s" % output)
|
||||
|
||||
@OETestDepends(['tpm2.Tpm2Test.test_tpm2_pkcs11'])
|
||||
def test_tpm2_swtpm_reset(self):
|
||||
(status, output) = self.target.run('swtpm_ioctl -i --tcp :2322')
|
||||
self.assertEqual(status, 0, msg="swtpm reset failed: %s" % output)
|
||||
|
||||
Reference in New Issue
Block a user