1.. _tfm_psa_test:
2
3TF-M Platform Security Architecture Test Sample
4###############################################
5
6Overview
7********
8
9Run PSA test suites tests with Zephyr and TFM.
10
11The PSA tests are implemented in the psa-arch-tests repo: https://github.com/ARM-software/psa-arch-tests
12
13This sample is supported for platforms that have a port in psa-arch-tests.
14See sample.yaml for a list of supported platforms.
15
16Building and Running
17********************
18
19You must choose a suite via the CONFIG_TFM_PSA_TEST_* configs.
20
21Only one of these suites can be run at a time, with the test suite set via one
22of the following kconfig options:
23
24* ``CONFIG_TFM_PSA_TEST_CRYPTO``
25* ``CONFIG_TFM_PSA_TEST_PROTECTED_STORAGE``
26* ``CONFIG_TFM_PSA_TEST_INTERNAL_TRUSTED_STORAGE``
27* ``CONFIG_TFM_PSA_TEST_STORAGE``
28* ``CONFIG_TFM_PSA_TEST_INITIAL_ATTESTATION``
29
30You can indicate the desired test suite at build time via a config flag:
31
32   .. code-block:: bash
33
34     $ west build samples/tfm_integration/tfm_psa_test/ \
35       -p -b mps2/an521/cpu0/ns -t run -- \
36       -DCONFIG_TFM_PSA_TEST_STORAGE=y
37
38Note that not all test suites are valid on all boards.
39
40On Target
41=========
42
43Refer to :zephyr:code-sample:`tfm_ipc` for detailed instructions.
44
45On QEMU:
46========
47
48Refer to :zephyr:code-sample:`tfm_ipc` for detailed instructions.
49Following is an example based on ``west build``
50
51   .. code-block:: bash
52
53      $ west build samples/tfm_integration/tfm_psa_test/ -p -b mps2/an521/cpu0/ns -t run -- -DCONFIG_TFM_PSA_TEST_STORAGE=y
54
55Sample Output
56=============
57
58   .. code-block:: console
59
60      *** Booting Zephyr OS build zephyr-v2.5.0-456-g06f4da459a99  ***
61
62      ***** PSA Architecture Test Suite - Version 1.0 *****
63
64      Running.. Storage Suite
65      ******************************************
66
67      TEST: 401 | DESCRIPTION: UID not found check
68      [Info] Executing tests from non-secure
69
70      [Info] Executing ITS tests
71      [Check 1] Call get API for UID 6 which is not set
72      [Check 2] Call get_info API for UID 6 which is not set
73      [Check 3] Call remove API for UID 6 which is not set
74      [Check 4] Call get API for UID 6 which is removed
75      [Check 5] Call get_info API for UID 6 which is removed
76      [Check 6] Call remove API for UID 6 which is removed
77      Set storage for UID 6
78      [Check 7] Call get API for different UID 5
79      [Check 8] Call get_info API for different UID 5
80      [Check 9] Call remove API for different UID 5
81
82      [Info] Executing PS tests
83      [Check 1] Call get API for UID 6 which is not set
84      [Check 2] Call get_info API for UID 6 which is not set
85      [Check 3] Call remove API for UID 6 which is not set
86      [Check 4] Call get API for UID 6 which is removed
87      [Check 5] Call get_info API for UID 6 which is removed
88      [Check 6] Call remove API for UID 6 which is removed
89      Set storage for UID 6
90      [Check 7] Call get API for different UID 5
91      [Check 8] Call get_info API for different UID 5
92      [Check 9] Call remove API for different UID 5
93
94      TEST RESULT: PASSED
95
96      ******************************************
97
98      [...]
99
100      TEST: 417 | DESCRIPTION: Storage assest capacity modification check
101      [Info] Executing tests from non-secure
102
103      [Info] Executing PS tests
104      Test Case skipped as Optional PS APIs not are supported.
105
106      TEST RESULT: SKIPPED (Skip Code=0x0000002B)
107
108      ******************************************
109
110      ************ Storage Suite Report **********
111      TOTAL TESTS     : 17
112      TOTAL PASSED    : 11
113      TOTAL SIM ERROR : 0
114      TOTAL FAILED    : 0
115      TOTAL SKIPPED   : 6
116      ******************************************
117
118      Entering standby..
119