xref: /xnu-11215.1.10/tests/test_strings.c (revision 8d741a5de7ff4191bf97d57b9f54c2f6d4a15585)
1*8d741a5dSApple OSS Distributions #define _FORTIFY_SOURCE 0
2*8d741a5dSApple OSS Distributions #define __arch_memcmp_zero_ptr_aligned
3*8d741a5dSApple OSS Distributions 
4*8d741a5dSApple OSS Distributions /* must include first because otherwise header guard conflicts with SDK's
5*8d741a5dSApple OSS Distributions  * string.h (quite reasonably)
6*8d741a5dSApple OSS Distributions  */
7*8d741a5dSApple OSS Distributions #include "../osfmk/libsa/string.h"
8*8d741a5dSApple OSS Distributions 
9*8d741a5dSApple OSS Distributions char *strerror(int);
10*8d741a5dSApple OSS Distributions char *itoa(int, char *);
11*8d741a5dSApple OSS Distributions 
12*8d741a5dSApple OSS Distributions #include <darwintest.h>
13*8d741a5dSApple OSS Distributions #include <darwintest_utils.h>
14*8d741a5dSApple OSS Distributions 
15*8d741a5dSApple OSS Distributions #pragma clang diagnostic ignored "-Wlanguage-extension-token"
16*8d741a5dSApple OSS Distributions #pragma clang diagnostic ignored "-Wformat-pedantic"
17*8d741a5dSApple OSS Distributions 
18*8d741a5dSApple OSS Distributions #define DEVELOPMENT 0
19*8d741a5dSApple OSS Distributions #define DEBUG 0
20*8d741a5dSApple OSS Distributions #define XNU_KERNEL_PRIVATE 1
21*8d741a5dSApple OSS Distributions 
22*8d741a5dSApple OSS Distributions __printflike(1, 2) __attribute__((noreturn))
23*8d741a5dSApple OSS Distributions static void
panic(const char * fmt,...)24*8d741a5dSApple OSS Distributions panic(const char *fmt, ...)
25*8d741a5dSApple OSS Distributions {
26*8d741a5dSApple OSS Distributions 	va_list ap;
27*8d741a5dSApple OSS Distributions 	va_start(ap, fmt);
28*8d741a5dSApple OSS Distributions 	vfprintf(stderr, fmt, ap);
29*8d741a5dSApple OSS Distributions 	abort();
30*8d741a5dSApple OSS Distributions }
31*8d741a5dSApple OSS Distributions 
32*8d741a5dSApple OSS Distributions #include "../libkern/libkern/section_keywords.h"
33*8d741a5dSApple OSS Distributions #include "../osfmk/machine/string.h"
34*8d741a5dSApple OSS Distributions #include "../osfmk/device/subrs.c"
35*8d741a5dSApple OSS Distributions 
36*8d741a5dSApple OSS Distributions #pragma clang diagnostic ignored "-Wdeclaration-after-statement"
37*8d741a5dSApple OSS Distributions #pragma clang diagnostic ignored "-Wgnu-designator"
38*8d741a5dSApple OSS Distributions 
39*8d741a5dSApple OSS Distributions T_GLOBAL_META(
40*8d741a5dSApple OSS Distributions 	T_META_RUN_CONCURRENTLY(true),
41*8d741a5dSApple OSS Distributions 	T_META_TAG_VM_PREFERRED);
42*8d741a5dSApple OSS Distributions 
43*8d741a5dSApple OSS Distributions T_DECL(strbufcmp, "strbufcmp") {
44*8d741a5dSApple OSS Distributions #define T_COMPARE(A, AS, B, BS, EQ) T_ASSERT_EQ(strbufcmp_impl((A), (AS), (B), (BS)), (EQ), "compare '%s'.%zu, '%s'.%zu", (A), (AS), (B), (BS))
45*8d741a5dSApple OSS Distributions 	// two identical strings
46*8d741a5dSApple OSS Distributions 	char a[] = "hello";
47*8d741a5dSApple OSS Distributions 	char b[] = "hello";
48*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, sizeof(b), 0);
49*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, sizeof(a), 0);
50*8d741a5dSApple OSS Distributions 
51*8d741a5dSApple OSS Distributions 	// the same string
52*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, sizeof(b), 0);
53*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, sizeof(a), 0);
54*8d741a5dSApple OSS Distributions 
55*8d741a5dSApple OSS Distributions 	// two different strings
56*8d741a5dSApple OSS Distributions 	char c[] = "world";
57*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), c, sizeof(c), a[0] - c[0]);
58*8d741a5dSApple OSS Distributions 	T_COMPARE(c, sizeof(c), a, sizeof(a), c[0] - a[0]);
59*8d741a5dSApple OSS Distributions 	char d[] = "hellp";
60*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), d, sizeof(d), 'o' - 'p');
61*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d), a, sizeof(a), 'p' - 'o');
62*8d741a5dSApple OSS Distributions 
63*8d741a5dSApple OSS Distributions 	// strings of different size
64*8d741a5dSApple OSS Distributions 	char e[] = "aaaa";
65*8d741a5dSApple OSS Distributions 	char f[] = "aaaab";
66*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e), f, sizeof(f), 0 - 'b');
67*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f), e, sizeof(e), 'b' - 0);
68*8d741a5dSApple OSS Distributions 
69*8d741a5dSApple OSS Distributions 	// strings that are not NUL-terminated
70*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, b, sizeof(b) - 1, 0);
71*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b) - 1, a, sizeof(a) - 1, 0);
72*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, d, sizeof(d) - 1, 'o' - 'p');
73*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d) - 1, a, sizeof(a) - 1, 'p' - 'o');
74*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e) - 1, f, sizeof(f) - 1, 0 - 'b');
75*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f) - 1, e, sizeof(e) - 1, 'b' - 0);
76*8d741a5dSApple OSS Distributions #undef T_COMPARE
77*8d741a5dSApple OSS Distributions }
78*8d741a5dSApple OSS Distributions 
79*8d741a5dSApple OSS Distributions T_DECL(strlcmp, "strlcmp") {
80*8d741a5dSApple OSS Distributions #define T_COMPARE(A, AS, B, EQ) T_ASSERT_EQ(strlcmp_impl((A), (B), (AS)), (EQ), "compare '%s'.%zu, '%s'", (A), (AS), (B))
81*8d741a5dSApple OSS Distributions 	// two identical strings
82*8d741a5dSApple OSS Distributions 	char a[] = "hello";
83*8d741a5dSApple OSS Distributions 	char b[] = "hello";
84*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, 0);
85*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, 0);
86*8d741a5dSApple OSS Distributions 
87*8d741a5dSApple OSS Distributions 	// the same string
88*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, 0);
89*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, 0);
90*8d741a5dSApple OSS Distributions 
91*8d741a5dSApple OSS Distributions 	// two different strings
92*8d741a5dSApple OSS Distributions 	char c[] = "world";
93*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), c, a[0] - c[0]);
94*8d741a5dSApple OSS Distributions 	T_COMPARE(c, sizeof(c), a, c[0] - a[0]);
95*8d741a5dSApple OSS Distributions 	char d[] = "hellp";
96*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), d, 'o' - 'p');
97*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d), a, 'p' - 'o');
98*8d741a5dSApple OSS Distributions 
99*8d741a5dSApple OSS Distributions 	// strings of different size
100*8d741a5dSApple OSS Distributions 	char e[] = "aaaa";
101*8d741a5dSApple OSS Distributions 	char f[] = "aaaab";
102*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e), f, 0 - 'b');
103*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f), e, 'b' - 0);
104*8d741a5dSApple OSS Distributions 
105*8d741a5dSApple OSS Distributions 	// strings that are not NUL-terminated
106*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, b, 0);
107*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b) - 1, a, 0);
108*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, d, 'o' - 'p');
109*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d) - 1, a, 'p' - 'o');
110*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e) - 1, f, 0 - 'b');
111*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f) - 1, e, 'b' - 0);
112*8d741a5dSApple OSS Distributions #undef T_COMPARE
113*8d741a5dSApple OSS Distributions }
114*8d741a5dSApple OSS Distributions 
115*8d741a5dSApple OSS Distributions T_DECL(strbufcasecmp, "strbufcasecmp") {
116*8d741a5dSApple OSS Distributions #define T_COMPARE(A, AS, B, BS, EQ) T_ASSERT_EQ(strbufcasecmp_impl((A), (AS), (B), (BS)), (EQ), "case-insensitive compare '%s'.%zu, '%s'.%zu", (A), (AS), (B), (BS))
117*8d741a5dSApple OSS Distributions 	// same tests as strcasecmp, then tests with individual characters
118*8d741a5dSApple OSS Distributions 	// two identical strings
119*8d741a5dSApple OSS Distributions 	char a[] = "hElLo";
120*8d741a5dSApple OSS Distributions 	char b[] = "HeLlO";
121*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, sizeof(b), 0);
122*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, sizeof(a), 0);
123*8d741a5dSApple OSS Distributions 
124*8d741a5dSApple OSS Distributions 	// the same string
125*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, sizeof(b), 0);
126*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, sizeof(a), 0);
127*8d741a5dSApple OSS Distributions 
128*8d741a5dSApple OSS Distributions 	// two different strings
129*8d741a5dSApple OSS Distributions 	char c[] = "world";
130*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), c, sizeof(c), a[0] - c[0]);
131*8d741a5dSApple OSS Distributions 	T_COMPARE(c, sizeof(c), a, sizeof(a), c[0] - a[0]);
132*8d741a5dSApple OSS Distributions 	char d[] = "hellp";
133*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), d, sizeof(d), 'o' - 'p');
134*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d), a, sizeof(a), 'p' - 'o');
135*8d741a5dSApple OSS Distributions 
136*8d741a5dSApple OSS Distributions 	// strings of different size
137*8d741a5dSApple OSS Distributions 	char e[] = "aAaA";
138*8d741a5dSApple OSS Distributions 	char f[] = "AaAaB";
139*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e), f, sizeof(f), 0 - 'b');
140*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f), e, sizeof(e), 'b' - 0);
141*8d741a5dSApple OSS Distributions 
142*8d741a5dSApple OSS Distributions 	// strings that are not NUL-terminated
143*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, b, sizeof(b) - 1, 0);
144*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b) - 1, a, sizeof(a) - 1, 0);
145*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, d, sizeof(d) - 1, 'o' - 'p');
146*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d) - 1, a, sizeof(a) - 1, 'p' - 'o');
147*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e) - 1, f, sizeof(f) - 1, 0 - 'b');
148*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f) - 1, e, sizeof(e) - 1, 'b' - 0);
149*8d741a5dSApple OSS Distributions #undef T_COMPARE
150*8d741a5dSApple OSS Distributions }
151*8d741a5dSApple OSS Distributions 
152*8d741a5dSApple OSS Distributions T_DECL(strlcasecmp, "strlcasecmp") {
153*8d741a5dSApple OSS Distributions #define T_COMPARE(A, AS, B, EQ) T_ASSERT_EQ(strlcasecmp_impl((A), (B), (AS)), (EQ), "case-insensitive compare '%s'.%zu, '%s'", (A), (AS), (B))
154*8d741a5dSApple OSS Distributions 	// same tests as strcasecmp, then tests with individual characters
155*8d741a5dSApple OSS Distributions 	// two identical strings
156*8d741a5dSApple OSS Distributions 	char a[] = "hElLo";
157*8d741a5dSApple OSS Distributions 	char b[] = "HeLlO";
158*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, 0);
159*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, 0);
160*8d741a5dSApple OSS Distributions 
161*8d741a5dSApple OSS Distributions 	// the same string
162*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), b, 0);
163*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b), a, 0);
164*8d741a5dSApple OSS Distributions 
165*8d741a5dSApple OSS Distributions 	// two different strings
166*8d741a5dSApple OSS Distributions 	char c[] = "world";
167*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), c, a[0] - c[0]);
168*8d741a5dSApple OSS Distributions 	T_COMPARE(c, sizeof(c), a, c[0] - a[0]);
169*8d741a5dSApple OSS Distributions 	char d[] = "hellp";
170*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a), d, 'o' - 'p');
171*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d), a, 'p' - 'o');
172*8d741a5dSApple OSS Distributions 
173*8d741a5dSApple OSS Distributions 	// strings of different size
174*8d741a5dSApple OSS Distributions 	char e[] = "aAaA";
175*8d741a5dSApple OSS Distributions 	char f[] = "AaAaB";
176*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e), f, 0 - 'b');
177*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f), e, 'b' - 0);
178*8d741a5dSApple OSS Distributions 
179*8d741a5dSApple OSS Distributions 	// strings that are not NUL-terminated
180*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, b, 0);
181*8d741a5dSApple OSS Distributions 	T_COMPARE(b, sizeof(b) - 1, a, 0);
182*8d741a5dSApple OSS Distributions 	T_COMPARE(a, sizeof(a) - 1, d, 'o' - 'p');
183*8d741a5dSApple OSS Distributions 	T_COMPARE(d, sizeof(d) - 1, a, 'p' - 'o');
184*8d741a5dSApple OSS Distributions 	T_COMPARE(e, sizeof(e) - 1, f, 0 - 'b');
185*8d741a5dSApple OSS Distributions 	T_COMPARE(f, sizeof(f) - 1, e, 'b' - 0);
186*8d741a5dSApple OSS Distributions #undef T_COMPARE
187*8d741a5dSApple OSS Distributions }
188*8d741a5dSApple OSS Distributions 
189*8d741a5dSApple OSS Distributions T_DECL(strbufcasecmp_all, "strbufcasecmp_all") {
190*8d741a5dSApple OSS Distributions #define T_CHAR_COMPARE(A, AS, B, BS, EQ) do { \
191*8d741a5dSApple OSS Distributions     int r = strbufcasecmp_impl((A), (AS), (B), (BS)); \
192*8d741a5dSApple OSS Distributions     if (r != (EQ)) T_FAIL("case-insensitive compare '0x%02hhx' to '0x%02hhx' was %i instead of %i", *(A), *(B), r, (EQ)); \
193*8d741a5dSApple OSS Distributions } while (0)
194*8d741a5dSApple OSS Distributions 	// test each character
195*8d741a5dSApple OSS Distributions 	char ga, gb, ha, hb;
196*8d741a5dSApple OSS Distributions 	char nul = 0;
197*8d741a5dSApple OSS Distributions 	for (int i = 0; i < 256; ++i) {
198*8d741a5dSApple OSS Distributions 		ga = (char)(i);
199*8d741a5dSApple OSS Distributions 		gb = (i >= 'A' && i <= 'Z') ? (char)(i - 'A' + 'a') : ga;
200*8d741a5dSApple OSS Distributions 		T_CHAR_COMPARE(&ga, 1, &nul, 0, gb);
201*8d741a5dSApple OSS Distributions 		T_CHAR_COMPARE(&nul, 0, &ga, 1, -gb);
202*8d741a5dSApple OSS Distributions 
203*8d741a5dSApple OSS Distributions 		for (int j = 0; j < 256; ++j) {
204*8d741a5dSApple OSS Distributions 			ha = (char)(j);
205*8d741a5dSApple OSS Distributions 			hb = (j >= 'A' && j <= 'Z') ? (char)(j - 'A' + 'a') : ha;
206*8d741a5dSApple OSS Distributions 			T_CHAR_COMPARE(&ga, 1, &ha, 1, gb - hb);
207*8d741a5dSApple OSS Distributions 			T_CHAR_COMPARE(&ha, 1, &ga, 1, hb - gb);
208*8d741a5dSApple OSS Distributions 		}
209*8d741a5dSApple OSS Distributions 	}
210*8d741a5dSApple OSS Distributions 	T_PASS("ASCII character case insensitivity");
211*8d741a5dSApple OSS Distributions }
212*8d741a5dSApple OSS Distributions 
213*8d741a5dSApple OSS Distributions T_DECL(strbufcpy, "strbufcpy") {
214*8d741a5dSApple OSS Distributions 	char dst[32];
215*8d741a5dSApple OSS Distributions 	// empty dest
216*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strbufcpy_impl(NULL, 0, "hello", 5), NULL, "0-length destination");
217*8d741a5dSApple OSS Distributions 
218*8d741a5dSApple OSS Distributions #define T_CPY(A, AS, B, BS) T_ASSERT_EQ(strbufcpy_impl((A), (AS), (B), (BS)), (char *)(A), "copy '%.*s'.%zu to dst.%zu", (int)(BS), (B), (size_t)(BS), (AS))
219*8d741a5dSApple OSS Distributions 	// copy NUL terminated string that fits in dst
220*8d741a5dSApple OSS Distributions 	char hello[] = "hello";
221*8d741a5dSApple OSS Distributions 	memset(dst, 0, sizeof(dst));
222*8d741a5dSApple OSS Distributions 	T_CPY(dst, sizeof(dst), hello, sizeof(hello));
223*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(memcmp_impl(dst, (char[32]){"hello"}, sizeof(dst)), 0, "check result is 'hello'");
224*8d741a5dSApple OSS Distributions 
225*8d741a5dSApple OSS Distributions 	// copy NUL terminated string that does not fit in dst
226*8d741a5dSApple OSS Distributions 	char aaa[40] = {[0 ... 38] = 'a' };
227*8d741a5dSApple OSS Distributions 	memset(dst, 0, sizeof(dst));
228*8d741a5dSApple OSS Distributions 	T_CPY(dst, sizeof(dst), aaa, sizeof(aaa));
229*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(memcmp_impl(aaa, dst, 31), 0, "check result is 'aaaaaa...'");
230*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(dst[31], 0, "check result is NUL-terminated");
231*8d741a5dSApple OSS Distributions 
232*8d741a5dSApple OSS Distributions 	// copy non-terminated string
233*8d741a5dSApple OSS Distributions 	memset(dst, 0xff, sizeof(dst));
234*8d741a5dSApple OSS Distributions 	T_CPY(dst, sizeof(dst), "bbb", 3);
235*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strcmp_impl(dst, "bbb"), 0, "check result is 'bbb'");
236*8d741a5dSApple OSS Distributions 
237*8d741a5dSApple OSS Distributions 	// copy string over itself
238*8d741a5dSApple OSS Distributions 	char hw1[32] = "hello world";
239*8d741a5dSApple OSS Distributions 	T_CPY(hw1 + 6, sizeof(hw1) - 6, hw1, sizeof(hw1));
240*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strcmp_impl(hw1, "hello hello world"), 0, "check copy over self is 'hello hello world'");
241*8d741a5dSApple OSS Distributions 
242*8d741a5dSApple OSS Distributions 	char hw2[32] = "hello world";
243*8d741a5dSApple OSS Distributions 	T_CPY(hw2, sizeof(hw2), hw2 + 6, sizeof(hw2) - 6);
244*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strcmp_impl(hw2, "world"), 0, "check copy over self is 'world'");
245*8d741a5dSApple OSS Distributions #undef T_CPY
246*8d741a5dSApple OSS Distributions }
247*8d741a5dSApple OSS Distributions 
248*8d741a5dSApple OSS Distributions T_DECL(strbufcat, "strbufcat") {
249*8d741a5dSApple OSS Distributions 	char dst[32] = {0};
250*8d741a5dSApple OSS Distributions 
251*8d741a5dSApple OSS Distributions 	// empty dst
252*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strbufcat_impl(NULL, 0, "hello", 5), NULL, "check concatenation to 0-length destination");
253*8d741a5dSApple OSS Distributions 
254*8d741a5dSApple OSS Distributions #define T_CAT_RESULT(RESULT) \
255*8d741a5dSApple OSS Distributions     T_ASSERT_EQ(strcmp_impl(dst, (RESULT)), 0, "check result of concatenation is '%s'", (RESULT)); \
256*8d741a5dSApple OSS Distributions 
257*8d741a5dSApple OSS Distributions #define T_CAT(TO_CAT, RESULT) do { \
258*8d741a5dSApple OSS Distributions     T_ASSERT_EQ(strbufcat_impl(dst, sizeof(dst), (TO_CAT), sizeof(TO_CAT)), (char *)dst, "check concatenation of '%s'", (TO_CAT)); \
259*8d741a5dSApple OSS Distributions     T_CAT_RESULT(RESULT); \
260*8d741a5dSApple OSS Distributions } while (0)
261*8d741a5dSApple OSS Distributions 
262*8d741a5dSApple OSS Distributions 	// append "hello "
263*8d741a5dSApple OSS Distributions 	T_CAT("hello ", "hello ");
264*8d741a5dSApple OSS Distributions 
265*8d741a5dSApple OSS Distributions 	// append "world!"
266*8d741a5dSApple OSS Distributions 	T_CAT("world!", "hello world!");
267*8d741a5dSApple OSS Distributions 
268*8d741a5dSApple OSS Distributions 	// append itself
269*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strbufcat_impl(dst, sizeof(dst), dst, sizeof(dst)), (char *)dst, "check concatenating self");
270*8d741a5dSApple OSS Distributions 	T_CAT_RESULT("hello world!hello world!");
271*8d741a5dSApple OSS Distributions 
272*8d741a5dSApple OSS Distributions 	// append bunch of 'a's
273*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strbufcat_impl(dst, sizeof(dst), "aaaaaaaaaa", 10), (char *)dst, "check concatenating 'aaaa...'");
274*8d741a5dSApple OSS Distributions 	T_CAT_RESULT("hello world!hello world!aaaaaaa");
275*8d741a5dSApple OSS Distributions 
276*8d741a5dSApple OSS Distributions #undef T_CAT
277*8d741a5dSApple OSS Distributions #undef T_CAT_RESULT
278*8d741a5dSApple OSS Distributions }
279*8d741a5dSApple OSS Distributions 
280*8d741a5dSApple OSS Distributions T_DECL(libsa_overloads, "libsa_overloads") {
281*8d741a5dSApple OSS Distributions 	char buf[32] = "hello, world";
282*8d741a5dSApple OSS Distributions 	char buf2[32] = "world, hello";
283*8d741a5dSApple OSS Distributions 
284*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strbuflen(buf), (size_t)12, "strbuflen one argument");
285*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(strbuflen(buf, sizeof(buf)), (size_t)12, "strbuflen two arguments");
286*8d741a5dSApple OSS Distributions 
287*8d741a5dSApple OSS Distributions 	T_ASSERT_LT(strbufcmp(buf, buf2), 0, "strbufcmp two arguments");
288*8d741a5dSApple OSS Distributions 	T_ASSERT_LT(strbufcmp(buf, sizeof(buf), buf2, sizeof(buf2)), 0, "strbufcmp four arguments");
289*8d741a5dSApple OSS Distributions 
290*8d741a5dSApple OSS Distributions 	T_ASSERT_LT(strbufcasecmp(buf, buf2), 0, "strbufcasecmp two arguments");
291*8d741a5dSApple OSS Distributions 	T_ASSERT_LT(strbufcasecmp(buf, sizeof(buf), buf2, sizeof(buf2)), 0, "strbufcasecmp four arguments");
292*8d741a5dSApple OSS Distributions 
293*8d741a5dSApple OSS Distributions 	T_ASSERT_NE(strbufcpy(buf, buf2), NULL, "strbufcpy two arguments");
294*8d741a5dSApple OSS Distributions 	T_ASSERT_NE(strbufcpy(buf, sizeof(buf), buf2, sizeof(buf2)), NULL, "strbufcpy four arguments");
295*8d741a5dSApple OSS Distributions 
296*8d741a5dSApple OSS Distributions 	T_ASSERT_NE(strbufcat(buf, buf2), NULL, "strbufcat two arguments");
297*8d741a5dSApple OSS Distributions 	T_ASSERT_NE(strbufcat(buf, sizeof(buf), buf2, sizeof(buf2)), NULL, "strbufcat four arguments");
298*8d741a5dSApple OSS Distributions }
299