blob: 2c4a8fb90de7749db7a483334a626a2110637ee4 [file] [log] [blame]
Valerio Setti5beb2362024-06-24 13:13:17 +02001/**
2 * This is the base AUT that exectues all other AUTs meant to test PSA APIs
3 * through PSASIM.
4 */
5
6/*
7 * Copyright The Mbed TLS Contributors
8 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
9 */
10
11/* First include Mbed TLS headers to get the Mbed TLS configuration and
12 * platform definitions that we'll use in this program. Also include
13 * standard C headers for functions we'll use here. */
14#include "mbedtls/build_info.h"
15
16#include "psa/crypto.h"
17
18#include <stdlib.h>
19#include <stdio.h>
20#include <string.h>
21
22int psa_hash_compute_main(void);
23int psa_hash_main(void);
Valerio Settia06b22d2024-06-24 14:59:34 +020024int psa_aead_encrypt_main(char *cipher_name);
25int psa_aead_encrypt_decrypt_main(void);
Valerio Settie9829e52024-06-24 16:37:27 +020026int psa_cipher_encrypt_decrypt_main(void);
Valerio Setti25afdc12024-06-24 13:44:12 +020027int psa_random_main(void);
Valerio Settif79e17a2024-06-24 13:57:49 +020028int psa_mac_main(void);
Valerio Setti6d6fe8b2024-06-24 14:46:08 +020029int psa_key_agreement_main(void);
Valerio Settibb1502b2024-06-24 14:50:54 +020030int psa_sign_verify_main(void);
Valerio Setti87be9db2024-06-24 15:09:33 +020031int psa_hkdf_main(void);
Valerio Setti5beb2362024-06-24 13:13:17 +020032
33#define TEST_MODULE(main_func) \
34 do { \
35 char title[128] = { 0 }; \
36 char separator[128] = { 0 }; \
37 int title_len = snprintf(title, sizeof(title), "=== Test: %s ===", #main_func); \
38 memset(separator, '=', title_len); \
39 printf("%s\n%s\n%s\n", separator, title, separator); \
40 ret = main_func; \
41 if (ret != 0) { \
42 goto exit; \
43 } \
44 } while (0)
45
46int main()
47{
48 int ret;
49
50 TEST_MODULE(psa_hash_compute_main());
51 TEST_MODULE(psa_hash_main());
52
Valerio Settia06b22d2024-06-24 14:59:34 +020053 TEST_MODULE(psa_aead_encrypt_main("aes128-gcm"));
54 TEST_MODULE(psa_aead_encrypt_main("aes256-gcm"));
55 TEST_MODULE(psa_aead_encrypt_main("aes128-gcm_8"));
56 TEST_MODULE(psa_aead_encrypt_main("chachapoly"));
Valerio Settie9829e52024-06-24 16:37:27 +020057 TEST_MODULE(psa_aead_encrypt_decrypt_main());
58 TEST_MODULE(psa_cipher_encrypt_decrypt_main());
Valerio Setti5beb2362024-06-24 13:13:17 +020059
Valerio Setti25afdc12024-06-24 13:44:12 +020060 TEST_MODULE(psa_random_main());
61
Valerio Settif79e17a2024-06-24 13:57:49 +020062 TEST_MODULE(psa_mac_main());
Valerio Setti6d6fe8b2024-06-24 14:46:08 +020063 TEST_MODULE(psa_key_agreement_main());
Valerio Settibb1502b2024-06-24 14:50:54 +020064 TEST_MODULE(psa_sign_verify_main());
Valerio Setti87be9db2024-06-24 15:09:33 +020065 TEST_MODULE(psa_hkdf_main());
Valerio Settif79e17a2024-06-24 13:57:49 +020066
Valerio Setti5beb2362024-06-24 13:13:17 +020067exit:
68 return (ret != 0) ? 1 : 0;
69}