1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
// Copyright © Tavian Barnes <tavianator@tavianator.com>
// SPDX-License-Identifier: 0BSD
/**
* Unit tests.
*/
#ifndef BFS_TESTS_H
#define BFS_TESTS_H
#include "bfstd.h"
#include "diag.h"
/** Memory allocation tests. */
void check_alloc(void);
/** Standard library wrapper tests. */
void check_bfstd(void);
/** Bit manipulation tests. */
void check_bit(void);
/** I/O queue tests. */
void check_ioq(void);
/** Linked list tests. */
void check_list(void);
/** Signal hook tests. */
void check_sighook(void);
/** Trie tests. */
void check_trie(void);
/** Process spawning tests. */
void check_xspawn(void);
/** Time tests. */
void check_xtime(void);
/** Record a single check and return the result. */
bool bfs_check_impl(bool result);
/**
* Check a condition, logging a message on failure but continuing.
*/
#define bfs_check(...) \
bfs_check_(#__VA_ARGS__, __VA_ARGS__, "", )
#define bfs_check_(str, cond, format, ...) \
bfs_check_impl((cond) || (bfs_check__(format, BFS_DIAG_MSG_(format, str), __VA_ARGS__), false))
#define bfs_check__(format, ...) \
bfs_diagf(sizeof(format) > 1 \
? BFS_DIAG_FORMAT_("%s" format "%s") \
: BFS_DIAG_FORMAT_("Check failed: `%s`"), \
BFS_DIAG_ARGS_(__VA_ARGS__))
/**
* Check a condition, logging the current error string on failure.
*/
#define bfs_echeck(...) \
bfs_echeck_(#__VA_ARGS__, __VA_ARGS__, "", )
#define bfs_echeck_(str, cond, format, ...) \
bfs_check_impl((cond) || (bfs_echeck__(format, BFS_DIAG_MSG_(format, str), __VA_ARGS__), false))
#define bfs_echeck__(format, ...) \
bfs_diagf(sizeof(format) > 1 \
? BFS_DIAG_FORMAT_("%s" format "%s: %s") \
: BFS_DIAG_FORMAT_("Check failed: `%s`: %s"), \
BFS_DIAG_ARGS_(__VA_ARGS__ errstr(), ))
#endif // BFS_TESTS_H
|