blob: 7d1d2c00fcee5ff524b586493e6e1bc6883b1445 [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);
24int psa_aead_main(char *cipher_name);
Valerio Setti25afdc12024-06-24 13:44:12 +020025int psa_random_main(void);
Valerio Settif79e17a2024-06-24 13:57:49 +020026int psa_mac_main(void);
Valerio Setti5beb2362024-06-24 13:13:17 +020027
28#define TEST_MODULE(main_func) \
29 do { \
30 char title[128] = { 0 }; \
31 char separator[128] = { 0 }; \
32 int title_len = snprintf(title, sizeof(title), "=== Test: %s ===", #main_func); \
33 memset(separator, '=', title_len); \
34 printf("%s\n%s\n%s\n", separator, title, separator); \
35 ret = main_func; \
36 if (ret != 0) { \
37 goto exit; \
38 } \
39 } while (0)
40
41int main()
42{
43 int ret;
44
45 TEST_MODULE(psa_hash_compute_main());
46 TEST_MODULE(psa_hash_main());
47
48 TEST_MODULE(psa_aead_main("aes128-gcm"));
49 TEST_MODULE(psa_aead_main("aes256-gcm"));
50 TEST_MODULE(psa_aead_main("aes128-gcm_8"));
51 TEST_MODULE(psa_aead_main("chachapoly"));
52
Valerio Setti25afdc12024-06-24 13:44:12 +020053 TEST_MODULE(psa_random_main());
54
Valerio Settif79e17a2024-06-24 13:57:49 +020055 TEST_MODULE(psa_mac_main());
56
Valerio Setti5beb2362024-06-24 13:13:17 +020057exit:
58 return (ret != 0) ? 1 : 0;
59}