Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 1 | # Copyright (C) 2019 - 2022 Armin Kuster <akuster808@gmail.com> |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 2 | # |
| 3 | from oeqa.runtime.case import OERuntimeTestCase |
| 4 | from oeqa.core.decorator.depends import OETestDepends |
| 5 | from oeqa.runtime.decorator.package import OEHasPackage |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 6 | from oeqa.core.decorator.data import skipIfNotFeature |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 7 | |
| 8 | class Tpm2Test(OERuntimeTestCase): |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 9 | @classmethod |
| 10 | def setUpClass(cls): |
Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 11 | cls.tc.target.run('swtpm_ioctl -s --tcp :2322') |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 12 | cls.tc.target.run('mkdir /tmp/myvtpm2') |
| 13 | |
| 14 | @classmethod |
| 15 | def tearDownClass(cls): |
Andrew Geissler | 615f2f1 | 2022-07-15 14:00:58 -0500 | [diff] [blame] | 16 | cls.tc.target.run('swtpm_ioctl -s --tcp :2322') |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 17 | cls.tc.target.run('rm -fr /tmp/myvtpm2') |
| 18 | |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 19 | def check_endlines(self, results, expected_endlines): |
| 20 | for line in results.splitlines(): |
| 21 | for el in expected_endlines: |
| 22 | if line == el: |
| 23 | expected_endlines.remove(el) |
| 24 | break |
| 25 | |
| 26 | if expected_endlines: |
| 27 | self.fail('Missing expected line endings:\n %s' % '\n '.join(expected_endlines)) |
| 28 | |
Brad Bishop | 26bdd44 | 2019-08-16 17:08:17 -0400 | [diff] [blame] | 29 | @OEHasPackage(['tpm2-tools']) |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 30 | @OEHasPackage(['tpm2-abrmd']) |
| 31 | @OEHasPackage(['swtpm']) |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 32 | @skipIfNotFeature('tpm2','Test tpm2_startup requires tpm2 to be in DISTRO_FEATURES') |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 33 | @OETestDepends(['ssh.SSHTest.test_ssh']) |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 34 | def test_tpm2_startup(self): |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 35 | cmds = [ |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 36 | 'swtpm socket -d --tpmstate dir=/tmp/myvtpm2 --tpm2 --ctrl type=tcp,port=2322 --server type=tcp,port=2321 --flags not-need-init', |
| 37 | 'tpm2_startup -c -T "swtpm:port=2321"', |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 38 | ] |
| 39 | |
| 40 | for cmd in cmds: |
| 41 | status, output = self.target.run(cmd) |
| 42 | self.assertEqual(status, 0, msg='\n'.join([cmd, output])) |
| 43 | |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 44 | @OETestDepends(['tpm2.Tpm2Test.test_tpm2_startup']) |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 45 | def test_tpm2_pcrread(self): |
| 46 | (status, output) = self.target.run('tpm2_pcrread') |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 47 | expected_endlines = [] |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 48 | expected_endlines.append(' sha1:') |
| 49 | expected_endlines.append(' 0 : 0x0000000000000000000000000000000000000000') |
| 50 | expected_endlines.append(' 1 : 0x0000000000000000000000000000000000000000') |
| 51 | expected_endlines.append(' sha256:') |
| 52 | expected_endlines.append(' 0 : 0x0000000000000000000000000000000000000000000000000000000000000000') |
| 53 | expected_endlines.append(' 1 : 0x0000000000000000000000000000000000000000000000000000000000000000') |
| 54 | |
Brad Bishop | 1932369 | 2019-04-05 15:28:33 -0400 | [diff] [blame] | 55 | |
| 56 | self.check_endlines(output, expected_endlines) |
| 57 | |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 58 | |
| 59 | @OEHasPackage(['p11-kit']) |
| 60 | @OEHasPackage(['tpm2-pkcs11']) |
Andrew Geissler | 78b7279 | 2022-06-14 06:47:25 -0500 | [diff] [blame] | 61 | @OETestDepends(['tpm2.Tpm2Test.test_tpm2_pcrread']) |
Andrew Geissler | d583833 | 2022-05-27 11:33:10 -0500 | [diff] [blame] | 62 | def test_tpm2_pkcs11(self): |
| 63 | (status, output) = self.target.run('p11-kit list-modules -v') |
| 64 | self.assertEqual(status, 0, msg="Modules missing: %s" % output) |
| 65 | |
| 66 | @OETestDepends(['tpm2.Tpm2Test.test_tpm2_pkcs11']) |
| 67 | def test_tpm2_swtpm_reset(self): |
| 68 | (status, output) = self.target.run('swtpm_ioctl -i --tcp :2322') |
| 69 | self.assertEqual(status, 0, msg="swtpm reset failed: %s" % output) |