1 /*
2  * Copyright (c) 1994 Cygnus Support.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms are permitted
6  * provided that the above copyright notice and this paragraph are
7  * duplicated in all such forms and that any documentation,
8  * and/or other materials related to such
9  * distribution and use acknowledge that the software was developed
10  * at Cygnus Support, Inc.  Cygnus Support, Inc. may not be used to
11  * endorse or promote products derived from this software without
12  * specific prior written permission.
13  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
14  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
15  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
16  */
17 #include "test.h"
18 #include <string.h>
19 #include <errno.h>
20 
21 
22 /* Suppresses compiler warnings
23  *    As described by items in quotes
24  */
25 
26 #pragma GCC diagnostic ignored "-Wmemset-transposed-args"
27 #ifndef __clang__
28 #pragma GCC diagnostic ignored "-Wstringop-overflow="
29 #pragma GCC diagnostic ignored "-Wstringop-truncation"
30 #endif
31 #pragma GCC diagnostic ignored "-Warray-bounds"
32 
33 
34 const char *it = "<UNSET>";	/* Routine name for message routines. */
35 int  errors = 0;
36 
37 /* Complain if condition is not true.  */
38 #define check(thing) checkit(thing, __LINE__)
39 
40 static void
checkit(int ok,int l)41 checkit (int ok,
42        int l )
43 
44 {
45   newfunc(it);
46   line(l);
47 
48   if (!ok)
49   {
50     printf("string.c:%d %s\n", l, it);
51     ++errors;
52   }
53 }
54 
55 
56 
57 /* Complain if first two args don't strcmp as equal.  */
58 #define equal(a, b)  funcqual(a,b,__LINE__);
59 
60 static void
funcqual(char * a,char * b,int l)61 funcqual (char *a,
62        char *b,
63        int l)
64 {
65   newfunc(it);
66 
67   line(l);
68   if (a == NULL && b == NULL) return;
69   if (strcmp(a,b)) {
70       printf("string.c:%d (%s)\n", l, it);
71     }
72 }
73 
74 
75 
76 static char one[100];
77 static char two[50];
78 
79 
test_string(void)80 void test_string(void)
81 {
82   /* Test strcmp first because we use it to test other things.  */
83   it = "strcmp";
84   check(strcmp("", "") == 0); /* Trivial case. */
85   check(strcmp("a", "a") == 0); /* Identity. */
86   check(strcmp("abc", "abc") == 0); /* Multicharacter. */
87   check(strcmp("abc", "abcd") < 0); /* Length mismatches. */
88   check(strcmp("abcd", "abc") > 0);
89   check(strcmp("abcd", "abce") < 0);	/* Honest miscompares. */
90   check(strcmp("abce", "abcd") > 0);
91   check(strcmp("a\103", "a") > 0); /* Tricky if char signed. */
92   check(strcmp("a\103", "a\003") > 0);
93 
94   /* Test strcpy next because we need it to set up other tests.  */
95   it = "strcpy";
96   check(strcpy(one, "abcd") == one);	/* Returned value. */
97   equal(one, "abcd");	/* Basic test. */
98 
99   (void) strcpy(one, "x");
100   equal(one, "x");		/* Writeover. */
101   equal(one+2, "cd");	/* Wrote too much? */
102 
103   (void) strcpy(two, "hi there");
104   (void) strcpy(one, two);
105   equal(one, "hi there");	/* Basic test encore. */
106   equal(two, "hi there");	/* Stomped on source? */
107 
108   (void) strcpy(one, "");
109   equal(one, "");		/* Boundary condition. */
110 
111   /* strcat.  */
112   it = "strcat";
113   (void) strcpy(one, "ijk");
114   check(strcat(one, "lmn") == one); /* Returned value. */
115   equal(one, "ijklmn");	/* Basic test. */
116 
117   (void) strcpy(one, "x");
118   (void) strcat(one, "yz");
119   equal(one, "xyz");		/* Writeover. */
120   equal(one+4, "mn");	/* Wrote too much? */
121 
122   (void) strcpy(one, "gh");
123   (void) strcpy(two, "ef");
124   (void) strcat(one, two);
125   equal(one, "ghef");	/* Basic test encore. */
126   equal(two, "ef");		/* Stomped on source? */
127 
128   (void) strcpy(one, "");
129   (void) strcat(one, "");
130   equal(one, "");		/* Boundary conditions. */
131   (void) strcpy(one, "ab");
132   (void) strcat(one, "");
133   equal(one, "ab");
134   (void) strcpy(one, "");
135   (void) strcat(one, "cd");
136   equal(one, "cd");
137 
138   /* strncat - first test it as strcat, with big counts,
139      then test the count mechanism.  */
140   it = "strncat";
141   (void) strcpy(one, "ijk");
142   check(strncat(one, "lmn", 99) == one); /* Returned value. */
143   equal(one, "ijklmn");	/* Basic test. */
144 
145   (void) strcpy(one, "x");
146   (void) strncat(one, "yz", 99);
147   equal(one, "xyz");		/* Writeover. */
148   equal(one+4, "mn");	/* Wrote too much? */
149 
150   (void) strcpy(one, "gh");
151   (void) strcpy(two, "ef");
152   (void) strncat(one, two, 99);
153   equal(one, "ghef");	/* Basic test encore. */
154   equal(two, "ef");		/* Stomped on source? */
155 
156   (void) strcpy(one, "");
157   (void) strncat(one, "", 99);
158   equal(one, "");		/* Boundary conditions. */
159   (void) strcpy(one, "ab");
160   (void) strncat(one, "", 99);
161   equal(one, "ab");
162   (void) strcpy(one, "");
163   (void) strncat(one, "cd", 99);
164   equal(one, "cd");
165 
166   (void) strcpy(one, "ab");
167   (void) strncat(one, "cdef", 2);
168   equal(one, "abcd");	/* Count-limited. */
169 
170   (void) strncat(one, "gh", 0);
171   equal(one, "abcd");	/* Zero count. */
172 
173   (void) strncat(one, "gh", 2);
174   equal(one, "abcdgh");	/* Count, length equal. */
175   it = "strncmp";
176   /* strncmp - first test as strcmp with big counts";*/
177   check(strncmp("", "", 99) == 0); /* Trivial case. */
178   check(strncmp("a", "a", 99) == 0);	/* Identity. */
179   check(strncmp("abc", "abc", 99) == 0); /* Multicharacter. */
180   check(strncmp("abc", "abcd", 99) < 0); /* Length unequal. */
181   check(strncmp("abcd", "abc",99) > 0);
182   check(strncmp("abcd", "abce", 99) < 0); /* Honestly unequal. */
183   check(strncmp("abce", "abcd",99)>0);
184   check(strncmp("abce", "abcd", 3) == 0); /* Count limited. */
185   check(strncmp("abce", "abc", 3) == 0); /* Count == length. */
186   check(strncmp("abcd", "abce", 4) < 0); /* Nudging limit. */
187   check(strncmp("abc", "def", 0) == 0); /* Zero count. */
188 
189   /* strncpy - testing is a bit different because of odd semantics.  */
190   it = "strncpy";
191   check(strncpy(one, "abc", 4) == one); /* Returned value. */
192   equal(one, "abc");		/* Did the copy go right? */
193 
194   (void) strcpy(one, "abcdefgh");
195   (void) strncpy(one, "xyz", 2);
196   equal(one, "xycdefgh");	/* Copy cut by count. */
197 
198   (void) strcpy(one, "abcdefgh");
199   (void) strncpy(one, "xyz", 3); /* Copy cut just before NUL. */
200   equal(one, "xyzdefgh");
201 
202   (void) strcpy(one, "abcdefgh");
203   (void) strncpy(one, "xyz", 4); /* Copy just includes NUL. */
204   equal(one, "xyz");
205   equal(one+4, "efgh");	/* Wrote too much? */
206 
207   (void) strcpy(one, "abcdefgh");
208   (void) strncpy(one, "xyz", 5); /* Copy includes padding. */
209   equal(one, "xyz");
210   equal(one+4, "");
211   equal(one+5, "fgh");
212 
213   (void) strcpy(one, "abc");
214   (void) strncpy(one, "xyz", 0); /* Zero-length copy. */
215   equal(one, "abc");
216 
217   (void) strncpy(one, "", 2);	/* Zero-length source. */
218   equal(one, "");
219   equal(one+1, "");
220   equal(one+2, "c");
221 
222   (void) strcpy(one, "hi there");
223   (void) strncpy(two, one, 9);
224   equal(two, "hi there");	/* Just paranoia. */
225   equal(one, "hi there");	/* Stomped on source? */
226 
227   /* strlen.  */
228   it = "strlen";
229   check(strlen("") == 0);	/* Empty. */
230   check(strlen("a") == 1);	/* Single char. */
231   check(strlen("abcd") == 4); /* Multiple chars. */
232 
233   /* strchr.  */
234   it = "strchr";
235   check(strchr("abcd", 'z') == NULL); /* Not found. */
236   (void) strcpy(one, "abcd");
237   check(strchr(one, 'c') == one+2); /* Basic test. */
238   check(strchr(one, 'd') == one+3); /* End of string. */
239   check(strchr(one, 'a') == one); /* Beginning. */
240   check(strchr(one, '\0') == one+4);	/* Finding NUL. */
241   (void) strcpy(one, "ababa");
242   check(strchr(one, 'b') == one+1); /* Finding first. */
243   (void) strcpy(one, "");
244   check(strchr(one, 'b') == NULL); /* Empty string. */
245   check(strchr(one, '\0') == one); /* NUL in empty string. */
246 
247   /* index - just like strchr.  */
248   it = "index";
249   check(index("abcd", 'z') == NULL);	/* Not found. */
250   (void) strcpy(one, "abcd");
251   check(index(one, 'c') == one+2); /* Basic test. */
252   check(index(one, 'd') == one+3); /* End of string. */
253   check(index(one, 'a') == one); /* Beginning. */
254   check(index(one, '\0') == one+4); /* Finding NUL. */
255   (void) strcpy(one, "ababa");
256   check(index(one, 'b') == one+1); /* Finding first. */
257   (void) strcpy(one, "");
258   check(index(one, 'b') == NULL); /* Empty string. */
259   check(index(one, '\0') == one); /* NUL in empty string. */
260 
261   /* strrchr.  */
262   it = "strrchr";
263   check(strrchr("abcd", 'z') == NULL); /* Not found. */
264   (void) strcpy(one, "abcd");
265   check(strrchr(one, 'c') == one+2);	/* Basic test. */
266   check(strrchr(one, 'd') == one+3);	/* End of string. */
267   check(strrchr(one, 'a') == one); /* Beginning. */
268   check(strrchr(one, '\0') == one+4); /* Finding NUL. */
269   (void) strcpy(one, "ababa");
270   check(strrchr(one, 'b') == one+3);	/* Finding last. */
271   (void) strcpy(one, "");
272   check(strrchr(one, 'b') == NULL); /* Empty string. */
273   check(strrchr(one, '\0') == one); /* NUL in empty string. */
274 
275   /* rindex - just like strrchr.  */
276   it = "rindex";
277   check(rindex("abcd", 'z') == NULL); /* Not found. */
278   (void) strcpy(one, "abcd");
279   check(rindex(one, 'c') == one+2); /* Basic test. */
280   check(rindex(one, 'd') == one+3); /* End of string. */
281   check(rindex(one, 'a') == one); /* Beginning. */
282   check(rindex(one, '\0') == one+4);	/* Finding NUL. */
283   (void) strcpy(one, "ababa");
284   check(rindex(one, 'b') == one+3); /* Finding last. */
285   (void) strcpy(one, "");
286   check(rindex(one, 'b') == NULL); /* Empty string. */
287   check(rindex(one, '\0') == one); /* NUL in empty string. */
288 
289   /* strpbrk - somewhat like strchr.  */
290   it = "strpbrk";
291   check(strpbrk("abcd", "z") == NULL); /* Not found. */
292   (void) strcpy(one, "abcd");
293   check(strpbrk(one, "c") == one+2);	/* Basic test. */
294   check(strpbrk(one, "d") == one+3);	/* End of string. */
295   check(strpbrk(one, "a") == one); /* Beginning. */
296   check(strpbrk(one, "") == NULL); /* Empty search list. */
297   check(strpbrk(one, "cb") == one+1); /* Multiple search. */
298   (void) strcpy(one, "abcabdea");
299   check(strpbrk(one, "b") == one+1);	/* Finding first. */
300   check(strpbrk(one, "cb") == one+1); /* With multiple search. */
301   check(strpbrk(one, "db") == one+1); /* Another variant. */
302   (void) strcpy(one, "");
303   check(strpbrk(one, "bc") == NULL); /* Empty string. */
304   check(strpbrk(one, "") == NULL); /* Both strings empty. */
305 
306   /* strstr - somewhat like strchr.  */
307   it = "strstr";
308   check(strstr("z", "abcd") == NULL); /* Not found. */
309   check(strstr("abx", "abcd") == NULL); /* Dead end. */
310   (void) strcpy(one, "abcd");
311   check(strstr(one,"c") == one+2); /* Basic test. */
312   check(strstr(one, "bc") == one+1);	/* Multichar. */
313   check(strstr(one,"d") == one+3); /* End of string. */
314   check(strstr(one,"cd") == one+2);	/* Tail of string. */
315   check(strstr(one,"abc") == one); /* Beginning. */
316   check(strstr(one,"abcd") == one);	/* Exact match. */
317   check(strstr(one,"de") == NULL);	/* Past end. */
318   check(strstr(one,"") == one); /* Finding empty. */
319   (void) strcpy(one, "ababa");
320   check(strstr(one,"ba") == one+1); /* Finding first. */
321   (void) strcpy(one, "");
322   check(strstr(one, "b") == NULL); /* Empty string. */
323   check(strstr(one,"") == one); /* Empty in empty string. */
324   (void) strcpy(one, "bcbca");
325   check(strstr(one,"bca") == one+2); /* False start. */
326   (void) strcpy(one, "bbbcabbca");
327   check(strstr(one,"bbca") == one+1); /* With overlap. */
328 
329   /* strspn.  */
330   it = "strspn";
331   check(strspn("abcba", "abc") == 5); /* Whole string. */
332   check(strspn("abcba", "ab") == 2);	/* Partial. */
333   check(strspn("abc", "qx") == 0); /* None. */
334   check(strspn("", "ab") == 0); /* Null string. */
335   check(strspn("abc", "") == 0); /* Null search list. */
336 
337   /* strcspn.  */
338   it = "strcspn";
339   check(strcspn("abcba", "qx") == 5); /* Whole string. */
340   check(strcspn("abcba", "cx") == 2); /* Partial. */
341   check(strcspn("abc", "abc") == 0);	/* None. */
342   check(strcspn("", "ab") == 0); /* Null string. */
343   check(strcspn("abc", "") == 3); /* Null search list. */
344 
345   /* strtok - the hard one.  */
346   it = "strtok";
347   (void) strcpy(one, "first, second, third");
348   equal(strtok(one, ", "), "first");	/* Basic test. */
349   equal(one, "first");
350   equal(strtok((char *)NULL, ", "), "second");
351   equal(strtok((char *)NULL, ", "), "third");
352   check(strtok((char *)NULL, ", ") == NULL);
353   (void) strcpy(one, ", first, ");
354   equal(strtok(one, ", "), "first");	/* Extra delims, 1 tok. */
355   check(strtok((char *)NULL, ", ") == NULL);
356   (void) strcpy(one, "1a, 1b; 2a, 2b");
357   equal(strtok(one, ", "), "1a"); /* Changing delim lists. */
358   equal(strtok((char *)NULL, "; "), "1b");
359   equal(strtok((char *)NULL, ", "), "2a");
360   (void) strcpy(two, "x-y");
361   equal(strtok(two, "-"), "x"); /* New string before done. */
362   equal(strtok((char *)NULL, "-"), "y");
363   check(strtok((char *)NULL, "-") == NULL);
364   (void) strcpy(one, "a,b, c,, ,d");
365   equal(strtok(one, ", "), "a"); /* Different separators. */
366   equal(strtok((char *)NULL, ", "), "b");
367   equal(strtok((char *)NULL, " ,"), "c"); /* Permute list too. */
368   equal(strtok((char *)NULL, " ,"), "d");
369   check(strtok((char *)NULL, ", ") == NULL);
370   check(strtok((char *)NULL, ", ") == NULL); /* Persistence. */
371   (void) strcpy(one, ", ");
372   check(strtok(one, ", ") == NULL);	/* No tokens. */
373   (void) strcpy(one, "");
374   check(strtok(one, ", ") == NULL);	/* Empty string. */
375   (void) strcpy(one, "abc");
376   equal(strtok(one, ", "), "abc"); /* No delimiters. */
377   check(strtok((char *)NULL, ", ") == NULL);
378   (void) strcpy(one, "abc");
379   equal(strtok(one, ""), "abc"); /* Empty delimiter list. */
380   check(strtok((char *)NULL, "") == NULL);
381   (void) strcpy(one, "abcdefgh");
382   (void) strcpy(one, "a,b,c");
383   equal(strtok(one, ","), "a"); /* Basics again... */
384   equal(strtok((char *)NULL, ","), "b");
385   equal(strtok((char *)NULL, ","), "c");
386   check(strtok((char *)NULL, ",") == NULL);
387   equal(one+6, "gh");	/* Stomped past end? */
388   equal(one, "a");		/* Stomped old tokens? */
389   equal(one+2, "b");
390   equal(one+4, "c");
391 
392   /* memcmp.  */
393   it = "memcmp";
394   check(memcmp("a", "a", 1) == 0); /* Identity. */
395   check(memcmp("abc", "abc", 3) == 0); /* Multicharacter. */
396   check(memcmp("abcd", "abce", 4) < 0); /* Honestly unequal. */
397   check(memcmp("abce", "abcd",4));
398   check(memcmp("alph", "beta", 4) < 0);
399   check(memcmp("abce", "abcd", 3) == 0); /* Count limited. */
400   check(memcmp("abc", "def", 0) == 0); /* Zero count. */
401 
402   /* memcmp should test strings as unsigned */
403   one[0] = 0xfe;
404   two[0] = 0x03;
405   check(memcmp(one, two,1) > 0);
406 
407 
408   /* memchr.  */
409   it = "memchr";
410   check(memchr("abcd", 'z', 4) == NULL); /* Not found. */
411   (void) strcpy(one, "abcd");
412   check(memchr(one, 'c', 4) == one+2); /* Basic test. */
413   check(memchr(one, 'd', 4) == one+3); /* End of string. */
414   check(memchr(one, 'a', 4) == one);	/* Beginning. */
415   check(memchr(one, '\0', 5) == one+4); /* Finding NUL. */
416   (void) strcpy(one, "ababa");
417   check(memchr(one, 'b', 5) == one+1); /* Finding first. */
418   check(memchr(one, 'b', 0) == NULL); /* Zero count. */
419   check(memchr(one, 'a', 1) == one);	/* Singleton case. */
420   (void) strcpy(one, "a\203b");
421   check(memchr(one, 0203, 3) == one+1); /* Unsignedness. */
422 
423   /* memcpy - need not work for overlap.  */
424   it = "memcpy";
425   check(memcpy(one, "abc", 4) == one); /* Returned value. */
426   equal(one, "abc");		/* Did the copy go right? */
427 
428   (void) strcpy(one, "abcdefgh");
429   (void) memcpy(one+1, "xyz", 2);
430   equal(one, "axydefgh");	/* Basic test. */
431 
432   (void) strcpy(one, "abc");
433   (void) memcpy(one, "xyz", 0);
434   equal(one, "abc");		/* Zero-length copy. */
435 
436   (void) strcpy(one, "hi there");
437   (void) strcpy(two, "foo");
438   (void) memcpy(two, one, 9);
439   equal(two, "hi there");	/* Just paranoia. */
440   equal(one, "hi there");	/* Stomped on source? */
441 #if 0
442   /* memmove - must work on overlap.  */
443   it = "memmove";
444   check(memmove(one, "abc", 4) == one); /* Returned value. */
445   equal(one, "abc");		/* Did the copy go right? */
446 
447   (void) strcpy(one, "abcdefgh");
448   (void) memmove(one+1, "xyz", 2);
449   equal(one, "axydefgh");	/* Basic test. */
450 
451   (void) strcpy(one, "abc");
452   (void) memmove(one, "xyz", 0);
453   equal(one, "abc");		/* Zero-length copy. */
454 
455   (void) strcpy(one, "hi there");
456   (void) strcpy(two, "foo");
457   (void) memmove(two, one, 9);
458   equal(two, "hi there");	/* Just paranoia. */
459   equal(one, "hi there");	/* Stomped on source? */
460 
461   (void) strcpy(one, "abcdefgh");
462   (void) memmove(one+1, one, 9);
463   equal(one, "aabcdefgh");	/* Overlap, right-to-left. */
464 
465   (void) strcpy(one, "abcdefgh");
466   (void) memmove(one+1, one+2, 7);
467   equal(one, "acdefgh");	/* Overlap, left-to-right. */
468 
469   (void) strcpy(one, "abcdefgh");
470   (void) memmove(one, one, 9);
471   equal(one, "abcdefgh");	/* 100% overlap. */
472 #endif
473 #if 0
474   /* memccpy - first test like memcpy, then the search part
475      The SVID, the only place where memccpy is mentioned, says
476      overlap might fail, so we don't try it.  Besides, it's hard
477      to see the rationale for a non-left-to-right memccpy.  */
478   it = "memccpy";
479   check(memccpy(one, "abc", 'q', 4) == NULL); /* Returned value. */
480   equal(one, "abc");		/* Did the copy go right? */
481 
482   (void) strcpy(one, "abcdefgh");
483   (void) memccpy(one+1, "xyz", 'q', 2);
484   equal(one, "axydefgh");	/* Basic test. */
485 
486   (void) strcpy(one, "abc");
487   (void) memccpy(one, "xyz", 'q', 0);
488   equal(one, "abc");		/* Zero-length copy. */
489 
490   (void) strcpy(one, "hi there");
491   (void) strcpy(two, "foo");
492   (void) memccpy(two, one, 'q', 9);
493   equal(two, "hi there");	/* Just paranoia. */
494   equal(one, "hi there");	/* Stomped on source? */
495 
496   (void) strcpy(one, "abcdefgh");
497   (void) strcpy(two, "horsefeathers");
498   check(memccpy(two, one, 'f', 9) == two+6);	/* Returned value. */
499   equal(one, "abcdefgh");	/* Source intact? */
500   equal(two, "abcdefeathers"); /* Copy correct? */
501 
502   (void) strcpy(one, "abcd");
503   (void) strcpy(two, "bumblebee");
504   check(memccpy(two, one, 'a', 4) == two+1); /* First char. */
505   equal(two, "aumblebee");
506   check(memccpy(two, one, 'd', 4) == two+4); /* Last char. */
507   equal(two, "abcdlebee");
508   (void) strcpy(one, "xyz");
509   check(memccpy(two, one, 'x', 1) == two+1); /* Singleton. */
510   equal(two, "xbcdlebee");
511 #endif
512   /* memset.  */
513   it = "memset";
514   (void) strcpy(one, "abcdefgh");
515   check(memset(one+1, 'x', 3) == one+1); /* Return value. */
516   equal(one, "axxxefgh");	/* Basic test. */
517 
518   (void) memset(one+2, 'y', 0);
519   equal(one, "axxxefgh");	/* Zero-length set. */
520 
521   (void) memset(one+5, 0, 1);
522   equal(one, "axxxe");	/* Zero fill. */
523   equal(one+6, "gh");	/*, the leftover. */
524 
525   (void) memset(one+2, 010045, 1);
526   equal(one, "ax\045xe");	/* Unsigned char convert. */
527 
528   /* bcopy - much like memcpy.
529      Berklix manual is silent about overlap, so don't test it.  */
530   it = "bcopy";
531   (void) bcopy("abc", one, 4);
532   equal(one, "abc");		/* Simple copy. */
533 
534   (void) strcpy(one, "abcdefgh");
535   (void) bcopy("xyz", one+1, 2);
536   equal(one, "axydefgh");	/* Basic test. */
537 
538   (void) strcpy(one, "abc");
539   (void) bcopy("xyz", one, 0);
540   equal(one, "abc");		/* Zero-length copy. */
541 
542   (void) strcpy(one, "hi there");
543   (void) strcpy(two, "foo");
544   (void) bcopy(one, two, 9);
545   equal(two, "hi there");	/* Just paranoia. */
546   equal(one, "hi there");	/* Stomped on source? */
547 
548   /* bzero.  */
549   it = "bzero";
550   (void) strcpy(one, "abcdef");
551   bzero(one+2, 2);
552   equal(one, "ab");		/* Basic test. */
553   equal(one+3, "");
554   equal(one+4, "ef");
555 
556   (void) strcpy(one, "abcdef");
557   bzero(one+2, (0));
558   equal(one, "abcdef");	/* Zero-length copy. */
559 
560   /* bcmp - somewhat like memcmp.  */
561   it = "bcmp";
562   check(bcmp("a", "a", 1) == 0); /* Identity. */
563   check(bcmp("abc", "abc", 3) == 0);	/* Multicharacter. */
564   check(bcmp("abcd", "abce", 4) != 0); /* Honestly unequal. */
565   check(bcmp("abce", "abcd",4));
566   check(bcmp("alph", "beta", 4) != 0);
567   check(bcmp("abce", "abcd", 3) == 0); /* Count limited. */
568   check(bcmp("abc", "def", 0) == 0);	/* Zero count. */
569 
570 #if 0  /* strerror - VERY system-dependent.  */
571 {
572   extern CONST unsigned int _sys_nerr;
573   extern CONST char *CONST _sys_errlist[];
574   int f;
575   it = "strerror";
576   f = open("/", O_WRONLY);	/* Should always fail. */
577   check(f < 0 && errno > 0 && errno < _sys_nerr);
578   equal(strerror(errno), _sys_errlist[errno]);
579 }
580 #endif
581 }
582 
583