1#line 2 "suites/main_test.function" 2/* 3 * *** THIS FILE HAS BEEN MACHINE GENERATED *** 4 * 5 * This file has been machine generated using the script: 6 * __MBEDTLS_TEST_TEMPLATE__GENERATOR_SCRIPT 7 * 8 * Test file : __MBEDTLS_TEST_TEMPLATE__TEST_FILE 9 * 10 * The following files were used to create this file. 11 * 12 * Main code file : __MBEDTLS_TEST_TEMPLATE__TEST_MAIN_FILE 13 * Platform code file : __MBEDTLS_TEST_TEMPLATE__TEST_PLATFORM_FILE 14 * Helper file : __MBEDTLS_TEST_TEMPLATE__TEST_COMMON_HELPER_FILE 15 * Test suite file : __MBEDTLS_TEST_TEMPLATE__TEST_CASE_FILE 16 * Test suite data : __MBEDTLS_TEST_TEMPLATE__TEST_CASE_DATA_FILE 17 * 18 */ 19 20#if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__)) 21#if !defined(_POSIX_C_SOURCE) 22#define _POSIX_C_SOURCE 200112L // for fileno() from <stdio.h> 23#endif 24#endif 25 26#include "mbedtls/build_info.h" 27 28/* Test code may use deprecated identifiers only if the preprocessor symbol 29 * MBEDTLS_TEST_DEPRECATED is defined. When building tests, set 30 * MBEDTLS_TEST_DEPRECATED explicitly if MBEDTLS_DEPRECATED_WARNING is 31 * enabled but the corresponding warnings are not treated as errors. 32 */ 33#if !defined(MBEDTLS_DEPRECATED_REMOVED) && !defined(MBEDTLS_DEPRECATED_WARNING) 34#define MBEDTLS_TEST_DEPRECATED 35#endif 36 37/*----------------------------------------------------------------------------*/ 38/* Common helper code */ 39 40__MBEDTLS_TEST_TEMPLATE__TEST_COMMON_HELPERS 41 42#line __MBEDTLS_TEST_TEMPLATE__LINE_NO "suites/main_test.function" 43 44 45/*----------------------------------------------------------------------------*/ 46/* Test Suite Code */ 47 48 49#define TEST_SUITE_ACTIVE 50 51__MBEDTLS_TEST_TEMPLATE__FUNCTIONS_CODE 52 53#line __MBEDTLS_TEST_TEMPLATE__LINE_NO "suites/main_test.function" 54 55 56/*----------------------------------------------------------------------------*/ 57/* Test dispatch code */ 58 59 60/** 61 * \brief Evaluates an expression/macro into its literal integer value. 62 * For optimizing space for embedded targets each expression/macro 63 * is identified by a unique identifier instead of string literals. 64 * Identifiers and evaluation code is generated by script: 65 * __MBEDTLS_TEST_TEMPLATE__GENERATOR_SCRIPT 66 * 67 * \param exp_id Expression identifier. 68 * \param out_value Pointer to int to hold the integer. 69 * 70 * \return 0 if exp_id is found. 1 otherwise. 71 */ 72int get_expression(int32_t exp_id, intmax_t *out_value) 73{ 74 int ret = KEY_VALUE_MAPPING_FOUND; 75 76 (void) exp_id; 77 (void) out_value; 78 79 switch (exp_id) { 80 __MBEDTLS_TEST_TEMPLATE__EXPRESSION_CODE 81#line __MBEDTLS_TEST_TEMPLATE__LINE_NO "suites/main_test.function" 82 default: 83 { 84 ret = KEY_VALUE_MAPPING_NOT_FOUND; 85 } 86 break; 87 } 88 return ret; 89} 90 91 92/** 93 * \brief Checks if the dependency i.e. the compile flag is set. 94 * For optimizing space for embedded targets each dependency 95 * is identified by a unique identifier instead of string literals. 96 * Identifiers and check code is generated by script: 97 * __MBEDTLS_TEST_TEMPLATE__GENERATOR_SCRIPT 98 * 99 * \param dep_id Dependency identifier. 100 * 101 * \return DEPENDENCY_SUPPORTED if set else DEPENDENCY_NOT_SUPPORTED 102 */ 103int dep_check(int dep_id) 104{ 105 int ret = DEPENDENCY_NOT_SUPPORTED; 106 107 (void) dep_id; 108 109 switch (dep_id) { 110 __MBEDTLS_TEST_TEMPLATE__DEP_CHECK_CODE 111#line __MBEDTLS_TEST_TEMPLATE__LINE_NO "suites/main_test.function" 112 default: 113 break; 114 } 115 return ret; 116} 117 118 119/** 120 * \brief Function pointer type for test function wrappers. 121 * 122 * A test function wrapper decodes the parameters and passes them to the 123 * underlying test function. Both the wrapper and the underlying function 124 * return void. Test wrappers assume that they are passed a suitable 125 * parameter array and do not perform any error detection. 126 * 127 * \param param_array The array of parameters. Each element is a `void *` 128 * which the wrapper casts to the correct type and 129 * dereferences. Each wrapper function hard-codes the 130 * number and types of the parameters. 131 */ 132typedef void (*TestWrapper_t)(void **param_array); 133 134 135/** 136 * \brief Table of test function wrappers. Used by dispatch_test(). 137 * This table is populated by script: 138 * __MBEDTLS_TEST_TEMPLATE__GENERATOR_SCRIPT 139 * 140 */ 141TestWrapper_t test_funcs[] = 142{ 143 __MBEDTLS_TEST_TEMPLATE__DISPATCH_CODE 144#line __MBEDTLS_TEST_TEMPLATE__LINE_NO "suites/main_test.function" 145}; 146 147/** 148 * \brief Dispatches test functions based on function index. 149 * 150 * \param func_idx Test function index. 151 * \param params The array of parameters to pass to the test function. 152 * It will be decoded by the #TestWrapper_t wrapper function. 153 * 154 * \return DISPATCH_TEST_SUCCESS if found 155 * DISPATCH_TEST_FN_NOT_FOUND if not found 156 * DISPATCH_UNSUPPORTED_SUITE if not compile time enabled. 157 */ 158int dispatch_test(size_t func_idx, void **params) 159{ 160 int ret = DISPATCH_TEST_SUCCESS; 161 TestWrapper_t fp = NULL; 162 163 if (func_idx < (int) (sizeof(test_funcs) / sizeof(TestWrapper_t))) { 164 fp = test_funcs[func_idx]; 165 if (fp) { 166 #if defined(MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG) 167 mbedtls_test_enable_insecure_external_rng(); 168 #endif 169 170 fp(params); 171 172 #if defined(MBEDTLS_TEST_MUTEX_USAGE) 173 mbedtls_test_mutex_usage_check(); 174 #endif /* MBEDTLS_TEST_MUTEX_USAGE */ 175 } else { 176 ret = DISPATCH_UNSUPPORTED_SUITE; 177 } 178 } else { 179 ret = DISPATCH_TEST_FN_NOT_FOUND; 180 } 181 182 return ret; 183} 184 185 186/** 187 * \brief Checks if test function is supported in this build-time 188 * configuration. 189 * 190 * \param func_idx Test function index. 191 * 192 * \return DISPATCH_TEST_SUCCESS if found 193 * DISPATCH_TEST_FN_NOT_FOUND if not found 194 * DISPATCH_UNSUPPORTED_SUITE if not compile time enabled. 195 */ 196int check_test(size_t func_idx) 197{ 198 int ret = DISPATCH_TEST_SUCCESS; 199 TestWrapper_t fp = NULL; 200 201 if (func_idx < (int) (sizeof(test_funcs)/sizeof(TestWrapper_t))) { 202 fp = test_funcs[func_idx]; 203 if (fp == NULL) { 204 ret = DISPATCH_UNSUPPORTED_SUITE; 205 } 206 } else { 207 ret = DISPATCH_TEST_FN_NOT_FOUND; 208 } 209 210 return ret; 211} 212 213 214__MBEDTLS_TEST_TEMPLATE__PLATFORM_CODE 215 216#line __MBEDTLS_TEST_TEMPLATE__LINE_NO "suites/main_test.function" 217 218/*----------------------------------------------------------------------------*/ 219/* Main Test code */ 220 221 222/** 223 * \brief Program main. Invokes platform specific execute_tests(). 224 * 225 * \param argc Command line arguments count. 226 * \param argv Array of command line arguments. 227 * 228 * \return Exit code. 229 */ 230int main(int argc, const char *argv[]) 231{ 232#if defined(MBEDTLS_TEST_HOOKS) 233 extern void (*mbedtls_test_hook_test_fail)(const char *test, int line, const char *file); 234 mbedtls_test_hook_test_fail = &mbedtls_test_fail; 235#if defined(MBEDTLS_ERROR_C) 236 mbedtls_test_hook_error_add = &mbedtls_test_err_add_check; 237#endif 238#endif 239 240 /* Try changing to the directory containing the executable, if 241 * using the default data file. This allows running the executable 242 * from another directory (e.g. the project root) and still access 243 * the .datax file as well as data files used by test cases 244 * (typically from tests/data_files). 245 * 246 * Note that we do this before the platform setup (which may access 247 * files such as a random seed). We also do this before accessing 248 * test-specific files such as the outcome file, which is arguably 249 * not desirable and should be fixed later. 250 */ 251 if (argc == 1) { 252 try_chdir_if_supported(argv[0]); 253 } 254 255 int ret = mbedtls_test_platform_setup(); 256 if (ret != 0) { 257 mbedtls_fprintf(stderr, 258 "FATAL: Failed to initialize platform - error %d\n", 259 ret); 260 return -1; 261 } 262 263 ret = execute_tests(argc, argv); 264 mbedtls_test_platform_teardown(); 265 return ret; 266} 267