chiark / gitweb /
757ebd629e9fbcef5369fe27301e36ebd76c558e
[elogind.git] / src / test / test-parse-util.c
1 /* SPDX-License-Identifier: LGPL-2.1+ */
2 /***
3   Copyright © 2013 Thomas H.P. Andersen
4 ***/
5
6 #include <errno.h>
7 #include <locale.h>
8 #include <math.h>
9 //#include <sys/socket.h>
10
11 #include "alloc-util.h"
12 #include "errno-list.h"
13 #include "log.h"
14 #include "parse-util.h"
15 #include "string-util.h"
16
17 static void test_parse_boolean(void) {
18         assert_se(parse_boolean("1") == 1);
19         assert_se(parse_boolean("y") == 1);
20         assert_se(parse_boolean("Y") == 1);
21         assert_se(parse_boolean("yes") == 1);
22         assert_se(parse_boolean("YES") == 1);
23         assert_se(parse_boolean("true") == 1);
24         assert_se(parse_boolean("TRUE") == 1);
25         assert_se(parse_boolean("on") == 1);
26         assert_se(parse_boolean("ON") == 1);
27
28         assert_se(parse_boolean("0") == 0);
29         assert_se(parse_boolean("n") == 0);
30         assert_se(parse_boolean("N") == 0);
31         assert_se(parse_boolean("no") == 0);
32         assert_se(parse_boolean("NO") == 0);
33         assert_se(parse_boolean("false") == 0);
34         assert_se(parse_boolean("FALSE") == 0);
35         assert_se(parse_boolean("off") == 0);
36         assert_se(parse_boolean("OFF") == 0);
37
38         assert_se(parse_boolean("garbage") < 0);
39         assert_se(parse_boolean("") < 0);
40         assert_se(parse_boolean("full") < 0);
41 }
42
43 static void test_parse_pid(void) {
44         int r;
45         pid_t pid;
46
47         r = parse_pid("100", &pid);
48         assert_se(r == 0);
49         assert_se(pid == 100);
50
51         r = parse_pid("0x7FFFFFFF", &pid);
52         assert_se(r == 0);
53         assert_se(pid == 2147483647);
54
55         pid = 65; /* pid is left unchanged on ERANGE. Set to known arbitrary value. */
56         r = parse_pid("0", &pid);
57         assert_se(r == -ERANGE);
58         assert_se(pid == 65);
59
60         pid = 65; /* pid is left unchanged on ERANGE. Set to known arbitrary value. */
61         r = parse_pid("-100", &pid);
62         assert_se(r == -ERANGE);
63         assert_se(pid == 65);
64
65         pid = 65; /* pid is left unchanged on ERANGE. Set to known arbitrary value. */
66         r = parse_pid("0xFFFFFFFFFFFFFFFFF", &pid);
67         assert_se(r == -ERANGE);
68         assert_se(pid == 65);
69
70         r = parse_pid("junk", &pid);
71         assert_se(r == -EINVAL);
72
73         r = parse_pid("", &pid);
74         assert_se(r == -EINVAL);
75 }
76
77 static void test_parse_mode(void) {
78         mode_t m;
79
80         assert_se(parse_mode("-1", &m) < 0);
81         assert_se(parse_mode("", &m) < 0);
82         assert_se(parse_mode("888", &m) < 0);
83         assert_se(parse_mode("77777", &m) < 0);
84
85         assert_se(parse_mode("544", &m) >= 0 && m == 0544);
86         assert_se(parse_mode("777", &m) >= 0 && m == 0777);
87         assert_se(parse_mode("7777", &m) >= 0 && m == 07777);
88         assert_se(parse_mode("0", &m) >= 0 && m == 0);
89 }
90
91 static void test_parse_size(void) {
92         uint64_t bytes;
93
94         assert_se(parse_size("", 1024, &bytes) == -EINVAL);
95
96         assert_se(parse_size("111", 1024, &bytes) == 0);
97         assert_se(bytes == 111);
98
99         assert_se(parse_size("111.4", 1024, &bytes) == 0);
100         assert_se(bytes == 111);
101
102         assert_se(parse_size(" 112 B", 1024, &bytes) == 0);
103         assert_se(bytes == 112);
104
105         assert_se(parse_size(" 112.6 B", 1024, &bytes) == 0);
106         assert_se(bytes == 112);
107
108         assert_se(parse_size("3.5 K", 1024, &bytes) == 0);
109         assert_se(bytes == 3*1024 + 512);
110
111         assert_se(parse_size("3. K", 1024, &bytes) == 0);
112         assert_se(bytes == 3*1024);
113
114         assert_se(parse_size("3.0 K", 1024, &bytes) == 0);
115         assert_se(bytes == 3*1024);
116
117         assert_se(parse_size("3. 0 K", 1024, &bytes) == -EINVAL);
118
119         assert_se(parse_size(" 4 M 11.5K", 1024, &bytes) == 0);
120         assert_se(bytes == 4*1024*1024 + 11 * 1024 + 512);
121
122         assert_se(parse_size("3B3.5G", 1024, &bytes) == -EINVAL);
123
124         assert_se(parse_size("3.5G3B", 1024, &bytes) == 0);
125         assert_se(bytes == 3ULL*1024*1024*1024 + 512*1024*1024 + 3);
126
127         assert_se(parse_size("3.5G 4B", 1024, &bytes) == 0);
128         assert_se(bytes == 3ULL*1024*1024*1024 + 512*1024*1024 + 4);
129
130         assert_se(parse_size("3B3G4T", 1024, &bytes) == -EINVAL);
131
132         assert_se(parse_size("4T3G3B", 1024, &bytes) == 0);
133         assert_se(bytes == (4ULL*1024 + 3)*1024*1024*1024 + 3);
134
135         assert_se(parse_size(" 4 T 3 G 3 B", 1024, &bytes) == 0);
136         assert_se(bytes == (4ULL*1024 + 3)*1024*1024*1024 + 3);
137
138         assert_se(parse_size("12P", 1024, &bytes) == 0);
139         assert_se(bytes == 12ULL * 1024*1024*1024*1024*1024);
140
141         assert_se(parse_size("12P12P", 1024, &bytes) == -EINVAL);
142
143         assert_se(parse_size("3E 2P", 1024, &bytes) == 0);
144         assert_se(bytes == (3 * 1024 + 2ULL) * 1024*1024*1024*1024*1024);
145
146         assert_se(parse_size("12X", 1024, &bytes) == -EINVAL);
147
148         assert_se(parse_size("12.5X", 1024, &bytes) == -EINVAL);
149
150         assert_se(parse_size("12.5e3", 1024, &bytes) == -EINVAL);
151
152         assert_se(parse_size("1024E", 1024, &bytes) == -ERANGE);
153         assert_se(parse_size("-1", 1024, &bytes) == -ERANGE);
154         assert_se(parse_size("-1024E", 1024, &bytes) == -ERANGE);
155
156         assert_se(parse_size("-1024P", 1024, &bytes) == -ERANGE);
157
158         assert_se(parse_size("-10B 20K", 1024, &bytes) == -ERANGE);
159 }
160
161 #if 0 /// UNNEEDED by elogind
162 static void test_parse_range(void) {
163         unsigned lower, upper;
164
165         /* Successful cases */
166         assert_se(parse_range("111", &lower, &upper) == 0);
167         assert_se(lower == 111);
168         assert_se(upper == 111);
169
170         assert_se(parse_range("111-123", &lower, &upper) == 0);
171         assert_se(lower == 111);
172         assert_se(upper == 123);
173
174         assert_se(parse_range("123-111", &lower, &upper) == 0);
175         assert_se(lower == 123);
176         assert_se(upper == 111);
177
178         assert_se(parse_range("123-123", &lower, &upper) == 0);
179         assert_se(lower == 123);
180         assert_se(upper == 123);
181
182         assert_se(parse_range("0", &lower, &upper) == 0);
183         assert_se(lower == 0);
184         assert_se(upper == 0);
185
186         assert_se(parse_range("0-15", &lower, &upper) == 0);
187         assert_se(lower == 0);
188         assert_se(upper == 15);
189
190         assert_se(parse_range("15-0", &lower, &upper) == 0);
191         assert_se(lower == 15);
192         assert_se(upper == 0);
193
194         assert_se(parse_range("128-65535", &lower, &upper) == 0);
195         assert_se(lower == 128);
196         assert_se(upper == 65535);
197
198         assert_se(parse_range("1024-4294967295", &lower, &upper) == 0);
199         assert_se(lower == 1024);
200         assert_se(upper == 4294967295);
201
202         /* Leading whitespace is acceptable */
203         assert_se(parse_range(" 111", &lower, &upper) == 0);
204         assert_se(lower == 111);
205         assert_se(upper == 111);
206
207         assert_se(parse_range(" 111-123", &lower, &upper) == 0);
208         assert_se(lower == 111);
209         assert_se(upper == 123);
210
211         assert_se(parse_range("111- 123", &lower, &upper) == 0);
212         assert_se(lower == 111);
213         assert_se(upper == 123);
214
215         assert_se(parse_range("\t111-\t123", &lower, &upper) == 0);
216         assert_se(lower == 111);
217         assert_se(upper == 123);
218
219         assert_se(parse_range(" \t 111- \t 123", &lower, &upper) == 0);
220         assert_se(lower == 111);
221         assert_se(upper == 123);
222
223         /* Error cases, make sure they fail as expected */
224         lower = upper = 9999;
225         assert_se(parse_range("111garbage", &lower, &upper) == -EINVAL);
226         assert_se(lower == 9999);
227         assert_se(upper == 9999);
228
229         assert_se(parse_range("garbage111", &lower, &upper) == -EINVAL);
230         assert_se(lower == 9999);
231         assert_se(upper == 9999);
232
233         assert_se(parse_range("garbage", &lower, &upper) == -EINVAL);
234         assert_se(lower == 9999);
235         assert_se(upper == 9999);
236
237         assert_se(parse_range("111-123garbage", &lower, &upper) == -EINVAL);
238         assert_se(lower == 9999);
239         assert_se(upper == 9999);
240
241         assert_se(parse_range("111garbage-123", &lower, &upper) == -EINVAL);
242         assert_se(lower == 9999);
243         assert_se(upper == 9999);
244
245         /* Empty string */
246         lower = upper = 9999;
247         assert_se(parse_range("", &lower, &upper) == -EINVAL);
248         assert_se(lower == 9999);
249         assert_se(upper == 9999);
250
251         /* 111--123 will pass -123 to safe_atou which returns -ERANGE for negative */
252         assert_se(parse_range("111--123", &lower, &upper) == -ERANGE);
253         assert_se(lower == 9999);
254         assert_se(upper == 9999);
255
256         assert_se(parse_range("-123", &lower, &upper) == -EINVAL);
257         assert_se(lower == 9999);
258         assert_se(upper == 9999);
259
260         assert_se(parse_range("-111-123", &lower, &upper) == -EINVAL);
261         assert_se(lower == 9999);
262         assert_se(upper == 9999);
263
264         assert_se(parse_range("111-123-", &lower, &upper) == -EINVAL);
265         assert_se(lower == 9999);
266         assert_se(upper == 9999);
267
268         assert_se(parse_range("111.4-123", &lower, &upper) == -EINVAL);
269         assert_se(lower == 9999);
270         assert_se(upper == 9999);
271
272         assert_se(parse_range("111-123.4", &lower, &upper) == -EINVAL);
273         assert_se(lower == 9999);
274         assert_se(upper == 9999);
275
276         assert_se(parse_range("111,4-123", &lower, &upper) == -EINVAL);
277         assert_se(lower == 9999);
278         assert_se(upper == 9999);
279
280         assert_se(parse_range("111-123,4", &lower, &upper) == -EINVAL);
281         assert_se(lower == 9999);
282         assert_se(upper == 9999);
283
284         /* Error on trailing dash */
285         assert_se(parse_range("111-", &lower, &upper) == -EINVAL);
286         assert_se(lower == 9999);
287         assert_se(upper == 9999);
288
289         assert_se(parse_range("111-123-", &lower, &upper) == -EINVAL);
290         assert_se(lower == 9999);
291         assert_se(upper == 9999);
292
293         assert_se(parse_range("111--", &lower, &upper) == -EINVAL);
294         assert_se(lower == 9999);
295         assert_se(upper == 9999);
296
297         assert_se(parse_range("111- ", &lower, &upper) == -EINVAL);
298         assert_se(lower == 9999);
299         assert_se(upper == 9999);
300
301         /* Whitespace is not a separator */
302         assert_se(parse_range("111 123", &lower, &upper) == -EINVAL);
303         assert_se(lower == 9999);
304         assert_se(upper == 9999);
305
306         assert_se(parse_range("111\t123", &lower, &upper) == -EINVAL);
307         assert_se(lower == 9999);
308         assert_se(upper == 9999);
309
310         assert_se(parse_range("111 \t 123", &lower, &upper) == -EINVAL);
311         assert_se(lower == 9999);
312         assert_se(upper == 9999);
313
314         /* Trailing whitespace is invalid (from safe_atou) */
315         assert_se(parse_range("111 ", &lower, &upper) == -EINVAL);
316         assert_se(lower == 9999);
317         assert_se(upper == 9999);
318
319         assert_se(parse_range("111-123 ", &lower, &upper) == -EINVAL);
320         assert_se(lower == 9999);
321         assert_se(upper == 9999);
322
323         assert_se(parse_range("111 -123", &lower, &upper) == -EINVAL);
324         assert_se(lower == 9999);
325         assert_se(upper == 9999);
326
327         assert_se(parse_range("111 -123 ", &lower, &upper) == -EINVAL);
328         assert_se(lower == 9999);
329         assert_se(upper == 9999);
330
331         assert_se(parse_range("111\t-123\t", &lower, &upper) == -EINVAL);
332         assert_se(lower == 9999);
333         assert_se(upper == 9999);
334
335         assert_se(parse_range("111 \t -123 \t ", &lower, &upper) == -EINVAL);
336         assert_se(lower == 9999);
337         assert_se(upper == 9999);
338
339         /* Out of the "unsigned" range, this is 1<<64 */
340         assert_se(parse_range("0-18446744073709551616", &lower, &upper) == -ERANGE);
341         assert_se(lower == 9999);
342         assert_se(upper == 9999);
343 }
344 #endif // 0
345
346 static void test_safe_atolli(void) {
347         int r;
348         long long l;
349
350         r = safe_atolli("12345", &l);
351         assert_se(r == 0);
352         assert_se(l == 12345);
353
354         r = safe_atolli("  12345", &l);
355         assert_se(r == 0);
356         assert_se(l == 12345);
357
358         r = safe_atolli("-12345", &l);
359         assert_se(r == 0);
360         assert_se(l == -12345);
361
362         r = safe_atolli("  -12345", &l);
363         assert_se(r == 0);
364         assert_se(l == -12345);
365
366         r = safe_atolli("12345678901234567890", &l);
367         assert_se(r == -ERANGE);
368
369         r = safe_atolli("-12345678901234567890", &l);
370         assert_se(r == -ERANGE);
371
372         r = safe_atolli("junk", &l);
373         assert_se(r == -EINVAL);
374
375         r = safe_atolli("123x", &l);
376         assert_se(r == -EINVAL);
377
378         r = safe_atolli("12.3", &l);
379         assert_se(r == -EINVAL);
380
381         r = safe_atolli("", &l);
382         assert_se(r == -EINVAL);
383 }
384
385 static void test_safe_atou16(void) {
386         int r;
387         uint16_t l;
388
389         r = safe_atou16("12345", &l);
390         assert_se(r == 0);
391         assert_se(l == 12345);
392
393         r = safe_atou16("  12345", &l);
394         assert_se(r == 0);
395         assert_se(l == 12345);
396
397         r = safe_atou16("123456", &l);
398         assert_se(r == -ERANGE);
399
400         r = safe_atou16("-1", &l);
401         assert_se(r == -ERANGE);
402
403         r = safe_atou16("  -1", &l);
404         assert_se(r == -ERANGE);
405
406         r = safe_atou16("junk", &l);
407         assert_se(r == -EINVAL);
408
409         r = safe_atou16("123x", &l);
410         assert_se(r == -EINVAL);
411
412         r = safe_atou16("12.3", &l);
413         assert_se(r == -EINVAL);
414
415         r = safe_atou16("", &l);
416         assert_se(r == -EINVAL);
417 }
418
419 static void test_safe_atoi16(void) {
420         int r;
421         int16_t l;
422
423         r = safe_atoi16("-12345", &l);
424         assert_se(r == 0);
425         assert_se(l == -12345);
426
427         r = safe_atoi16("  -12345", &l);
428         assert_se(r == 0);
429         assert_se(l == -12345);
430
431         r = safe_atoi16("32767", &l);
432         assert_se(r == 0);
433         assert_se(l == 32767);
434
435         r = safe_atoi16("  32767", &l);
436         assert_se(r == 0);
437         assert_se(l == 32767);
438
439         r = safe_atoi16("36536", &l);
440         assert_se(r == -ERANGE);
441
442         r = safe_atoi16("-32769", &l);
443         assert_se(r == -ERANGE);
444
445         r = safe_atoi16("junk", &l);
446         assert_se(r == -EINVAL);
447
448         r = safe_atoi16("123x", &l);
449         assert_se(r == -EINVAL);
450
451         r = safe_atoi16("12.3", &l);
452         assert_se(r == -EINVAL);
453
454         r = safe_atoi16("", &l);
455         assert_se(r == -EINVAL);
456 }
457
458 static void test_safe_atoux16(void) {
459         int r;
460         uint16_t l;
461
462         r = safe_atoux16("1234", &l);
463         assert_se(r == 0);
464         assert_se(l == 0x1234);
465
466         r = safe_atoux16("abcd", &l);
467         assert_se(r == 0);
468         assert_se(l == 0xabcd);
469
470         r = safe_atoux16("  1234", &l);
471         assert_se(r == 0);
472         assert_se(l == 0x1234);
473
474         r = safe_atoux16("12345", &l);
475         assert_se(r == -ERANGE);
476
477         r = safe_atoux16("-1", &l);
478         assert_se(r == -ERANGE);
479
480         r = safe_atoux16("  -1", &l);
481         assert_se(r == -ERANGE);
482
483         r = safe_atoux16("junk", &l);
484         assert_se(r == -EINVAL);
485
486         r = safe_atoux16("123x", &l);
487         assert_se(r == -EINVAL);
488
489         r = safe_atoux16("12.3", &l);
490         assert_se(r == -EINVAL);
491
492         r = safe_atoux16("", &l);
493         assert_se(r == -EINVAL);
494 }
495
496 static void test_safe_atou64(void) {
497         int r;
498         uint64_t l;
499
500         r = safe_atou64("12345", &l);
501         assert_se(r == 0);
502         assert_se(l == 12345);
503
504         r = safe_atou64("  12345", &l);
505         assert_se(r == 0);
506         assert_se(l == 12345);
507
508         r = safe_atou64("18446744073709551617", &l);
509         assert_se(r == -ERANGE);
510
511         r = safe_atou64("-1", &l);
512         assert_se(r == -ERANGE);
513
514         r = safe_atou64("  -1", &l);
515         assert_se(r == -ERANGE);
516
517         r = safe_atou64("junk", &l);
518         assert_se(r == -EINVAL);
519
520         r = safe_atou64("123x", &l);
521         assert_se(r == -EINVAL);
522
523         r = safe_atou64("12.3", &l);
524         assert_se(r == -EINVAL);
525
526         r = safe_atou64("", &l);
527         assert_se(r == -EINVAL);
528 }
529
530 static void test_safe_atoi64(void) {
531         int r;
532         int64_t l;
533
534         r = safe_atoi64("-12345", &l);
535         assert_se(r == 0);
536         assert_se(l == -12345);
537
538         r = safe_atoi64("  -12345", &l);
539         assert_se(r == 0);
540         assert_se(l == -12345);
541
542         r = safe_atoi64("32767", &l);
543         assert_se(r == 0);
544         assert_se(l == 32767);
545
546         r = safe_atoi64("  32767", &l);
547         assert_se(r == 0);
548         assert_se(l == 32767);
549
550         r = safe_atoi64("9223372036854775813", &l);
551         assert_se(r == -ERANGE);
552
553         r = safe_atoi64("-9223372036854775813", &l);
554         assert_se(r == -ERANGE);
555
556         r = safe_atoi64("junk", &l);
557         assert_se(r == -EINVAL);
558
559         r = safe_atoi64("123x", &l);
560         assert_se(r == -EINVAL);
561
562         r = safe_atoi64("12.3", &l);
563         assert_se(r == -EINVAL);
564
565         r = safe_atoi64("", &l);
566         assert_se(r == -EINVAL);
567 }
568
569 static void test_safe_atod(void) {
570         int r;
571         double d;
572         char *e;
573
574         r = safe_atod("junk", &d);
575         assert_se(r == -EINVAL);
576
577         r = safe_atod("0.2244", &d);
578         assert_se(r == 0);
579         assert_se(fabs(d - 0.2244) < 0.000001);
580
581         r = safe_atod("0,5", &d);
582         assert_se(r == -EINVAL);
583
584         errno = 0;
585         strtod("0,5", &e);
586         assert_se(*e == ',');
587
588         r = safe_atod("", &d);
589         assert_se(r == -EINVAL);
590
591         /* Check if this really is locale independent */
592         if (setlocale(LC_NUMERIC, "de_DE.utf8")) {
593
594                 r = safe_atod("0.2244", &d);
595                 assert_se(r == 0);
596                 assert_se(fabs(d - 0.2244) < 0.000001);
597
598                 r = safe_atod("0,5", &d);
599                 assert_se(r == -EINVAL);
600
601                 errno = 0;
602 /// elogind supports musl_libc, and their strtod doesn't seem to use the set locale.
603 #if defined(__GLIBC__)
604                 assert_se(fabs(strtod("0,5", &e) - 0.5) < 0.00001);
605 #endif // __GLIBC__
606
607                 r = safe_atod("", &d);
608                 assert_se(r == -EINVAL);
609         }
610
611         /* And check again, reset */
612         assert_se(setlocale(LC_NUMERIC, "C"));
613
614         r = safe_atod("0.2244", &d);
615         assert_se(r == 0);
616         assert_se(fabs(d - 0.2244) < 0.000001);
617
618         r = safe_atod("0,5", &d);
619         assert_se(r == -EINVAL);
620
621         errno = 0;
622         strtod("0,5", &e);
623         assert_se(*e == ',');
624
625         r = safe_atod("", &d);
626         assert_se(r == -EINVAL);
627 }
628
629 static void test_parse_percent(void) {
630         assert_se(parse_percent("") == -EINVAL);
631         assert_se(parse_percent("foo") == -EINVAL);
632         assert_se(parse_percent("0") == -EINVAL);
633         assert_se(parse_percent("50") == -EINVAL);
634         assert_se(parse_percent("100") == -EINVAL);
635         assert_se(parse_percent("-1") == -EINVAL);
636         assert_se(parse_percent("0%") == 0);
637         assert_se(parse_percent("55%") == 55);
638         assert_se(parse_percent("100%") == 100);
639         assert_se(parse_percent("-7%") == -ERANGE);
640         assert_se(parse_percent("107%") == -ERANGE);
641         assert_se(parse_percent("%") == -EINVAL);
642         assert_se(parse_percent("%%") == -EINVAL);
643         assert_se(parse_percent("%1") == -EINVAL);
644         assert_se(parse_percent("1%%") == -EINVAL);
645         assert_se(parse_percent("3.2%") == -EINVAL);
646 }
647
648 static void test_parse_percent_unbounded(void) {
649         assert_se(parse_percent_unbounded("101%") == 101);
650         assert_se(parse_percent_unbounded("400%") == 400);
651 }
652
653 static void test_parse_permille(void) {
654         assert_se(parse_permille("") == -EINVAL);
655         assert_se(parse_permille("foo") == -EINVAL);
656         assert_se(parse_permille("0") == -EINVAL);
657         assert_se(parse_permille("50") == -EINVAL);
658         assert_se(parse_permille("100") == -EINVAL);
659         assert_se(parse_permille("-1") == -EINVAL);
660
661         assert_se(parse_permille("0‰") == 0);
662         assert_se(parse_permille("555‰") == 555);
663         assert_se(parse_permille("1000‰") == 1000);
664         assert_se(parse_permille("-7‰") == -ERANGE);
665         assert_se(parse_permille("1007‰") == -ERANGE);
666         assert_se(parse_permille("‰") == -EINVAL);
667         assert_se(parse_permille("‰‰") == -EINVAL);
668         assert_se(parse_permille("‰1") == -EINVAL);
669         assert_se(parse_permille("1‰‰") == -EINVAL);
670         assert_se(parse_permille("3.2‰") == -EINVAL);
671
672         assert_se(parse_permille("0%") == 0);
673         assert_se(parse_permille("55%") == 550);
674         assert_se(parse_permille("55.5%") == 555);
675         assert_se(parse_permille("100%") == 1000);
676         assert_se(parse_permille("-7%") == -ERANGE);
677         assert_se(parse_permille("107%") == -ERANGE);
678         assert_se(parse_permille("%") == -EINVAL);
679         assert_se(parse_permille("%%") == -EINVAL);
680         assert_se(parse_permille("%1") == -EINVAL);
681         assert_se(parse_permille("1%%") == -EINVAL);
682         assert_se(parse_permille("3.21%") == -EINVAL);
683 }
684
685 static void test_parse_permille_unbounded(void) {
686         assert_se(parse_permille_unbounded("1001‰") == 1001);
687         assert_se(parse_permille_unbounded("4000‰") == 4000);
688         assert_se(parse_permille_unbounded("2147483647‰") == 2147483647);
689         assert_se(parse_permille_unbounded("2147483648‰") == -ERANGE);
690         assert_se(parse_permille_unbounded("4294967295‰") == -ERANGE);
691         assert_se(parse_permille_unbounded("4294967296‰") == -ERANGE);
692
693         assert_se(parse_permille_unbounded("101%") == 1010);
694         assert_se(parse_permille_unbounded("400%") == 4000);
695         assert_se(parse_permille_unbounded("214748364.7%") == 2147483647);
696         assert_se(parse_permille_unbounded("214748364.8%") == -ERANGE);
697         assert_se(parse_permille_unbounded("429496729.5%") == -ERANGE);
698         assert_se(parse_permille_unbounded("429496729.6%") == -ERANGE);
699 }
700
701 #if 0 /// UNNEEDED by elogind
702 static void test_parse_nice(void) {
703         int n;
704
705         assert_se(parse_nice("0", &n) >= 0 && n == 0);
706         assert_se(parse_nice("+0", &n) >= 0 && n == 0);
707         assert_se(parse_nice("-1", &n) >= 0 && n == -1);
708         assert_se(parse_nice("-2", &n) >= 0 && n == -2);
709         assert_se(parse_nice("1", &n) >= 0 && n == 1);
710         assert_se(parse_nice("2", &n) >= 0 && n == 2);
711         assert_se(parse_nice("+1", &n) >= 0 && n == 1);
712         assert_se(parse_nice("+2", &n) >= 0 && n == 2);
713         assert_se(parse_nice("-20", &n) >= 0 && n == -20);
714         assert_se(parse_nice("19", &n) >= 0 && n == 19);
715         assert_se(parse_nice("+19", &n) >= 0 && n == 19);
716
717         assert_se(parse_nice("", &n) == -EINVAL);
718         assert_se(parse_nice("-", &n) == -EINVAL);
719         assert_se(parse_nice("+", &n) == -EINVAL);
720         assert_se(parse_nice("xx", &n) == -EINVAL);
721         assert_se(parse_nice("-50", &n) == -ERANGE);
722         assert_se(parse_nice("50", &n) == -ERANGE);
723         assert_se(parse_nice("+50", &n) == -ERANGE);
724         assert_se(parse_nice("-21", &n) == -ERANGE);
725         assert_se(parse_nice("20", &n) == -ERANGE);
726         assert_se(parse_nice("+20", &n) == -ERANGE);
727 }
728 #endif // 0
729
730 static void test_parse_dev(void) {
731         dev_t dev;
732
733         assert_se(parse_dev("", &dev) == -EINVAL);
734         assert_se(parse_dev("junk", &dev) == -EINVAL);
735         assert_se(parse_dev("0", &dev) == -EINVAL);
736         assert_se(parse_dev("5", &dev) == -EINVAL);
737         assert_se(parse_dev("5:", &dev) == -EINVAL);
738         assert_se(parse_dev(":5", &dev) == -EINVAL);
739 #if SIZEOF_DEV_T < 8
740         assert_se(parse_dev("4294967295:4294967295", &dev) == -EINVAL);
741 #endif
742         assert_se(parse_dev("8:11", &dev) >= 0 && major(dev) == 8 && minor(dev) == 11);
743 }
744
745 static void test_parse_errno(void) {
746         assert_se(parse_errno("EILSEQ") == EILSEQ);
747         assert_se(parse_errno("EINVAL") == EINVAL);
748         assert_se(parse_errno("0") == 0);
749         assert_se(parse_errno("1") == 1);
750         assert_se(parse_errno("4095") == 4095);
751
752         assert_se(parse_errno("-1") == -ERANGE);
753         assert_se(parse_errno("-3") == -ERANGE);
754         assert_se(parse_errno("4096") == -ERANGE);
755
756         assert_se(parse_errno("") == -EINVAL);
757         assert_se(parse_errno("12.3") == -EINVAL);
758         assert_se(parse_errno("123junk") == -EINVAL);
759         assert_se(parse_errno("junk123") == -EINVAL);
760         assert_se(parse_errno("255EILSEQ") == -EINVAL);
761         assert_se(parse_errno("EINVAL12") == -EINVAL);
762         assert_se(parse_errno("-EINVAL") == -EINVAL);
763         assert_se(parse_errno("EINVALaaa") == -EINVAL);
764 }
765
766 static void test_parse_syscall_and_errno(void) {
767         _cleanup_free_ char *n = NULL;
768         int e;
769
770         assert_se(parse_syscall_and_errno("uname:EILSEQ", &n, &e) >= 0);
771         assert_se(streq(n, "uname"));
772         assert_se(e == errno_from_name("EILSEQ") && e >= 0);
773         n = mfree(n);
774
775         assert_se(parse_syscall_and_errno("uname:EINVAL", &n, &e) >= 0);
776         assert_se(streq(n, "uname"));
777         assert_se(e == errno_from_name("EINVAL") && e >= 0);
778         n = mfree(n);
779
780         assert_se(parse_syscall_and_errno("@sync:4095", &n, &e) >= 0);
781         assert_se(streq(n, "@sync"));
782         assert_se(e == 4095);
783         n = mfree(n);
784
785         /* If errno is omitted, then e is set to -1 */
786         assert_se(parse_syscall_and_errno("mount", &n, &e) >= 0);
787         assert_se(streq(n, "mount"));
788         assert_se(e == -1);
789         n = mfree(n);
790
791         /* parse_syscall_and_errno() does not check the syscall name is valid or not. */
792         assert_se(parse_syscall_and_errno("hoge:255", &n, &e) >= 0);
793         assert_se(streq(n, "hoge"));
794         assert_se(e == 255);
795         n = mfree(n);
796
797         /* The function checks the syscall name is empty or not. */
798         assert_se(parse_syscall_and_errno("", &n, &e) == -EINVAL);
799         assert_se(parse_syscall_and_errno(":255", &n, &e) == -EINVAL);
800
801         /* errno must be a valid errno name or number between 0 and ERRNO_MAX == 4095 */
802         assert_se(parse_syscall_and_errno("hoge:4096", &n, &e) == -ERANGE);
803         assert_se(parse_syscall_and_errno("hoge:-3", &n, &e) == -ERANGE);
804         assert_se(parse_syscall_and_errno("hoge:12.3", &n, &e) == -EINVAL);
805         assert_se(parse_syscall_and_errno("hoge:123junk", &n, &e) == -EINVAL);
806         assert_se(parse_syscall_and_errno("hoge:junk123", &n, &e) == -EINVAL);
807         assert_se(parse_syscall_and_errno("hoge:255:EILSEQ", &n, &e) == -EINVAL);
808         assert_se(parse_syscall_and_errno("hoge:-EINVAL", &n, &e) == -EINVAL);
809         assert_se(parse_syscall_and_errno("hoge:EINVALaaa", &n, &e) == -EINVAL);
810         assert_se(parse_syscall_and_errno("hoge:", &n, &e) == -EINVAL);
811 }
812
813 static void test_parse_mtu(void) {
814         uint32_t mtu = 0;
815
816         assert_se(parse_mtu(AF_UNSPEC, "1500", &mtu) >= 0 && mtu == 1500);
817         assert_se(parse_mtu(AF_UNSPEC, "1400", &mtu) >= 0 && mtu == 1400);
818         assert_se(parse_mtu(AF_UNSPEC, "65535", &mtu) >= 0 && mtu == 65535);
819         assert_se(parse_mtu(AF_UNSPEC, "65536", &mtu) >= 0 && mtu == 65536);
820         assert_se(parse_mtu(AF_UNSPEC, "4294967295", &mtu) >= 0 && mtu == 4294967295);
821         assert_se(parse_mtu(AF_UNSPEC, "500", &mtu) >= 0 && mtu == 500);
822         assert_se(parse_mtu(AF_UNSPEC, "1280", &mtu) >= 0 && mtu == 1280);
823         assert_se(parse_mtu(AF_INET6, "1280", &mtu) >= 0 && mtu == 1280);
824         assert_se(parse_mtu(AF_INET6, "1279", &mtu) == -ERANGE);
825         assert_se(parse_mtu(AF_UNSPEC, "4294967296", &mtu) == -ERANGE);
826         assert_se(parse_mtu(AF_INET6, "4294967296", &mtu) == -ERANGE);
827         assert_se(parse_mtu(AF_INET6, "68", &mtu) == -ERANGE);
828         assert_se(parse_mtu(AF_UNSPEC, "68", &mtu) >= 0 && mtu == 68);
829         assert_se(parse_mtu(AF_UNSPEC, "67", &mtu) == -ERANGE);
830         assert_se(parse_mtu(AF_UNSPEC, "0", &mtu) == -ERANGE);
831         assert_se(parse_mtu(AF_UNSPEC, "", &mtu) == -EINVAL);
832 }
833
834 int main(int argc, char *argv[]) {
835         log_parse_environment();
836         log_open();
837
838         test_parse_boolean();
839         test_parse_pid();
840         test_parse_mode();
841         test_parse_size();
842 #if 0 /// UNNEEDED by elogind
843         test_parse_range();
844 #endif // 0
845         test_safe_atolli();
846         test_safe_atou16();
847         test_safe_atoi16();
848         test_safe_atoux16();
849         test_safe_atou64();
850         test_safe_atoi64();
851         test_safe_atod();
852         test_parse_percent();
853         test_parse_percent_unbounded();
854         test_parse_permille();
855         test_parse_permille_unbounded();
856 #if 0 /// UNNEEDED by elogind
857         test_parse_nice();
858 #endif // 0
859         test_parse_dev();
860         test_parse_errno();
861         test_parse_syscall_and_errno();
862         test_parse_mtu();
863
864         return 0;
865 }