aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/test-rpc_hash.c23
1 files changed, 20 insertions, 3 deletions
diff --git a/tests/test-rpc_hash.c b/tests/test-rpc_hash.c
index 38bb793..8b41ac7 100644
--- a/tests/test-rpc_hash.c
+++ b/tests/test-rpc_hash.c
@@ -536,6 +536,11 @@ static int _test_hash(const hal_digest_algorithm_t alg,
{
uint8_t digest[512];
hal_error_t err;
+ static hal_digest_algorithm_t last_alg = -1;
+ static hal_error_t last_err = -1;
+
+ if (last_alg == alg && last_err == HAL_ERROR_CORE_NOT_FOUND)
+ return 1;
assert(data != NULL && result != NULL && label != NULL);
assert(result_len <= sizeof(digest));
@@ -546,7 +551,10 @@ static int _test_hash(const hal_digest_algorithm_t alg,
hal_session_handle_t session = {0};
hal_hash_handle_t hash;
- if ((err = hal_rpc_hash_initialize(client, session, &hash, alg, NULL, 0)) != HAL_OK) {
+ err = hal_rpc_hash_initialize(client, session, &hash, alg, NULL, 0);
+ last_alg = alg;
+ last_err = err;
+ if (err != HAL_OK) {
printf("Failed while initializing hash: %s\n", hal_error_string(err));
return 0;
}
@@ -575,7 +583,8 @@ static int _test_hash(const hal_digest_algorithm_t alg,
}
printf("OK\n");
- return 1;
+ last_err = err;
+ return 1;
}
static int _test_hmac(const hal_digest_algorithm_t alg,
@@ -586,6 +595,11 @@ static int _test_hmac(const hal_digest_algorithm_t alg,
{
uint8_t digest[512];
hal_error_t err;
+ static hal_digest_algorithm_t last_alg = -1;
+ static hal_error_t last_err = -1;
+
+ if (last_alg == alg && last_err == HAL_ERROR_CORE_NOT_FOUND)
+ return 1;
assert(data != NULL && result != NULL && label != NULL);
assert(result_len <= sizeof(digest));
@@ -596,7 +610,10 @@ static int _test_hmac(const hal_digest_algorithm_t alg,
hal_session_handle_t session = {0};
hal_hash_handle_t hash;
- if ((err = hal_rpc_hash_initialize(client, session, &hash, alg, key, key_len)) != HAL_OK) {
+ err = hal_rpc_hash_initialize(client, session, &hash, alg, key, key_len);
+ last_alg = alg;
+ last_err = err;
+ if (err != HAL_OK) {
printf("Failed while initializing HMAC: %s\n", hal_error_string(err));
return 0;
}
ref='#n173'>173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205