summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatt Caswell <matt@openssl.org>2021-05-11 17:45:10 +1000
committerPauli <pauli@openssl.org>2021-05-12 18:20:03 +1000
commit5725ab808713abd79fc49d70a9f4ac79a83d3103 (patch)
treeddcc68d9927c9cf3c5e1b18ed1628d9fcbbd8949
parent1f12bf71fecf77c3d0def0fd4211be1dc85a53a1 (diff)
property: add test case for setting default user properties before fetching
Shamelessly culled from #15218. Co-authored-by: Dr Paul Dale <pauli@openssl.org> Reviewed-by: Tim Hudson <tjh@openssl.org> Reviewed-by: Paul Dale <pauli@openssl.org> (Merged from https://github.com/openssl/openssl/pull/15222)
-rw-r--r--test/build.info6
-rw-r--r--test/recipes/03-test_property.t17
-rw-r--r--test/user_property_test.c132
3 files changed, 150 insertions, 5 deletions
diff --git a/test/build.info b/test/build.info
index 2279b4e14d..842a7bbe35 100644
--- a/test/build.info
+++ b/test/build.info
@@ -56,7 +56,7 @@ IF[{- !$disabled{tests} -}]
sysdefaulttest errtest ssl_ctx_test gosttest \
context_internal_test aesgcmtest params_test evp_pkey_dparams_test \
keymgmt_internal_test hexstr_test provider_status_test defltfips_test \
- bio_readbuffer_test
+ bio_readbuffer_test user_property_test
IF[{- !$disabled{'deprecated-3.0'} -}]
PROGRAMS{noinst}=enginetest
@@ -129,6 +129,10 @@ IF[{- !$disabled{tests} -}]
INCLUDE[tls13ccstest]=../include ../apps/include
DEPEND[tls13ccstest]=../libcrypto ../libssl libtestutil.a
+ SOURCE[user_property_test]=user_property_test.c
+ INCLUDE[user_property_test]=../include ../apps/include
+ DEPEND[user_property_test]=../libcrypto libtestutil.a
+
SOURCE[evp_test]=evp_test.c
INCLUDE[evp_test]=../include ../apps/include
DEPEND[evp_test]=../libcrypto libtestutil.a
diff --git a/test/recipes/03-test_property.t b/test/recipes/03-test_property.t
index 2654215619..f11602873e 100644
--- a/test/recipes/03-test_property.t
+++ b/test/recipes/03-test_property.t
@@ -1,12 +1,21 @@
#! /usr/bin/env perl
-# Copyright 2019 The OpenSSL Project Authors. All Rights Reserved.
-# Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
+# Copyright 2021 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
# in the file LICENSE in the source distribution or at
# https://www.openssl.org/source/license.html
-use OpenSSL::Test::Simple;
+use strict;
+use warnings;
-simple_test("test_property", "property_test");
+use OpenSSL::Test;
+use OpenSSL::Test::Utils;
+
+setup('test_property');
+
+plan tests => 2;
+
+ok(run(test(["property_test"])), "running property_test");
+
+ok(run(test(["user_property_test"])), "running user_property_test");
diff --git a/test/user_property_test.c b/test/user_property_test.c
new file mode 100644
index 0000000000..7b7ab62832
--- /dev/null
+++ b/test/user_property_test.c
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2021 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
+ * in the file LICENSE in the source distribution or at
+ * https://www.openssl.org/source/license.html
+ */
+
+#include <openssl/core.h>
+#include <openssl/core_dispatch.h>
+#include <openssl/core_names.h>
+#include <openssl/provider.h>
+#include <openssl/crypto.h>
+#include <openssl/evp.h>
+#include "testutil.h"
+
+#define MYPROPERTIES "foo.bar=yes"
+
+static OSSL_FUNC_provider_query_operation_fn testprov_query;
+static OSSL_FUNC_digest_get_params_fn tmpmd_get_params;
+static OSSL_FUNC_digest_digest_fn tmpmd_digest;
+
+static int tmpmd_get_params(OSSL_PARAM params[])
+{
+ OSSL_PARAM *p = NULL;
+
+ p = OSSL_PARAM_locate(params, OSSL_DIGEST_PARAM_BLOCK_SIZE);
+ if (p != NULL && !OSSL_PARAM_set_size_t(p, 1))
+ return 0;
+
+ p = OSSL_PARAM_locate(params, OSSL_DIGEST_PARAM_SIZE);
+ if (p != NULL && !OSSL_PARAM_set_size_t(p, 1))
+ return 0;
+
+ return 1;
+}
+
+static int tmpmd_digest(void *provctx, const unsigned char *in, size_t inl,
+ unsigned char *out, size_t *outl, size_t outsz)
+{
+ return 0;
+}
+
+static const OSSL_DISPATCH testprovmd_functions[] = {
+ { OSSL_FUNC_DIGEST_GET_PARAMS, (void (*)(void))tmpmd_get_params },
+ { OSSL_FUNC_DIGEST_DIGEST, (void (*)(void))tmpmd_digest },
+ { 0, NULL }
+};
+
+static const OSSL_ALGORITHM testprov_digests[] = {
+ { "testprovmd", MYPROPERTIES, testprovmd_functions },
+ { NULL, NULL, NULL }
+};
+
+static const OSSL_ALGORITHM *testprov_query(void *provctx,
+ int operation_id,
+ int *no_cache)
+{
+ *no_cache = 0;
+ return operation_id == OSSL_OP_DIGEST ? testprov_digests : NULL;
+}
+
+static const OSSL_DISPATCH testprov_dispatch_table[] = {
+ { OSSL_FUNC_PROVIDER_QUERY_OPERATION, (void (*)(void))testprov_query },
+ { 0, NULL }
+};
+
+static int testprov_provider_init(const OSSL_CORE_HANDLE *handle,
+ const OSSL_DISPATCH *in,
+ const OSSL_DISPATCH **out,
+ void **provctx)
+{
+ *provctx = (void *)handle;
+ *out = testprov_dispatch_table;
+ return 1;
+}
+
+enum {
+ DEFAULT_PROPS_FIRST = 0,
+ DEFAULT_PROPS_AFTER_LOAD,
+ DEFAULT_PROPS_AFTER_FETCH,
+ DEFAULT_PROPS_FINAL
+};
+
+static int test_default_props_and_providers(int propsorder)
+{
+ OSSL_LIB_CTX *libctx;
+ OSSL_PROVIDER *testprov = NULL;
+ EVP_MD *testprovmd = NULL;
+ int res = 0;
+
+ if (!TEST_ptr(libctx = OSSL_LIB_CTX_new())
+ || !TEST_true(OSSL_PROVIDER_add_builtin(libctx, "testprov",
+ testprov_provider_init)))
+ goto err;
+
+ if (propsorder == DEFAULT_PROPS_FIRST
+ && !TEST_true(EVP_set_default_properties(libctx, MYPROPERTIES)))
+ goto err;
+
+ if (!TEST_ptr(testprov = OSSL_PROVIDER_load(libctx, "testprov")))
+ goto err;
+
+ if (propsorder == DEFAULT_PROPS_AFTER_LOAD
+ && !TEST_true(EVP_set_default_properties(libctx, MYPROPERTIES)))
+ goto err;
+
+ if (!TEST_ptr(testprovmd = EVP_MD_fetch(libctx, "testprovmd", NULL)))
+ goto err;
+
+ if (propsorder == DEFAULT_PROPS_AFTER_FETCH) {
+ if (!TEST_true(EVP_set_default_properties(libctx, MYPROPERTIES)))
+ goto err;
+ EVP_MD_free(testprovmd);
+ if (!TEST_ptr(testprovmd = EVP_MD_fetch(libctx, "testprovmd", NULL)))
+ goto err;
+ }
+
+ res = 1;
+ err:
+ EVP_MD_free(testprovmd);
+ OSSL_PROVIDER_unload(testprov);
+ OSSL_LIB_CTX_free(libctx);
+ return res;
+}
+
+int setup_tests(void)
+{
+ ADD_ALL_TESTS(test_default_props_and_providers, DEFAULT_PROPS_FINAL);
+ return 1;
+}