diff options
| author | Enji Cooper <ngie@FreeBSD.org> | 2025-07-11 00:18:38 +0000 | 
|---|---|---|
| committer | Enji Cooper <ngie@FreeBSD.org> | 2025-07-11 00:18:38 +0000 | 
| commit | ecf8229ffeb17a05c78fab6b973b0cccb84e25c5 (patch) | |
| tree | da8cf5ccc84d9bc3fbadcf674c7d501f9ca7ab5d /test/evp_libctx_test.c | |
| parent | 1c34280346af8284acdc0eae39496811d37df25d (diff) | |
Diffstat (limited to 'test/evp_libctx_test.c')
| -rw-r--r-- | test/evp_libctx_test.c | 17 | 
1 files changed, 13 insertions, 4 deletions
| diff --git a/test/evp_libctx_test.c b/test/evp_libctx_test.c index fd114a118cb2..1a4b398643d8 100644 --- a/test/evp_libctx_test.c +++ b/test/evp_libctx_test.c @@ -1,5 +1,5 @@  /* - * Copyright 2020-2022 The OpenSSL Project Authors. All Rights Reserved. + * Copyright 2020-2025 The OpenSSL Project Authors. All Rights Reserved.   *   * Licensed under the Apache License 2.0 (the "License").  You may not use   * this file except in compliance with the License.  You can obtain a copy @@ -38,6 +38,8 @@ static OSSL_LIB_CTX *libctx = NULL;  static OSSL_PROVIDER *nullprov = NULL;  static OSSL_PROVIDER *libprov = NULL;  static STACK_OF(OPENSSL_STRING) *cipher_names = NULL; +static int is_fips = 0; +static int is_fips_lt_3_5 = 0;  typedef enum OPTION_choice {      OPT_ERR = -1, @@ -631,9 +633,10 @@ static int kem_rsa_params(void)          && TEST_int_eq(EVP_PKEY_decapsulate(pubctx, secret, &secretlen, ct,                                              sizeof(ct)), 0)          && TEST_uchar_eq(secret[0], 0) -        /* Test encapsulate fails if the mode is not set */ +        /* Unless newer FIPS, test encapsulate fails when the mode is not set. */          && TEST_int_eq(EVP_PKEY_encapsulate_init(pubctx, NULL), 1) -        && TEST_int_eq(EVP_PKEY_encapsulate(pubctx, ct, &ctlen, secret, &secretlen), -2) +        && (!is_fips_lt_3_5 || +            TEST_int_eq(EVP_PKEY_encapsulate(pubctx, ct, &ctlen, secret, &secretlen), -2))          /* Test setting a bad kem ops fail */          && TEST_int_eq(EVP_PKEY_CTX_set_kem_op(pubctx, "RSA"), 0)          && TEST_int_eq(EVP_PKEY_CTX_set_kem_op(pubctx, NULL), 0) @@ -743,8 +746,14 @@ int setup_tests(void)      if (!test_get_libctx(&libctx, &nullprov, config_file, &libprov, prov_name))          return 0; +    if (strcmp(prov_name, "fips") == 0) +        is_fips = 1; + +    is_fips_lt_3_5 = is_fips && fips_provider_version_lt(libctx, 3, 5, 0); +  #if !defined(OPENSSL_NO_DSA) && !defined(OPENSSL_NO_DH) -    ADD_ALL_TESTS(test_dsa_param_keygen, 3 * 3 * 3); +    if (!is_fips || fips_provider_version_lt(libctx, 3, 4, 0)) +        ADD_ALL_TESTS(test_dsa_param_keygen, 3 * 3 * 3);  #endif  #ifndef OPENSSL_NO_DH      ADD_ALL_TESTS(test_dh_safeprime_param_keygen, 3 * 3 * 3); | 
