X-Git-Url: https://git.openssl.org/?a=blobdiff_plain;f=test%2Ftest_test.c;h=18b61c6d0b1005f80baafccb225c1eb151b237e8;hb=0d8da77908df1aa3186b00113aab1b338cba9b07;hp=cab580c1524917d5333af463faca783bbbbf3225;hpb=7ac5b84ea7920343f5c69247251bbc84ac259b2b;p=openssl.git diff --git a/test/test_test.c b/test/test_test.c index cab580c152..18b61c6d0b 100644 --- a/test/test_test.c +++ b/test/test_test.c @@ -1,5 +1,6 @@ /* - * Copyright 2017 The OpenSSL Project Authors. All Rights Reserved. + * Copyright 2017-2018 The OpenSSL Project Authors. All Rights Reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * * Licensed under the OpenSSL license (the "License"). You may not use * this file except in compliance with the License. You can obtain a copy @@ -7,10 +8,6 @@ * https://www.openssl.org/source/license.html */ -/* - * Copyright (c) 2017 Oracle and/or its affiliates. All rights reserved. - */ - #include #include @@ -19,7 +16,7 @@ #include #include -#include "e_os.h" +#include "internal/nelem.h" #include "testutil.h" #define TEST(expected, test) test_case((expected), #test, (test)) @@ -173,20 +170,43 @@ err: static int test_size_t(void) { - if (!TEST(1, TEST_int_eq((size_t)10, (size_t)10)) - | !TEST(0, TEST_int_eq((size_t)10, (size_t)12)) - | !TEST(1, TEST_int_ne((size_t)10, (size_t)12)) - | !TEST(0, TEST_int_ne((size_t)24, (size_t)24)) - | !TEST(1, TEST_int_lt((size_t)30, (size_t)88)) - | !TEST(0, TEST_int_lt((size_t)88, (size_t)30)) - | !TEST(1, TEST_int_le((size_t)30, (size_t)88)) - | !TEST(1, TEST_int_le((size_t)33, (size_t)33)) - | !TEST(0, TEST_int_le((size_t)88, (size_t)30)) - | !TEST(1, TEST_int_gt((size_t)52, (size_t)33)) - | !TEST(0, TEST_int_gt((size_t)33, (size_t)52)) - | !TEST(1, TEST_int_ge((size_t)52, (size_t)33)) - | !TEST(1, TEST_int_ge((size_t)38, (size_t)38)) - | !TEST(0, TEST_int_ge((size_t)33, (size_t)52))) + if (!TEST(1, TEST_size_t_eq((size_t)10, (size_t)10)) + | !TEST(0, TEST_size_t_eq((size_t)10, (size_t)12)) + | !TEST(1, TEST_size_t_ne((size_t)10, (size_t)12)) + | !TEST(0, TEST_size_t_ne((size_t)24, (size_t)24)) + | !TEST(1, TEST_size_t_lt((size_t)30, (size_t)88)) + | !TEST(0, TEST_size_t_lt((size_t)88, (size_t)30)) + | !TEST(1, TEST_size_t_le((size_t)30, (size_t)88)) + | !TEST(1, TEST_size_t_le((size_t)33, (size_t)33)) + | !TEST(0, TEST_size_t_le((size_t)88, (size_t)30)) + | !TEST(1, TEST_size_t_gt((size_t)52, (size_t)33)) + | !TEST(0, TEST_size_t_gt((size_t)33, (size_t)52)) + | !TEST(1, TEST_size_t_ge((size_t)52, (size_t)33)) + | !TEST(1, TEST_size_t_ge((size_t)38, (size_t)38)) + | !TEST(0, TEST_size_t_ge((size_t)33, (size_t)52))) + goto err; + return 1; + +err: + return 0; +} + +static int test_time_t(void) +{ + if (!TEST(1, TEST_time_t_eq((time_t)10, (time_t)10)) + | !TEST(0, TEST_time_t_eq((time_t)10, (time_t)12)) + | !TEST(1, TEST_time_t_ne((time_t)10, (time_t)12)) + | !TEST(0, TEST_time_t_ne((time_t)24, (time_t)24)) + | !TEST(1, TEST_time_t_lt((time_t)30, (time_t)88)) + | !TEST(0, TEST_time_t_lt((time_t)88, (time_t)30)) + | !TEST(1, TEST_time_t_le((time_t)30, (time_t)88)) + | !TEST(1, TEST_time_t_le((time_t)33, (time_t)33)) + | !TEST(0, TEST_time_t_le((time_t)88, (time_t)30)) + | !TEST(1, TEST_time_t_gt((time_t)52, (time_t)33)) + | !TEST(0, TEST_time_t_gt((time_t)33, (time_t)52)) + | !TEST(1, TEST_time_t_ge((time_t)52, (time_t)33)) + | !TEST(1, TEST_time_t_ge((time_t)38, (time_t)38)) + | !TEST(0, TEST_time_t_ge((time_t)33, (time_t)52))) goto err; return 1; @@ -480,7 +500,43 @@ static int test_single_eval(void) && TEST_mem_eq(p--, sizeof("456"), "456", sizeof("456")); } -void register_tests(void) +static int test_output(void) +{ + const char s[] = "1234567890123456789012345678901234567890123456789012" + "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; + + test_output_string("test", s, sizeof(s) - 1); + test_output_memory("test", (const unsigned char *)s, sizeof(s)); + return 1; +} + +static const char *bn_output_tests[] = { + NULL, + "0", + "-12345678", + "1234567890123456789012345678901234567890123456789012" + "1234567890123456789012345678901234567890123456789013" + "987657" +}; + +static int test_bn_output(int n) +{ + BIGNUM *b = NULL; + + if (bn_output_tests[n] != NULL + && !TEST_true(BN_hex2bn(&b, bn_output_tests[n]))) + return 0; + test_output_bignum(bn_output_tests[n], b); + BN_free(b); + return 1; +} + +static int test_memcmp(void) +{ + return CRYPTO_memcmp("ab","cd",2); +} + +int setup_tests(void) { ADD_TEST(test_int); ADD_TEST(test_uint); @@ -489,6 +545,7 @@ void register_tests(void) ADD_TEST(test_long); ADD_TEST(test_ulong); ADD_TEST(test_size_t); + ADD_TEST(test_time_t); ADD_TEST(test_pointer); ADD_TEST(test_bool); ADD_TEST(test_string); @@ -499,4 +556,8 @@ void register_tests(void) ADD_TEST(test_long_output); ADD_TEST(test_messages); ADD_TEST(test_single_eval); + ADD_TEST(test_output); + ADD_TEST(test_memcmp); + ADD_ALL_TESTS(test_bn_output, OSSL_NELEM(bn_output_tests)); + return 1; }