hexstr_test.c revision 1.1.1.1
1/* 2 * Copyright 2020-2021 The OpenSSL Project Authors. All Rights Reserved. 3 * 4 * Licensed under the Apache License 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * https://www.openssl.org/source/license.html 8 * or in the file LICENSE in the source distribution. 9 */ 10 11/* 12 * This program tests the use of OSSL_PARAM, currently in raw form. 13 */ 14 15#include "internal/nelem.h" 16#include "internal/cryptlib.h" 17#include "testutil.h" 18 19struct testdata 20{ 21 const char *in; 22 const unsigned char *expected; 23 size_t expected_len; 24 const char sep; 25}; 26 27static const unsigned char test_1[] = { 0xAB, 0xCD, 0xEF, 0xF1 }; 28static const unsigned char test_2[] = { 0xAB, 0xCD, 0xEF, 0x76, 0x00 }; 29 30static struct testdata tbl_testdata[] = { 31 { 32 "AB:CD:EF:F1", 33 test_1, sizeof(test_1), 34 ':', 35 }, 36 { 37 "AB:CD:EF:76:00", 38 test_2, sizeof(test_2), 39 ':', 40 }, 41 { 42 "AB_CD_EF_F1", 43 test_1, sizeof(test_1), 44 '_', 45 }, 46 { 47 "AB_CD_EF_76_00", 48 test_2, sizeof(test_2), 49 '_', 50 }, 51 { 52 "ABCDEFF1", 53 test_1, sizeof(test_1), 54 '\0', 55 }, 56 { 57 "ABCDEF7600", 58 test_2, sizeof(test_2), 59 '\0', 60 }, 61}; 62 63static int test_hexstr_sep_to_from(int test_index) 64{ 65 int ret = 0; 66 long len = 0; 67 unsigned char *buf = NULL; 68 char *out = NULL; 69 struct testdata *test = &tbl_testdata[test_index]; 70 71 if (!TEST_ptr(buf = ossl_hexstr2buf_sep(test->in, &len, test->sep)) 72 || !TEST_mem_eq(buf, len, test->expected, test->expected_len) 73 || !TEST_ptr(out = ossl_buf2hexstr_sep(buf, len, test->sep)) 74 || !TEST_str_eq(out, test->in)) 75 goto err; 76 77 ret = 1; 78err: 79 OPENSSL_free(buf); 80 OPENSSL_free(out); 81 return ret; 82} 83 84static int test_hexstr_to_from(int test_index) 85{ 86 int ret = 0; 87 long len = 0; 88 unsigned char *buf = NULL; 89 char *out = NULL; 90 struct testdata *test = &tbl_testdata[test_index]; 91 92 if (test->sep != '_') { 93 if (!TEST_ptr(buf = OPENSSL_hexstr2buf(test->in, &len)) 94 || !TEST_mem_eq(buf, len, test->expected, test->expected_len) 95 || !TEST_ptr(out = OPENSSL_buf2hexstr(buf, len))) 96 goto err; 97 if (test->sep == ':') { 98 if (!TEST_str_eq(out, test->in)) 99 goto err; 100 } else if (!TEST_str_ne(out, test->in)) { 101 goto err; 102 } 103 } else { 104 if (!TEST_ptr_null(buf = OPENSSL_hexstr2buf(test->in, &len))) 105 goto err; 106 } 107 ret = 1; 108err: 109 OPENSSL_free(buf); 110 OPENSSL_free(out); 111 return ret; 112} 113 114static int test_hexstr_ex_to_from(int test_index) 115{ 116 size_t len = 0; 117 char out[64]; 118 unsigned char buf[64]; 119 struct testdata *test = &tbl_testdata[test_index]; 120 121 return TEST_true(OPENSSL_hexstr2buf_ex(buf, sizeof(buf), &len, test->in, ':')) 122 && TEST_mem_eq(buf, len, test->expected, test->expected_len) 123 && TEST_true(OPENSSL_buf2hexstr_ex(out, sizeof(out), NULL, buf, len, 124 ':')) 125 && TEST_str_eq(out, test->in); 126} 127 128int setup_tests(void) 129{ 130 ADD_ALL_TESTS(test_hexstr_sep_to_from, OSSL_NELEM(tbl_testdata)); 131 ADD_ALL_TESTS(test_hexstr_to_from, OSSL_NELEM(tbl_testdata)); 132 ADD_ALL_TESTS(test_hexstr_ex_to_from, 2); 133 return 1; 134} 135