1*e0c4386eSCy Schubert /*
2*e0c4386eSCy Schubert * Copyright 2017-2022 The OpenSSL Project Authors. All Rights Reserved.
3*e0c4386eSCy Schubert * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
4*e0c4386eSCy Schubert *
5*e0c4386eSCy Schubert * Licensed under the Apache License 2.0 (the "License"). You may not use
6*e0c4386eSCy Schubert * this file except in compliance with the License. You can obtain a copy
7*e0c4386eSCy Schubert * in the file LICENSE in the source distribution or at
8*e0c4386eSCy Schubert * https://www.openssl.org/source/license.html
9*e0c4386eSCy Schubert */
10*e0c4386eSCy Schubert
11*e0c4386eSCy Schubert #include <stdio.h>
12*e0c4386eSCy Schubert #include <string.h>
13*e0c4386eSCy Schubert
14*e0c4386eSCy Schubert #include <openssl/opensslconf.h>
15*e0c4386eSCy Schubert #include <openssl/err.h>
16*e0c4386eSCy Schubert #include <openssl/crypto.h>
17*e0c4386eSCy Schubert #include <openssl/bn.h>
18*e0c4386eSCy Schubert
19*e0c4386eSCy Schubert #include "internal/nelem.h"
20*e0c4386eSCy Schubert #include "testutil.h"
21*e0c4386eSCy Schubert
22*e0c4386eSCy Schubert #define TEST(expected, test) test_case((expected), #test, (test))
23*e0c4386eSCy Schubert
test_case(int expected,const char * test,int result)24*e0c4386eSCy Schubert static int test_case(int expected, const char *test, int result)
25*e0c4386eSCy Schubert {
26*e0c4386eSCy Schubert if (result != expected) {
27*e0c4386eSCy Schubert fprintf(stderr, "# FATAL: %s != %d\n", test, expected);
28*e0c4386eSCy Schubert return 0;
29*e0c4386eSCy Schubert }
30*e0c4386eSCy Schubert return 1;
31*e0c4386eSCy Schubert }
32*e0c4386eSCy Schubert
test_int(void)33*e0c4386eSCy Schubert static int test_int(void)
34*e0c4386eSCy Schubert {
35*e0c4386eSCy Schubert if (!TEST(1, TEST_int_eq(1, 1))
36*e0c4386eSCy Schubert || !TEST(0, TEST_int_eq(1, -1))
37*e0c4386eSCy Schubert || !TEST(1, TEST_int_ne(1, 2))
38*e0c4386eSCy Schubert || !TEST(0, TEST_int_ne(3, 3))
39*e0c4386eSCy Schubert || !TEST(1, TEST_int_lt(4, 9))
40*e0c4386eSCy Schubert || !TEST(0, TEST_int_lt(9, 4))
41*e0c4386eSCy Schubert || !TEST(1, TEST_int_le(4, 9))
42*e0c4386eSCy Schubert || !TEST(1, TEST_int_le(5, 5))
43*e0c4386eSCy Schubert || !TEST(0, TEST_int_le(9, 4))
44*e0c4386eSCy Schubert || !TEST(1, TEST_int_gt(8, 5))
45*e0c4386eSCy Schubert || !TEST(0, TEST_int_gt(5, 8))
46*e0c4386eSCy Schubert || !TEST(1, TEST_int_ge(8, 5))
47*e0c4386eSCy Schubert || !TEST(1, TEST_int_ge(6, 6))
48*e0c4386eSCy Schubert || !TEST(0, TEST_int_ge(5, 8)))
49*e0c4386eSCy Schubert goto err;
50*e0c4386eSCy Schubert return 1;
51*e0c4386eSCy Schubert
52*e0c4386eSCy Schubert err:
53*e0c4386eSCy Schubert return 0;
54*e0c4386eSCy Schubert }
55*e0c4386eSCy Schubert
test_uint(void)56*e0c4386eSCy Schubert static int test_uint(void)
57*e0c4386eSCy Schubert {
58*e0c4386eSCy Schubert if (!TEST(1, TEST_uint_eq(3u, 3u))
59*e0c4386eSCy Schubert || !TEST(0, TEST_uint_eq(3u, 5u))
60*e0c4386eSCy Schubert || !TEST(1, TEST_uint_ne(4u, 2u))
61*e0c4386eSCy Schubert || !TEST(0, TEST_uint_ne(6u, 6u))
62*e0c4386eSCy Schubert || !TEST(1, TEST_uint_lt(5u, 9u))
63*e0c4386eSCy Schubert || !TEST(0, TEST_uint_lt(9u, 5u))
64*e0c4386eSCy Schubert || !TEST(1, TEST_uint_le(5u, 9u))
65*e0c4386eSCy Schubert || !TEST(1, TEST_uint_le(7u, 7u))
66*e0c4386eSCy Schubert || !TEST(0, TEST_uint_le(9u, 5u))
67*e0c4386eSCy Schubert || !TEST(1, TEST_uint_gt(11u, 1u))
68*e0c4386eSCy Schubert || !TEST(0, TEST_uint_gt(1u, 11u))
69*e0c4386eSCy Schubert || !TEST(1, TEST_uint_ge(11u, 1u))
70*e0c4386eSCy Schubert || !TEST(1, TEST_uint_ge(6u, 6u))
71*e0c4386eSCy Schubert || !TEST(0, TEST_uint_ge(1u, 11u)))
72*e0c4386eSCy Schubert goto err;
73*e0c4386eSCy Schubert return 1;
74*e0c4386eSCy Schubert
75*e0c4386eSCy Schubert err:
76*e0c4386eSCy Schubert return 0;
77*e0c4386eSCy Schubert }
78*e0c4386eSCy Schubert
test_char(void)79*e0c4386eSCy Schubert static int test_char(void)
80*e0c4386eSCy Schubert {
81*e0c4386eSCy Schubert if (!TEST(1, TEST_char_eq('a', 'a'))
82*e0c4386eSCy Schubert || !TEST(0, TEST_char_eq('a', 'A'))
83*e0c4386eSCy Schubert || !TEST(1, TEST_char_ne('a', 'c'))
84*e0c4386eSCy Schubert || !TEST(0, TEST_char_ne('e', 'e'))
85*e0c4386eSCy Schubert || !TEST(1, TEST_char_lt('i', 'x'))
86*e0c4386eSCy Schubert || !TEST(0, TEST_char_lt('x', 'i'))
87*e0c4386eSCy Schubert || !TEST(1, TEST_char_le('i', 'x'))
88*e0c4386eSCy Schubert || !TEST(1, TEST_char_le('n', 'n'))
89*e0c4386eSCy Schubert || !TEST(0, TEST_char_le('x', 'i'))
90*e0c4386eSCy Schubert || !TEST(1, TEST_char_gt('w', 'n'))
91*e0c4386eSCy Schubert || !TEST(0, TEST_char_gt('n', 'w'))
92*e0c4386eSCy Schubert || !TEST(1, TEST_char_ge('w', 'n'))
93*e0c4386eSCy Schubert || !TEST(1, TEST_char_ge('p', 'p'))
94*e0c4386eSCy Schubert || !TEST(0, TEST_char_ge('n', 'w')))
95*e0c4386eSCy Schubert goto err;
96*e0c4386eSCy Schubert return 1;
97*e0c4386eSCy Schubert
98*e0c4386eSCy Schubert err:
99*e0c4386eSCy Schubert return 0;
100*e0c4386eSCy Schubert }
101*e0c4386eSCy Schubert
test_uchar(void)102*e0c4386eSCy Schubert static int test_uchar(void)
103*e0c4386eSCy Schubert {
104*e0c4386eSCy Schubert if (!TEST(1, TEST_uchar_eq(49, 49))
105*e0c4386eSCy Schubert || !TEST(0, TEST_uchar_eq(49, 60))
106*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_ne(50, 2))
107*e0c4386eSCy Schubert || !TEST(0, TEST_uchar_ne(66, 66))
108*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_lt(60, 80))
109*e0c4386eSCy Schubert || !TEST(0, TEST_uchar_lt(80, 60))
110*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_le(60, 80))
111*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_le(78, 78))
112*e0c4386eSCy Schubert || !TEST(0, TEST_uchar_le(80, 60))
113*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_gt(88, 37))
114*e0c4386eSCy Schubert || !TEST(0, TEST_uchar_gt(37, 88))
115*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_ge(88, 37))
116*e0c4386eSCy Schubert || !TEST(1, TEST_uchar_ge(66, 66))
117*e0c4386eSCy Schubert || !TEST(0, TEST_uchar_ge(37, 88)))
118*e0c4386eSCy Schubert goto err;
119*e0c4386eSCy Schubert return 1;
120*e0c4386eSCy Schubert
121*e0c4386eSCy Schubert err:
122*e0c4386eSCy Schubert return 0;
123*e0c4386eSCy Schubert }
124*e0c4386eSCy Schubert
test_long(void)125*e0c4386eSCy Schubert static int test_long(void)
126*e0c4386eSCy Schubert {
127*e0c4386eSCy Schubert if (!TEST(1, TEST_long_eq(123l, 123l))
128*e0c4386eSCy Schubert || !TEST(0, TEST_long_eq(123l, -123l))
129*e0c4386eSCy Schubert || !TEST(1, TEST_long_ne(123l, 500l))
130*e0c4386eSCy Schubert || !TEST(0, TEST_long_ne(1000l, 1000l))
131*e0c4386eSCy Schubert || !TEST(1, TEST_long_lt(-8923l, 102934563l))
132*e0c4386eSCy Schubert || !TEST(0, TEST_long_lt(102934563l, -8923l))
133*e0c4386eSCy Schubert || !TEST(1, TEST_long_le(-8923l, 102934563l))
134*e0c4386eSCy Schubert || !TEST(1, TEST_long_le(12345l, 12345l))
135*e0c4386eSCy Schubert || !TEST(0, TEST_long_le(102934563l, -8923l))
136*e0c4386eSCy Schubert || !TEST(1, TEST_long_gt(84325677l, 12345l))
137*e0c4386eSCy Schubert || !TEST(0, TEST_long_gt(12345l, 84325677l))
138*e0c4386eSCy Schubert || !TEST(1, TEST_long_ge(84325677l, 12345l))
139*e0c4386eSCy Schubert || !TEST(1, TEST_long_ge(465869l, 465869l))
140*e0c4386eSCy Schubert || !TEST(0, TEST_long_ge(12345l, 84325677l)))
141*e0c4386eSCy Schubert goto err;
142*e0c4386eSCy Schubert return 1;
143*e0c4386eSCy Schubert
144*e0c4386eSCy Schubert err:
145*e0c4386eSCy Schubert return 0;
146*e0c4386eSCy Schubert }
147*e0c4386eSCy Schubert
test_ulong(void)148*e0c4386eSCy Schubert static int test_ulong(void)
149*e0c4386eSCy Schubert {
150*e0c4386eSCy Schubert if (!TEST(1, TEST_ulong_eq(919ul, 919ul))
151*e0c4386eSCy Schubert || !TEST(0, TEST_ulong_eq(919ul, 10234ul))
152*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_ne(8190ul, 66ul))
153*e0c4386eSCy Schubert || !TEST(0, TEST_ulong_ne(10555ul, 10555ul))
154*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_lt(10234ul, 1000000ul))
155*e0c4386eSCy Schubert || !TEST(0, TEST_ulong_lt(1000000ul, 10234ul))
156*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_le(10234ul, 1000000ul))
157*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_le(100000ul, 100000ul))
158*e0c4386eSCy Schubert || !TEST(0, TEST_ulong_le(1000000ul, 10234ul))
159*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_gt(100000000ul, 22ul))
160*e0c4386eSCy Schubert || !TEST(0, TEST_ulong_gt(22ul, 100000000ul))
161*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_ge(100000000ul, 22ul))
162*e0c4386eSCy Schubert || !TEST(1, TEST_ulong_ge(10555ul, 10555ul))
163*e0c4386eSCy Schubert || !TEST(0, TEST_ulong_ge(22ul, 100000000ul)))
164*e0c4386eSCy Schubert goto err;
165*e0c4386eSCy Schubert return 1;
166*e0c4386eSCy Schubert
167*e0c4386eSCy Schubert err:
168*e0c4386eSCy Schubert return 0;
169*e0c4386eSCy Schubert }
170*e0c4386eSCy Schubert
test_size_t(void)171*e0c4386eSCy Schubert static int test_size_t(void)
172*e0c4386eSCy Schubert {
173*e0c4386eSCy Schubert if (!TEST(1, TEST_size_t_eq((size_t)10, (size_t)10))
174*e0c4386eSCy Schubert || !TEST(0, TEST_size_t_eq((size_t)10, (size_t)12))
175*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_ne((size_t)10, (size_t)12))
176*e0c4386eSCy Schubert || !TEST(0, TEST_size_t_ne((size_t)24, (size_t)24))
177*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_lt((size_t)30, (size_t)88))
178*e0c4386eSCy Schubert || !TEST(0, TEST_size_t_lt((size_t)88, (size_t)30))
179*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_le((size_t)30, (size_t)88))
180*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_le((size_t)33, (size_t)33))
181*e0c4386eSCy Schubert || !TEST(0, TEST_size_t_le((size_t)88, (size_t)30))
182*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_gt((size_t)52, (size_t)33))
183*e0c4386eSCy Schubert || !TEST(0, TEST_size_t_gt((size_t)33, (size_t)52))
184*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_ge((size_t)52, (size_t)33))
185*e0c4386eSCy Schubert || !TEST(1, TEST_size_t_ge((size_t)38, (size_t)38))
186*e0c4386eSCy Schubert || !TEST(0, TEST_size_t_ge((size_t)33, (size_t)52)))
187*e0c4386eSCy Schubert goto err;
188*e0c4386eSCy Schubert return 1;
189*e0c4386eSCy Schubert
190*e0c4386eSCy Schubert err:
191*e0c4386eSCy Schubert return 0;
192*e0c4386eSCy Schubert }
193*e0c4386eSCy Schubert
test_time_t(void)194*e0c4386eSCy Schubert static int test_time_t(void)
195*e0c4386eSCy Schubert {
196*e0c4386eSCy Schubert if (!TEST(1, TEST_time_t_eq((time_t)10, (time_t)10))
197*e0c4386eSCy Schubert || !TEST(0, TEST_time_t_eq((time_t)10, (time_t)12))
198*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_ne((time_t)10, (time_t)12))
199*e0c4386eSCy Schubert || !TEST(0, TEST_time_t_ne((time_t)24, (time_t)24))
200*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_lt((time_t)30, (time_t)88))
201*e0c4386eSCy Schubert || !TEST(0, TEST_time_t_lt((time_t)88, (time_t)30))
202*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_le((time_t)30, (time_t)88))
203*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_le((time_t)33, (time_t)33))
204*e0c4386eSCy Schubert || !TEST(0, TEST_time_t_le((time_t)88, (time_t)30))
205*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_gt((time_t)52, (time_t)33))
206*e0c4386eSCy Schubert || !TEST(0, TEST_time_t_gt((time_t)33, (time_t)52))
207*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_ge((time_t)52, (time_t)33))
208*e0c4386eSCy Schubert || !TEST(1, TEST_time_t_ge((time_t)38, (time_t)38))
209*e0c4386eSCy Schubert || !TEST(0, TEST_time_t_ge((time_t)33, (time_t)52)))
210*e0c4386eSCy Schubert goto err;
211*e0c4386eSCy Schubert return 1;
212*e0c4386eSCy Schubert
213*e0c4386eSCy Schubert err:
214*e0c4386eSCy Schubert return 0;
215*e0c4386eSCy Schubert }
216*e0c4386eSCy Schubert
test_pointer(void)217*e0c4386eSCy Schubert static int test_pointer(void)
218*e0c4386eSCy Schubert {
219*e0c4386eSCy Schubert int x = 0;
220*e0c4386eSCy Schubert char y = 1;
221*e0c4386eSCy Schubert
222*e0c4386eSCy Schubert if (!TEST(1, TEST_ptr(&y))
223*e0c4386eSCy Schubert || !TEST(0, TEST_ptr(NULL))
224*e0c4386eSCy Schubert || !TEST(0, TEST_ptr_null(&y))
225*e0c4386eSCy Schubert || !TEST(1, TEST_ptr_null(NULL))
226*e0c4386eSCy Schubert || !TEST(1, TEST_ptr_eq(NULL, NULL))
227*e0c4386eSCy Schubert || !TEST(0, TEST_ptr_eq(NULL, &y))
228*e0c4386eSCy Schubert || !TEST(0, TEST_ptr_eq(&y, NULL))
229*e0c4386eSCy Schubert || !TEST(0, TEST_ptr_eq(&y, &x))
230*e0c4386eSCy Schubert || !TEST(1, TEST_ptr_eq(&x, &x))
231*e0c4386eSCy Schubert || !TEST(0, TEST_ptr_ne(NULL, NULL))
232*e0c4386eSCy Schubert || !TEST(1, TEST_ptr_ne(NULL, &y))
233*e0c4386eSCy Schubert || !TEST(1, TEST_ptr_ne(&y, NULL))
234*e0c4386eSCy Schubert || !TEST(1, TEST_ptr_ne(&y, &x))
235*e0c4386eSCy Schubert || !TEST(0, TEST_ptr_ne(&x, &x)))
236*e0c4386eSCy Schubert goto err;
237*e0c4386eSCy Schubert return 1;
238*e0c4386eSCy Schubert
239*e0c4386eSCy Schubert err:
240*e0c4386eSCy Schubert return 0;
241*e0c4386eSCy Schubert }
242*e0c4386eSCy Schubert
test_bool(void)243*e0c4386eSCy Schubert static int test_bool(void)
244*e0c4386eSCy Schubert {
245*e0c4386eSCy Schubert if (!TEST(0, TEST_true(0))
246*e0c4386eSCy Schubert || !TEST(1, TEST_true(1))
247*e0c4386eSCy Schubert || !TEST(1, TEST_false(0))
248*e0c4386eSCy Schubert || !TEST(0, TEST_false(1)))
249*e0c4386eSCy Schubert goto err;
250*e0c4386eSCy Schubert return 1;
251*e0c4386eSCy Schubert
252*e0c4386eSCy Schubert err:
253*e0c4386eSCy Schubert return 0;
254*e0c4386eSCy Schubert }
255*e0c4386eSCy Schubert
test_string(void)256*e0c4386eSCy Schubert static int test_string(void)
257*e0c4386eSCy Schubert {
258*e0c4386eSCy Schubert static char buf[] = "abc";
259*e0c4386eSCy Schubert
260*e0c4386eSCy Schubert if (!TEST(1, TEST_str_eq(NULL, NULL))
261*e0c4386eSCy Schubert || !TEST(1, TEST_str_eq("abc", buf))
262*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq("abc", NULL))
263*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq("abc", ""))
264*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq(NULL, buf))
265*e0c4386eSCy Schubert || !TEST(0, TEST_str_ne(NULL, NULL))
266*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq("", NULL))
267*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq(NULL, ""))
268*e0c4386eSCy Schubert || !TEST(0, TEST_str_ne("", ""))
269*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq("\1\2\3\4\5", "\1x\3\6\5"))
270*e0c4386eSCy Schubert || !TEST(0, TEST_str_ne("abc", buf))
271*e0c4386eSCy Schubert || !TEST(1, TEST_str_ne("abc", NULL))
272*e0c4386eSCy Schubert || !TEST(1, TEST_str_ne(NULL, buf))
273*e0c4386eSCy Schubert || !TEST(0, TEST_str_eq("abcdef", "abcdefghijk")))
274*e0c4386eSCy Schubert goto err;
275*e0c4386eSCy Schubert return 1;
276*e0c4386eSCy Schubert
277*e0c4386eSCy Schubert err:
278*e0c4386eSCy Schubert return 0;
279*e0c4386eSCy Schubert }
280*e0c4386eSCy Schubert
test_memory(void)281*e0c4386eSCy Schubert static int test_memory(void)
282*e0c4386eSCy Schubert {
283*e0c4386eSCy Schubert static char buf[] = "xyz";
284*e0c4386eSCy Schubert
285*e0c4386eSCy Schubert if (!TEST(1, TEST_mem_eq(NULL, 0, NULL, 0))
286*e0c4386eSCy Schubert || !TEST(1, TEST_mem_eq(NULL, 1, NULL, 2))
287*e0c4386eSCy Schubert || !TEST(0, TEST_mem_eq(NULL, 0, "xyz", 3))
288*e0c4386eSCy Schubert || !TEST(0, TEST_mem_eq(NULL, 7, "abc", 3))
289*e0c4386eSCy Schubert || !TEST(0, TEST_mem_ne(NULL, 0, NULL, 0))
290*e0c4386eSCy Schubert || !TEST(0, TEST_mem_eq(NULL, 0, "", 0))
291*e0c4386eSCy Schubert || !TEST(0, TEST_mem_eq("", 0, NULL, 0))
292*e0c4386eSCy Schubert || !TEST(0, TEST_mem_ne("", 0, "", 0))
293*e0c4386eSCy Schubert || !TEST(0, TEST_mem_eq("xyz", 3, NULL, 0))
294*e0c4386eSCy Schubert || !TEST(0, TEST_mem_eq("xyz", 3, buf, sizeof(buf)))
295*e0c4386eSCy Schubert || !TEST(1, TEST_mem_eq("xyz", 4, buf, sizeof(buf))))
296*e0c4386eSCy Schubert goto err;
297*e0c4386eSCy Schubert return 1;
298*e0c4386eSCy Schubert
299*e0c4386eSCy Schubert err:
300*e0c4386eSCy Schubert return 0;
301*e0c4386eSCy Schubert }
302*e0c4386eSCy Schubert
test_memory_overflow(void)303*e0c4386eSCy Schubert static int test_memory_overflow(void)
304*e0c4386eSCy Schubert {
305*e0c4386eSCy Schubert /* Verify that the memory printing overflows without walking the stack */
306*e0c4386eSCy Schubert const char *p = "1234567890123456789012345678901234567890123456789012";
307*e0c4386eSCy Schubert const char *q = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
308*e0c4386eSCy Schubert
309*e0c4386eSCy Schubert return TEST(0, TEST_mem_eq(p, strlen(p), q, strlen(q)));
310*e0c4386eSCy Schubert }
311*e0c4386eSCy Schubert
test_bignum(void)312*e0c4386eSCy Schubert static int test_bignum(void)
313*e0c4386eSCy Schubert {
314*e0c4386eSCy Schubert BIGNUM *a = NULL, *b = NULL, *c = NULL;
315*e0c4386eSCy Schubert int r = 0;
316*e0c4386eSCy Schubert
317*e0c4386eSCy Schubert if (!TEST(1, TEST_int_eq(BN_dec2bn(&a, "0"), 1))
318*e0c4386eSCy Schubert || !TEST(1, TEST_BN_eq_word(a, 0))
319*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq_word(a, 30))
320*e0c4386eSCy Schubert || !TEST(1, TEST_BN_abs_eq_word(a, 0))
321*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq_one(a))
322*e0c4386eSCy Schubert || !TEST(1, TEST_BN_eq_zero(a))
323*e0c4386eSCy Schubert || !TEST(0, TEST_BN_ne_zero(a))
324*e0c4386eSCy Schubert || !TEST(1, TEST_BN_le_zero(a))
325*e0c4386eSCy Schubert || !TEST(0, TEST_BN_lt_zero(a))
326*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ge_zero(a))
327*e0c4386eSCy Schubert || !TEST(0, TEST_BN_gt_zero(a))
328*e0c4386eSCy Schubert || !TEST(1, TEST_BN_even(a))
329*e0c4386eSCy Schubert || !TEST(0, TEST_BN_odd(a))
330*e0c4386eSCy Schubert || !TEST(1, TEST_BN_eq(b, c))
331*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq(a, b))
332*e0c4386eSCy Schubert || !TEST(0, TEST_BN_ne(NULL, c))
333*e0c4386eSCy Schubert || !TEST(1, TEST_int_eq(BN_dec2bn(&b, "1"), 1))
334*e0c4386eSCy Schubert || !TEST(1, TEST_BN_eq_word(b, 1))
335*e0c4386eSCy Schubert || !TEST(1, TEST_BN_eq_one(b))
336*e0c4386eSCy Schubert || !TEST(0, TEST_BN_abs_eq_word(b, 0))
337*e0c4386eSCy Schubert || !TEST(1, TEST_BN_abs_eq_word(b, 1))
338*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq_zero(b))
339*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ne_zero(b))
340*e0c4386eSCy Schubert || !TEST(0, TEST_BN_le_zero(b))
341*e0c4386eSCy Schubert || !TEST(0, TEST_BN_lt_zero(b))
342*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ge_zero(b))
343*e0c4386eSCy Schubert || !TEST(1, TEST_BN_gt_zero(b))
344*e0c4386eSCy Schubert || !TEST(0, TEST_BN_even(b))
345*e0c4386eSCy Schubert || !TEST(1, TEST_BN_odd(b))
346*e0c4386eSCy Schubert || !TEST(1, TEST_int_eq(BN_dec2bn(&c, "-334739439"), 10))
347*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq_word(c, 334739439))
348*e0c4386eSCy Schubert || !TEST(1, TEST_BN_abs_eq_word(c, 334739439))
349*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq_zero(c))
350*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ne_zero(c))
351*e0c4386eSCy Schubert || !TEST(1, TEST_BN_le_zero(c))
352*e0c4386eSCy Schubert || !TEST(1, TEST_BN_lt_zero(c))
353*e0c4386eSCy Schubert || !TEST(0, TEST_BN_ge_zero(c))
354*e0c4386eSCy Schubert || !TEST(0, TEST_BN_gt_zero(c))
355*e0c4386eSCy Schubert || !TEST(0, TEST_BN_even(c))
356*e0c4386eSCy Schubert || !TEST(1, TEST_BN_odd(c))
357*e0c4386eSCy Schubert || !TEST(1, TEST_BN_eq(a, a))
358*e0c4386eSCy Schubert || !TEST(0, TEST_BN_ne(a, a))
359*e0c4386eSCy Schubert || !TEST(0, TEST_BN_eq(a, b))
360*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ne(a, b))
361*e0c4386eSCy Schubert || !TEST(0, TEST_BN_lt(a, c))
362*e0c4386eSCy Schubert || !TEST(1, TEST_BN_lt(c, b))
363*e0c4386eSCy Schubert || !TEST(0, TEST_BN_lt(b, c))
364*e0c4386eSCy Schubert || !TEST(0, TEST_BN_le(a, c))
365*e0c4386eSCy Schubert || !TEST(1, TEST_BN_le(c, b))
366*e0c4386eSCy Schubert || !TEST(0, TEST_BN_le(b, c))
367*e0c4386eSCy Schubert || !TEST(1, TEST_BN_gt(a, c))
368*e0c4386eSCy Schubert || !TEST(0, TEST_BN_gt(c, b))
369*e0c4386eSCy Schubert || !TEST(1, TEST_BN_gt(b, c))
370*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ge(a, c))
371*e0c4386eSCy Schubert || !TEST(0, TEST_BN_ge(c, b))
372*e0c4386eSCy Schubert || !TEST(1, TEST_BN_ge(b, c)))
373*e0c4386eSCy Schubert goto err;
374*e0c4386eSCy Schubert
375*e0c4386eSCy Schubert r = 1;
376*e0c4386eSCy Schubert err:
377*e0c4386eSCy Schubert BN_free(a);
378*e0c4386eSCy Schubert BN_free(b);
379*e0c4386eSCy Schubert BN_free(c);
380*e0c4386eSCy Schubert return r;
381*e0c4386eSCy Schubert }
382*e0c4386eSCy Schubert
test_long_output(void)383*e0c4386eSCy Schubert static int test_long_output(void)
384*e0c4386eSCy Schubert {
385*e0c4386eSCy Schubert const char *p = "1234567890123456789012345678901234567890123456789012";
386*e0c4386eSCy Schubert const char *q = "1234567890klmnopqrs01234567890EFGHIJKLM0123456789XYZ";
387*e0c4386eSCy Schubert const char *r = "1234567890123456789012345678901234567890123456789012"
388*e0c4386eSCy Schubert "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXY+"
389*e0c4386eSCy Schubert "12345678901234567890123ABC78901234567890123456789012";
390*e0c4386eSCy Schubert const char *s = "1234567890123456789012345678901234567890123456789012"
391*e0c4386eSCy Schubert "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXY-"
392*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
393*e0c4386eSCy Schubert "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
394*e0c4386eSCy Schubert
395*e0c4386eSCy Schubert return TEST(0, TEST_str_eq(p, q))
396*e0c4386eSCy Schubert & TEST(0, TEST_str_eq(q, r))
397*e0c4386eSCy Schubert & TEST(0, TEST_str_eq(r, s))
398*e0c4386eSCy Schubert & TEST(0, TEST_mem_eq(r, strlen(r), s, strlen(s)));
399*e0c4386eSCy Schubert }
400*e0c4386eSCy Schubert
test_long_bignum(void)401*e0c4386eSCy Schubert static int test_long_bignum(void)
402*e0c4386eSCy Schubert {
403*e0c4386eSCy Schubert int r;
404*e0c4386eSCy Schubert BIGNUM *a = NULL, *b = NULL, *c = NULL, *d = NULL;
405*e0c4386eSCy Schubert const char as[] = "1234567890123456789012345678901234567890123456789012"
406*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
407*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
408*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
409*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
410*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
411*e0c4386eSCy Schubert "FFFFFF";
412*e0c4386eSCy Schubert const char bs[] = "1234567890123456789012345678901234567890123456789012"
413*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789013"
414*e0c4386eSCy Schubert "987657";
415*e0c4386eSCy Schubert const char cs[] = "-" /* 64 characters plus sign */
416*e0c4386eSCy Schubert "123456789012345678901234567890"
417*e0c4386eSCy Schubert "123456789012345678901234567890"
418*e0c4386eSCy Schubert "ABCD";
419*e0c4386eSCy Schubert const char ds[] = "-" /* 63 characters plus sign */
420*e0c4386eSCy Schubert "23456789A123456789B123456789C"
421*e0c4386eSCy Schubert "123456789D123456789E123456789F"
422*e0c4386eSCy Schubert "ABCD";
423*e0c4386eSCy Schubert
424*e0c4386eSCy Schubert r = TEST_true(BN_hex2bn(&a, as))
425*e0c4386eSCy Schubert && TEST_true(BN_hex2bn(&b, bs))
426*e0c4386eSCy Schubert && TEST_true(BN_hex2bn(&c, cs))
427*e0c4386eSCy Schubert && TEST_true(BN_hex2bn(&d, ds))
428*e0c4386eSCy Schubert && (TEST(0, TEST_BN_eq(a, b))
429*e0c4386eSCy Schubert & TEST(0, TEST_BN_eq(b, a))
430*e0c4386eSCy Schubert & TEST(0, TEST_BN_eq(b, NULL))
431*e0c4386eSCy Schubert & TEST(0, TEST_BN_eq(NULL, a))
432*e0c4386eSCy Schubert & TEST(1, TEST_BN_ne(a, NULL))
433*e0c4386eSCy Schubert & TEST(0, TEST_BN_eq(c, d)));
434*e0c4386eSCy Schubert BN_free(a);
435*e0c4386eSCy Schubert BN_free(b);
436*e0c4386eSCy Schubert BN_free(c);
437*e0c4386eSCy Schubert BN_free(d);
438*e0c4386eSCy Schubert return r;
439*e0c4386eSCy Schubert }
440*e0c4386eSCy Schubert
test_messages(void)441*e0c4386eSCy Schubert static int test_messages(void)
442*e0c4386eSCy Schubert {
443*e0c4386eSCy Schubert TEST_info("This is an %s message.", "info");
444*e0c4386eSCy Schubert TEST_error("This is an %s message.", "error");
445*e0c4386eSCy Schubert return 1;
446*e0c4386eSCy Schubert }
447*e0c4386eSCy Schubert
test_single_eval(void)448*e0c4386eSCy Schubert static int test_single_eval(void)
449*e0c4386eSCy Schubert {
450*e0c4386eSCy Schubert int i = 4;
451*e0c4386eSCy Schubert long l = -9000;
452*e0c4386eSCy Schubert char c = 'd';
453*e0c4386eSCy Schubert unsigned char uc = 22;
454*e0c4386eSCy Schubert unsigned long ul = 500;
455*e0c4386eSCy Schubert size_t st = 1234;
456*e0c4386eSCy Schubert char buf[4] = { 0 }, *p = buf;
457*e0c4386eSCy Schubert
458*e0c4386eSCy Schubert /* int */
459*e0c4386eSCy Schubert return TEST_int_eq(i++, 4)
460*e0c4386eSCy Schubert && TEST_int_eq(i, 5)
461*e0c4386eSCy Schubert && TEST_int_gt(++i, 5)
462*e0c4386eSCy Schubert && TEST_int_le(5, i++)
463*e0c4386eSCy Schubert && TEST_int_ne(--i, 5)
464*e0c4386eSCy Schubert && TEST_int_eq(12, i *= 2)
465*e0c4386eSCy Schubert /* Long */
466*e0c4386eSCy Schubert && TEST_long_eq(l--, -9000L)
467*e0c4386eSCy Schubert && TEST_long_eq(++l, -9000L)
468*e0c4386eSCy Schubert && TEST_long_ne(-9000L, l /= 2)
469*e0c4386eSCy Schubert && TEST_long_lt(--l, -4500L)
470*e0c4386eSCy Schubert /* char */
471*e0c4386eSCy Schubert && TEST_char_eq(++c, 'e')
472*e0c4386eSCy Schubert && TEST_char_eq('e', c--)
473*e0c4386eSCy Schubert && TEST_char_ne('d', --c)
474*e0c4386eSCy Schubert && TEST_char_le('b', --c)
475*e0c4386eSCy Schubert && TEST_char_lt(c++, 'c')
476*e0c4386eSCy Schubert /* unsigned char */
477*e0c4386eSCy Schubert && TEST_uchar_eq(22, uc++)
478*e0c4386eSCy Schubert && TEST_uchar_eq(uc /= 2, 11)
479*e0c4386eSCy Schubert && TEST_ulong_eq(ul ^= 1, 501)
480*e0c4386eSCy Schubert && TEST_ulong_eq(502, ul ^= 3)
481*e0c4386eSCy Schubert && TEST_ulong_eq(ul = ul * 3 - 6, 1500)
482*e0c4386eSCy Schubert /* size_t */
483*e0c4386eSCy Schubert && TEST_size_t_eq((--i, st++), 1234)
484*e0c4386eSCy Schubert && TEST_size_t_eq(st, 1235)
485*e0c4386eSCy Schubert && TEST_int_eq(11, i)
486*e0c4386eSCy Schubert /* pointers */
487*e0c4386eSCy Schubert && TEST_ptr_eq(p++, buf)
488*e0c4386eSCy Schubert && TEST_ptr_eq(buf + 2, ++p)
489*e0c4386eSCy Schubert && TEST_ptr_eq(buf, p -= 2)
490*e0c4386eSCy Schubert && TEST_ptr(++p)
491*e0c4386eSCy Schubert && TEST_ptr_eq(p, buf + 1)
492*e0c4386eSCy Schubert && TEST_ptr_null(p = NULL)
493*e0c4386eSCy Schubert /* strings */
494*e0c4386eSCy Schubert && TEST_str_eq(p = &("123456"[1]), "23456")
495*e0c4386eSCy Schubert && TEST_str_eq("3456", ++p)
496*e0c4386eSCy Schubert && TEST_str_ne(p++, "456")
497*e0c4386eSCy Schubert /* memory */
498*e0c4386eSCy Schubert && TEST_mem_eq(--p, sizeof("3456"), "3456", sizeof("3456"))
499*e0c4386eSCy Schubert && TEST_mem_ne(p++, sizeof("456"), "456", sizeof("456"))
500*e0c4386eSCy Schubert && TEST_mem_eq(p--, sizeof("456"), "456", sizeof("456"));
501*e0c4386eSCy Schubert }
502*e0c4386eSCy Schubert
test_output(void)503*e0c4386eSCy Schubert static int test_output(void)
504*e0c4386eSCy Schubert {
505*e0c4386eSCy Schubert const char s[] = "1234567890123456789012345678901234567890123456789012"
506*e0c4386eSCy Schubert "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
507*e0c4386eSCy Schubert
508*e0c4386eSCy Schubert test_output_string("test", s, sizeof(s) - 1);
509*e0c4386eSCy Schubert test_output_memory("test", (const unsigned char *)s, sizeof(s));
510*e0c4386eSCy Schubert return 1;
511*e0c4386eSCy Schubert }
512*e0c4386eSCy Schubert
513*e0c4386eSCy Schubert static const char *bn_output_tests[] = {
514*e0c4386eSCy Schubert NULL,
515*e0c4386eSCy Schubert "0",
516*e0c4386eSCy Schubert "-12345678",
517*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789012"
518*e0c4386eSCy Schubert "1234567890123456789012345678901234567890123456789013"
519*e0c4386eSCy Schubert "987657"
520*e0c4386eSCy Schubert };
521*e0c4386eSCy Schubert
test_bn_output(int n)522*e0c4386eSCy Schubert static int test_bn_output(int n)
523*e0c4386eSCy Schubert {
524*e0c4386eSCy Schubert BIGNUM *b = NULL;
525*e0c4386eSCy Schubert
526*e0c4386eSCy Schubert if (bn_output_tests[n] != NULL
527*e0c4386eSCy Schubert && !TEST_true(BN_hex2bn(&b, bn_output_tests[n])))
528*e0c4386eSCy Schubert return 0;
529*e0c4386eSCy Schubert test_output_bignum(bn_output_tests[n], b);
530*e0c4386eSCy Schubert BN_free(b);
531*e0c4386eSCy Schubert return 1;
532*e0c4386eSCy Schubert }
533*e0c4386eSCy Schubert
test_skip_one(void)534*e0c4386eSCy Schubert static int test_skip_one(void)
535*e0c4386eSCy Schubert {
536*e0c4386eSCy Schubert return TEST_skip("skip test");
537*e0c4386eSCy Schubert }
538*e0c4386eSCy Schubert
test_skip_many(int n)539*e0c4386eSCy Schubert static int test_skip_many(int n)
540*e0c4386eSCy Schubert {
541*e0c4386eSCy Schubert return TEST_skip("skip tests: %d", n);
542*e0c4386eSCy Schubert }
543*e0c4386eSCy Schubert
test_skip_null(void)544*e0c4386eSCy Schubert static int test_skip_null(void)
545*e0c4386eSCy Schubert {
546*e0c4386eSCy Schubert /*
547*e0c4386eSCy Schubert * This is not a recommended way of skipping a test, a reason or
548*e0c4386eSCy Schubert * description should be included.
549*e0c4386eSCy Schubert */
550*e0c4386eSCy Schubert return TEST_skip(NULL);
551*e0c4386eSCy Schubert }
552*e0c4386eSCy Schubert
setup_tests(void)553*e0c4386eSCy Schubert int setup_tests(void)
554*e0c4386eSCy Schubert {
555*e0c4386eSCy Schubert ADD_TEST(test_int);
556*e0c4386eSCy Schubert ADD_TEST(test_uint);
557*e0c4386eSCy Schubert ADD_TEST(test_char);
558*e0c4386eSCy Schubert ADD_TEST(test_uchar);
559*e0c4386eSCy Schubert ADD_TEST(test_long);
560*e0c4386eSCy Schubert ADD_TEST(test_ulong);
561*e0c4386eSCy Schubert ADD_TEST(test_size_t);
562*e0c4386eSCy Schubert ADD_TEST(test_time_t);
563*e0c4386eSCy Schubert ADD_TEST(test_pointer);
564*e0c4386eSCy Schubert ADD_TEST(test_bool);
565*e0c4386eSCy Schubert ADD_TEST(test_string);
566*e0c4386eSCy Schubert ADD_TEST(test_memory);
567*e0c4386eSCy Schubert ADD_TEST(test_memory_overflow);
568*e0c4386eSCy Schubert ADD_TEST(test_bignum);
569*e0c4386eSCy Schubert ADD_TEST(test_long_bignum);
570*e0c4386eSCy Schubert ADD_TEST(test_long_output);
571*e0c4386eSCy Schubert ADD_TEST(test_messages);
572*e0c4386eSCy Schubert ADD_TEST(test_single_eval);
573*e0c4386eSCy Schubert ADD_TEST(test_output);
574*e0c4386eSCy Schubert ADD_ALL_TESTS(test_bn_output, OSSL_NELEM(bn_output_tests));
575*e0c4386eSCy Schubert ADD_TEST(test_skip_one);
576*e0c4386eSCy Schubert ADD_TEST(test_skip_null);
577*e0c4386eSCy Schubert ADD_ALL_TESTS(test_skip_many, 3);
578*e0c4386eSCy Schubert return 1;
579*e0c4386eSCy Schubert }
580