From 9fbb5c3087eb0e90e808aca1d6ba0108b2903c5d Mon Sep 17 00:00:00 2001 From: Duc Nguyen Date: Wed, 1 Nov 2023 11:50:26 -0400 Subject: [PATCH] add return code in case pthread API has errors --- tests/test_sig_stfl.c | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/tests/test_sig_stfl.c b/tests/test_sig_stfl.c index 689397af52..4b346707e3 100644 --- a/tests/test_sig_stfl.c +++ b/tests/test_sig_stfl.c @@ -14,6 +14,7 @@ #include #include "tmp_store.c" +#include "system_info.c" #if OQS_USE_PTHREADS_IN_TESTS #include @@ -31,8 +32,6 @@ static pthread_mutex_t *sk_lock = NULL; #define OQS_TEST_CT_DECLASSIFY(addr, len) #endif -#include "system_info.c" - /* * For stateful signature, we skip key generation because it can takes hours to complete. * So the ReadHex and and FindMarker serve the purpose of reading pre-generate keypair from KATs. @@ -1015,6 +1014,7 @@ int main(int argc, char **argv) { #endif OQS_STATUS rc = OQS_ERROR, rc1 = OQS_ERROR; + int exit_status = EXIT_SUCCESS; #if OQS_USE_PTHREADS_IN_TESTS #define MAX_LEN_SIG_NAME_ 64 @@ -1041,11 +1041,13 @@ int main(int argc, char **argv) { if (pthread_mutex_init(test_sk_lock, NULL) || pthread_mutex_init(sk_lock, NULL)) { fprintf(stderr, "ERROR: Initializing mutex\n"); + exit_status = EXIT_FAILURE; goto err; } if (pthread_create(&thread, NULL, test_wrapper, &td)) { fprintf(stderr, "ERROR: Creating pthread for test_wrapper\n"); + exit_status = EXIT_FAILURE; goto err; } pthread_join(thread, NULL); @@ -1054,6 +1056,7 @@ int main(int argc, char **argv) { if (pthread_create(&create_key_thread, NULL, test_create_keys, &td_create)) { fprintf(stderr, "ERROR: Creating pthread for test_create_keys\n"); + exit_status = EXIT_FAILURE; goto err; } pthread_join(create_key_thread, NULL); @@ -1061,6 +1064,7 @@ int main(int argc, char **argv) { if (pthread_create(&sign_key_thread, NULL, test_sig_gen, &td_sign)) { fprintf(stderr, "ERROR: Creating pthread for test_sig_gen\n"); + exit_status = EXIT_FAILURE; goto err; } pthread_join(sign_key_thread, NULL); @@ -1068,19 +1072,15 @@ int main(int argc, char **argv) { if (pthread_create(&query_key_thread, NULL, test_query_key, &td_query)) { fprintf(stderr, "ERROR: Creating pthread for test_query_key\n"); + exit_status = EXIT_FAILURE; goto err; } pthread_join(query_key_thread, NULL); rc_query = td_query.rc; err: - if (test_sk_lock) { - pthread_mutex_destroy(test_sk_lock); - } - - if (sk_lock) { - pthread_mutex_destroy(sk_lock); - } + pthread_mutex_destroy(test_sk_lock); + pthread_mutex_destroy(sk_lock); #else rc = sig_stfl_test_correctness(alg_name, katfile); rc1 = sig_stfl_test_secret_key(alg_name, katfile); @@ -1098,5 +1098,5 @@ int main(int argc, char **argv) { rc_create != OQS_SUCCESS || rc_sign != OQS_SUCCESS || rc_query != OQS_SUCCESS) { return EXIT_FAILURE; } - return EXIT_SUCCESS; + return exit_status; }