From 039119a0f3eeb610689f21834ea04cc1f0efe8df Mon Sep 17 00:00:00 2001 From: Matt Caswell Date: Thu, 19 Oct 2023 11:37:28 +0100 Subject: [PATCH] Add a test for converting OSSL_TIME to struct timeval Reviewed-by: Hugo Landau Reviewed-by: Tomas Mraz (Merged from https://github.com/openssl/openssl/pull/22440) --- test/build.info | 6 ++- test/recipes/02-test_time.t | 12 ++++++ test/time_test.c | 79 +++++++++++++++++++++++++++++++++++++ 3 files changed, 96 insertions(+), 1 deletion(-) create mode 100644 test/recipes/02-test_time.t create mode 100644 test/time_test.c diff --git a/test/build.info b/test/build.info index 73f8de1f7a125..cd8254164a0ac 100644 --- a/test/build.info +++ b/test/build.info @@ -34,7 +34,7 @@ IF[{- !$disabled{tests} -}] confdump \ versions \ aborttest test_test pkcs12_format_test pkcs12_api_test \ - sanitytest rsa_complex exdatatest bntest \ + sanitytest time_test rsa_complex exdatatest bntest \ ecstresstest gmdifftest pbelutest \ destest mdc2test sha_test \ exptest pbetest localetest evp_pkey_ctx_new_from_name \ @@ -97,6 +97,10 @@ IF[{- !$disabled{tests} -}] INCLUDE[sanitytest]=../include ../apps/include DEPEND[sanitytest]=../libcrypto.a libtestutil.a + SOURCE[time_test]=time_test.c + INCLUDE[time_test]=../include ../apps/include + DEPEND[time_test]=../libcrypto.a libtestutil.a + SOURCE[rand_test]=rand_test.c INCLUDE[rand_test]=../include ../apps/include DEPEND[rand_test]=../libcrypto libtestutil.a diff --git a/test/recipes/02-test_time.t b/test/recipes/02-test_time.t new file mode 100644 index 0000000000000..c4534034fcfda --- /dev/null +++ b/test/recipes/02-test_time.t @@ -0,0 +1,12 @@ +#! /usr/bin/env perl +# Copyright 2023 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; + +simple_test("test_time", "time_test"); diff --git a/test/time_test.c b/test/time_test.c new file mode 100644 index 0000000000000..62f911f61cbc1 --- /dev/null +++ b/test/time_test.c @@ -0,0 +1,79 @@ +/* + * Copyright 2023 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 "testutil.h" +#include "internal/time.h" + +static int test_time_to_timeval(void) +{ + OSSL_TIME a; + struct timeval tv; + + a = ossl_time_zero(); + + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 0) || !TEST_long_eq(tv.tv_usec, 0)) + return 0; + + /* Test that zero round trips */ + if (!TEST_true(ossl_time_is_zero(ossl_time_from_timeval(tv)))) + return 0; + + /* We should round up nano secs to the next usec */ + a = ossl_ticks2time(1); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 0) || !TEST_long_eq(tv.tv_usec, 1)) + return 0; + a = ossl_ticks2time(999); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 0) || !TEST_long_eq(tv.tv_usec, 1)) + return 0; + a = ossl_ticks2time(1000); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 0) || !TEST_long_eq(tv.tv_usec, 1)) + return 0; + a = ossl_ticks2time(1001); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 0) || !TEST_long_eq(tv.tv_usec, 2)) + return 0; + a = ossl_ticks2time(999000); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 0) || !TEST_long_eq(tv.tv_usec, 999)) + return 0; + a = ossl_ticks2time(999999001); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 1) || !TEST_long_eq(tv.tv_usec, 0)) + return 0; + a = ossl_ticks2time(999999999); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 1) || !TEST_long_eq(tv.tv_usec, 0)) + return 0; + a = ossl_ticks2time(1000000000); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 1) || !TEST_long_eq(tv.tv_usec, 0)) + return 0; + a = ossl_ticks2time(1000000001); + tv = ossl_time_to_timeval(a); + if (!TEST_long_eq(tv.tv_sec, 1) || !TEST_long_eq(tv.tv_usec, 1)) + return 0; + + /* + * Note that we don't currently support infinity round tripping. Instead + * callers need to explicitly test for infinity. + */ + + return 1; +} + +int setup_tests(void) +{ + ADD_TEST(test_time_to_timeval); + + return 1; +}