]>
git.ipfire.org Git - thirdparty/systemd.git/blob - src/test/test-hexdecoct.c
1 /* SPDX-License-Identifier: LGPL-2.1+ */
3 This file is part of systemd.
5 Copyright 2010 Lennart Poettering
7 systemd is free software; you can redistribute it and/or modify it
8 under the terms of the GNU Lesser General Public License as published by
9 the Free Software Foundation; either version 2.1 of the License, or
10 (at your option) any later version.
12 systemd is distributed in the hope that it will be useful, but
13 WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
17 You should have received a copy of the GNU Lesser General Public License
18 along with systemd; If not, see <http://www.gnu.org/licenses/>.
23 #include "alloc-util.h"
24 #include "hexdecoct.h"
26 #include "string-util.h"
28 static void test_hexchar(void) {
29 assert_se(hexchar(0xa) == 'a');
30 assert_se(hexchar(0x0) == '0');
33 static void test_unhexchar(void) {
34 assert_se(unhexchar('a') == 0xA);
35 assert_se(unhexchar('A') == 0xA);
36 assert_se(unhexchar('0') == 0x0);
39 static void test_base32hexchar(void) {
40 assert_se(base32hexchar(0) == '0');
41 assert_se(base32hexchar(9) == '9');
42 assert_se(base32hexchar(10) == 'A');
43 assert_se(base32hexchar(31) == 'V');
46 static void test_unbase32hexchar(void) {
47 assert_se(unbase32hexchar('0') == 0);
48 assert_se(unbase32hexchar('9') == 9);
49 assert_se(unbase32hexchar('A') == 10);
50 assert_se(unbase32hexchar('V') == 31);
51 assert_se(unbase32hexchar('=') == -EINVAL
);
54 static void test_base64char(void) {
55 assert_se(base64char(0) == 'A');
56 assert_se(base64char(26) == 'a');
57 assert_se(base64char(63) == '/');
60 static void test_unbase64char(void) {
61 assert_se(unbase64char('A') == 0);
62 assert_se(unbase64char('Z') == 25);
63 assert_se(unbase64char('a') == 26);
64 assert_se(unbase64char('z') == 51);
65 assert_se(unbase64char('0') == 52);
66 assert_se(unbase64char('9') == 61);
67 assert_se(unbase64char('+') == 62);
68 assert_se(unbase64char('/') == 63);
69 assert_se(unbase64char('=') == -EINVAL
);
72 static void test_octchar(void) {
73 assert_se(octchar(00) == '0');
74 assert_se(octchar(07) == '7');
77 static void test_unoctchar(void) {
78 assert_se(unoctchar('0') == 00);
79 assert_se(unoctchar('7') == 07);
82 static void test_decchar(void) {
83 assert_se(decchar(0) == '0');
84 assert_se(decchar(9) == '9');
87 static void test_undecchar(void) {
88 assert_se(undecchar('0') == 0);
89 assert_se(undecchar('9') == 9);
92 static void test_unhexmem(void) {
93 const char *hex
= "efa2149213";
94 const char *hex_invalid
= "efa214921o";
95 _cleanup_free_
char *hex2
= NULL
;
96 _cleanup_free_
void *mem
= NULL
;
99 assert_se(unhexmem(hex_invalid
, strlen(hex_invalid
), &mem
, &len
) == -EINVAL
);
100 assert_se(unhexmem(hex
, strlen(hex
) + 1, &mem
, &len
) == -EINVAL
);
101 assert_se(unhexmem(hex
, strlen(hex
) - 1, &mem
, &len
) == -EINVAL
);
102 assert_se(unhexmem(hex
, strlen(hex
), &mem
, &len
) == 0);
104 assert_se((hex2
= hexmem(mem
, len
)));
105 assert_se(streq(hex
, hex2
));
108 /* https://tools.ietf.org/html/rfc4648#section-10 */
109 static void test_base32hexmem(void) {
112 b32
= base32hexmem("", STRLEN(""), true);
114 assert_se(streq(b32
, ""));
117 b32
= base32hexmem("f", STRLEN("f"), true);
119 assert_se(streq(b32
, "CO======"));
122 b32
= base32hexmem("fo", STRLEN("fo"), true);
124 assert_se(streq(b32
, "CPNG===="));
127 b32
= base32hexmem("foo", STRLEN("foo"), true);
129 assert_se(streq(b32
, "CPNMU==="));
132 b32
= base32hexmem("foob", STRLEN("foob"), true);
134 assert_se(streq(b32
, "CPNMUOG="));
137 b32
= base32hexmem("fooba", STRLEN("fooba"), true);
139 assert_se(streq(b32
, "CPNMUOJ1"));
142 b32
= base32hexmem("foobar", STRLEN("foobar"), true);
144 assert_se(streq(b32
, "CPNMUOJ1E8======"));
147 b32
= base32hexmem("", STRLEN(""), false);
149 assert_se(streq(b32
, ""));
152 b32
= base32hexmem("f", STRLEN("f"), false);
154 assert_se(streq(b32
, "CO"));
157 b32
= base32hexmem("fo", STRLEN("fo"), false);
159 assert_se(streq(b32
, "CPNG"));
162 b32
= base32hexmem("foo", STRLEN("foo"), false);
164 assert_se(streq(b32
, "CPNMU"));
167 b32
= base32hexmem("foob", STRLEN("foob"), false);
169 assert_se(streq(b32
, "CPNMUOG"));
172 b32
= base32hexmem("fooba", STRLEN("fooba"), false);
174 assert_se(streq(b32
, "CPNMUOJ1"));
177 b32
= base32hexmem("foobar", STRLEN("foobar"), false);
179 assert_se(streq(b32
, "CPNMUOJ1E8"));
183 static void test_unbase32hexmem(void) {
187 assert_se(unbase32hexmem("", STRLEN(""), true, &mem
, &len
) == 0);
188 assert_se(streq(strndupa(mem
, len
), ""));
191 assert_se(unbase32hexmem("CO======", STRLEN("CO======"), true, &mem
, &len
) == 0);
192 assert_se(streq(strndupa(mem
, len
), "f"));
195 assert_se(unbase32hexmem("CPNG====", STRLEN("CPNG===="), true, &mem
, &len
) == 0);
196 assert_se(streq(strndupa(mem
, len
), "fo"));
199 assert_se(unbase32hexmem("CPNMU===", STRLEN("CPNMU==="), true, &mem
, &len
) == 0);
200 assert_se(streq(strndupa(mem
, len
), "foo"));
203 assert_se(unbase32hexmem("CPNMUOG=", STRLEN("CPNMUOG="), true, &mem
, &len
) == 0);
204 assert_se(streq(strndupa(mem
, len
), "foob"));
207 assert_se(unbase32hexmem("CPNMUOJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == 0);
208 assert_se(streq(strndupa(mem
, len
), "fooba"));
211 assert_se(unbase32hexmem("CPNMUOJ1E8======", STRLEN("CPNMUOJ1E8======"), true, &mem
, &len
) == 0);
212 assert_se(streq(strndupa(mem
, len
), "foobar"));
215 assert_se(unbase32hexmem("A", STRLEN("A"), true, &mem
, &len
) == -EINVAL
);
216 assert_se(unbase32hexmem("A=======", STRLEN("A======="), true, &mem
, &len
) == -EINVAL
);
217 assert_se(unbase32hexmem("AAA=====", STRLEN("AAA====="), true, &mem
, &len
) == -EINVAL
);
218 assert_se(unbase32hexmem("AAAAAA==", STRLEN("AAAAAA=="), true, &mem
, &len
) == -EINVAL
);
219 assert_se(unbase32hexmem("AB======", STRLEN("AB======"), true, &mem
, &len
) == -EINVAL
);
220 assert_se(unbase32hexmem("AAAB====", STRLEN("AAAB===="), true, &mem
, &len
) == -EINVAL
);
221 assert_se(unbase32hexmem("AAAAB===", STRLEN("AAAAB==="), true, &mem
, &len
) == -EINVAL
);
222 assert_se(unbase32hexmem("AAAAAAB=", STRLEN("AAAAAAB="), true, &mem
, &len
) == -EINVAL
);
224 assert_se(unbase32hexmem("XPNMUOJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
225 assert_se(unbase32hexmem("CXNMUOJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
226 assert_se(unbase32hexmem("CPXMUOJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
227 assert_se(unbase32hexmem("CPNXUOJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
228 assert_se(unbase32hexmem("CPNMXOJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
229 assert_se(unbase32hexmem("CPNMUXJ1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
230 assert_se(unbase32hexmem("CPNMUOX1", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
231 assert_se(unbase32hexmem("CPNMUOJX", STRLEN("CPNMUOJ1"), true, &mem
, &len
) == -EINVAL
);
233 assert_se(unbase32hexmem("", STRLEN(""), false, &mem
, &len
) == 0);
234 assert_se(streq(strndupa(mem
, len
), ""));
237 assert_se(unbase32hexmem("CO", STRLEN("CO"), false, &mem
, &len
) == 0);
238 assert_se(streq(strndupa(mem
, len
), "f"));
241 assert_se(unbase32hexmem("CPNG", STRLEN("CPNG"), false, &mem
, &len
) == 0);
242 assert_se(streq(strndupa(mem
, len
), "fo"));
245 assert_se(unbase32hexmem("CPNMU", STRLEN("CPNMU"), false, &mem
, &len
) == 0);
246 assert_se(streq(strndupa(mem
, len
), "foo"));
249 assert_se(unbase32hexmem("CPNMUOG", STRLEN("CPNMUOG"), false, &mem
, &len
) == 0);
250 assert_se(streq(strndupa(mem
, len
), "foob"));
253 assert_se(unbase32hexmem("CPNMUOJ1", STRLEN("CPNMUOJ1"), false, &mem
, &len
) == 0);
254 assert_se(streq(strndupa(mem
, len
), "fooba"));
257 assert_se(unbase32hexmem("CPNMUOJ1E8", STRLEN("CPNMUOJ1E8"), false, &mem
, &len
) == 0);
258 assert_se(streq(strndupa(mem
, len
), "foobar"));
261 assert_se(unbase32hexmem("CPNMUOG=", STRLEN("CPNMUOG="), false, &mem
, &len
) == -EINVAL
);
262 assert_se(unbase32hexmem("CPNMUOJ1E8======", STRLEN("CPNMUOJ1E8======"), false, &mem
, &len
) == -EINVAL
);
263 assert_se(unbase32hexmem("A", STRLEN("A"), false, &mem
, &len
) == -EINVAL
);
264 assert_se(unbase32hexmem("A", STRLEN("A"), false, &mem
, &len
) == -EINVAL
);
265 assert_se(unbase32hexmem("AAA", STRLEN("AAA"), false, &mem
, &len
) == -EINVAL
);
266 assert_se(unbase32hexmem("AAAAAA", STRLEN("AAAAAA"), false, &mem
, &len
) == -EINVAL
);
267 assert_se(unbase32hexmem("AB", STRLEN("AB"), false, &mem
, &len
) == -EINVAL
);
268 assert_se(unbase32hexmem("AAAB", STRLEN("AAAB"), false, &mem
, &len
) == -EINVAL
);
269 assert_se(unbase32hexmem("AAAAB", STRLEN("AAAAB"), false, &mem
, &len
) == -EINVAL
);
270 assert_se(unbase32hexmem("AAAAAAB", STRLEN("AAAAAAB"), false, &mem
, &len
) == -EINVAL
);
273 /* https://tools.ietf.org/html/rfc4648#section-10 */
274 static void test_base64mem(void) {
277 assert_se(base64mem("", STRLEN(""), &b64
) == 0);
278 assert_se(streq(b64
, ""));
281 assert_se(base64mem("f", STRLEN("f"), &b64
) == 4);
282 assert_se(streq(b64
, "Zg=="));
285 assert_se(base64mem("fo", STRLEN("fo"), &b64
) == 4);
286 assert_se(streq(b64
, "Zm8="));
289 assert_se(base64mem("foo", STRLEN("foo"), &b64
) == 4);
290 assert_se(streq(b64
, "Zm9v"));
293 assert_se(base64mem("foob", STRLEN("foob"), &b64
) == 8);
294 assert_se(streq(b64
, "Zm9vYg=="));
297 assert_se(base64mem("fooba", STRLEN("fooba"), &b64
) == 8);
298 assert_se(streq(b64
, "Zm9vYmE="));
301 assert_se(base64mem("foobar", STRLEN("foobar"), &b64
) == 8);
302 assert_se(streq(b64
, "Zm9vYmFy"));
306 static void test_unbase64mem_one(const char *input
, const char *output
, int ret
) {
307 _cleanup_free_
void *buffer
= NULL
;
310 assert_se(unbase64mem(input
, (size_t) -1, &buffer
, &size
) == ret
);
313 assert_se(size
== strlen(output
));
314 assert_se(memcmp(buffer
, output
, size
) == 0);
315 assert_se(((char*) buffer
)[size
] == 0);
319 static void test_unbase64mem(void) {
321 test_unbase64mem_one("", "", 0);
322 test_unbase64mem_one("Zg==", "f", 0);
323 test_unbase64mem_one("Zm8=", "fo", 0);
324 test_unbase64mem_one("Zm9v", "foo", 0);
325 test_unbase64mem_one("Zm9vYg==", "foob", 0);
326 test_unbase64mem_one("Zm9vYmE=", "fooba", 0);
327 test_unbase64mem_one("Zm9vYmFy", "foobar", 0);
329 test_unbase64mem_one(" ", "", 0);
330 test_unbase64mem_one(" \n\r ", "", 0);
331 test_unbase64mem_one(" Zg\n== ", "f", 0);
332 test_unbase64mem_one(" Zm 8=\r", "fo", 0);
333 test_unbase64mem_one(" Zm9\n\r\r\nv ", "foo", 0);
334 test_unbase64mem_one(" Z m9vYg==\n\r", "foob", 0);
335 test_unbase64mem_one(" Zm 9vYmE= ", "fooba", 0);
336 test_unbase64mem_one(" Z m9v YmFy ", "foobar", 0);
338 test_unbase64mem_one("A", NULL
, -EPIPE
);
339 test_unbase64mem_one("A====", NULL
, -EINVAL
);
340 test_unbase64mem_one("AAB==", NULL
, -EINVAL
);
341 test_unbase64mem_one(" A A A B = ", NULL
, -EINVAL
);
342 test_unbase64mem_one(" Z m 8 = q u u x ", NULL
, -ENAMETOOLONG
);
345 static void test_hexdump(void) {
349 hexdump(stdout
, NULL
, 0);
350 hexdump(stdout
, "", 0);
351 hexdump(stdout
, "", 1);
352 hexdump(stdout
, "x", 1);
353 hexdump(stdout
, "x", 2);
354 hexdump(stdout
, "foobar", 7);
355 hexdump(stdout
, "f\nobar", 7);
356 hexdump(stdout
, "xxxxxxxxxxxxxxxxxxxxyz", 23);
358 for (i
= 0; i
< ELEMENTSOF(data
); i
++)
361 hexdump(stdout
, data
, sizeof(data
));
364 int main(int argc
, char *argv
[]) {
367 test_base32hexchar();
368 test_unbase32hexchar();
377 test_unbase32hexmem();