diff --git a/lib/libc/tests/locale/Makefile b/lib/libc/tests/locale/Makefile index c0e037857d4c..e05cbae3ac9f 100644 --- a/lib/libc/tests/locale/Makefile +++ b/lib/libc/tests/locale/Makefile @@ -2,6 +2,24 @@ .include +ATF_TESTS_C+= btowc_test +ATF_TESTS_C+= c16rtomb_test +ATF_TESTS_C+= iswctype_test +ATF_TESTS_C+= mblen_test +ATF_TESTS_C+= mbrlen_test +ATF_TESTS_C+= mbrtoc16_test +ATF_TESTS_C+= mbrtowc_2_test +ATF_TESTS_C+= mbsnrtowcs_2_test +ATF_TESTS_C+= mbsrtowcs_test +ATF_TESTS_C+= mbstowcs_2_test +ATF_TESTS_C+= mbtowc_2_test +ATF_TESTS_C+= towctrans_test +ATF_TESTS_C+= wcrtomb_test +ATF_TESTS_C+= wcsnrtombs_test +ATF_TESTS_C+= wcsrtombs_test +ATF_TESTS_C+= wcstombs_test +ATF_TESTS_C+= wctomb_2_test + NETBSD_ATF_TESTS_C= io_test NETBSD_ATF_TESTS_C+= mbrtowc_test NETBSD_ATF_TESTS_C+= mbstowcs_test @@ -13,7 +31,13 @@ NETBSD_ATF_TESTS_C+= wcsspn_test NETBSD_ATF_TESTS_C+= wcstod_test NETBSD_ATF_TESTS_C+= wctomb_test -CFLAGS.t_wctomb.c+= -Wno-stack-protector +SRCS.mbrtowc_2_test= mbrtowc_test.c +SRCS.mbsnrtowcs_2_test= mbsnrtowcs_test.c +SRCS.mbstowcs_2_test= mbstowcs_test.c +SRCS.mbtowc_2_test= mbtowc_test.c +SRCS.wctomb_2_test= wctomb_test.c + +CFLAGS.t_wctomb.c+= -Wno-stack-protector .include "../Makefile.netbsd-tests" diff --git a/tools/regression/lib/libc/locale/test-btowc.c b/lib/libc/tests/locale/btowc_test.c similarity index 75% rename from tools/regression/lib/libc/locale/test-btowc.c rename to lib/libc/tests/locale/btowc_test.c index b01c04344aa2..01a1133e89d5 100644 --- a/tools/regression/lib/libc/locale/test-btowc.c +++ b/lib/libc/tests/locale/btowc_test.c @@ -34,7 +34,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -42,32 +41,31 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(btowc_test); +ATF_TC_BODY(btowc_test, tc) { int i; - printf("1..2\n"); - - /* - * C/POSIX locale. - */ - assert(btowc(EOF) == WEOF); - assert(wctob(WEOF) == EOF); + /* C/POSIX locale. */ + ATF_REQUIRE(btowc(EOF) == WEOF); + ATF_REQUIRE(wctob(WEOF) == EOF); for (i = 0; i < UCHAR_MAX; i++) - assert(btowc(i) == (wchar_t)i && i == (int)wctob(i)); + ATF_REQUIRE(btowc(i) == (wchar_t)i && i == (int)wctob(i)); - /* - * Japanese (EUC) locale. - */ + /* Japanese (EUC) locale. */ + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); + ATF_REQUIRE(btowc('A') == L'A' && wctob(L'A') == 'A'); + ATF_REQUIRE(btowc(0xa3) == WEOF && wctob(0xa3c1) == EOF); - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); - assert(btowc('A') == L'A' && wctob(L'A') == 'A'); - assert(btowc(0xa3) == WEOF && wctob(0xa3c1) == EOF); - - printf("ok 1 - btowc()\n"); - printf("ok 2 - wctob()\n"); - - return (0); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, btowc_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-c16rtomb.c b/lib/libc/tests/locale/c16rtomb_test.c similarity index 61% rename from tools/regression/lib/libc/locale/test-c16rtomb.c rename to lib/libc/tests/locale/c16rtomb_test.c index 2c188fa337b8..bf451eff973f 100644 --- a/tools/regression/lib/libc/locale/test-c16rtomb.c +++ b/lib/libc/tests/locale/c16rtomb_test.c @@ -33,7 +33,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -41,105 +40,103 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(c16rtomb_test); +ATF_TC_BODY(c16rtomb_test, tc) { mbstate_t s; char buf[MB_LEN_MAX + 1]; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); + /* C/POSIX locale. */ /* * If the buffer argument is NULL, c16 is implicitly 0, * c16rtomb() resets its internal state. */ - assert(c16rtomb(NULL, L'\0', NULL) == 1); - assert(c16rtomb(NULL, 0xdc00, NULL) == 1); + ATF_REQUIRE(c16rtomb(NULL, L'\0', NULL) == 1); + ATF_REQUIRE(c16rtomb(NULL, 0xdc00, NULL) == 1); /* Null wide character. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0, &s) == 1); - assert((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(c16rtomb(buf, 0, &s) == 1); + ATF_REQUIRE((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); /* Latin letter A, internal state. */ - assert(c16rtomb(NULL, L'\0', NULL) == 1); - assert(c16rtomb(NULL, L'A', NULL) == 1); + ATF_REQUIRE(c16rtomb(NULL, L'\0', NULL) == 1); + ATF_REQUIRE(c16rtomb(NULL, L'A', NULL) == 1); /* Latin letter A. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, L'A', &s) == 1); - assert((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(c16rtomb(buf, L'A', &s) == 1); + ATF_REQUIRE((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); /* Unicode character 'Pile of poo'. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0xd83d, &s) == 0); - assert(c16rtomb(buf, 0xdca9, &s) == (size_t)-1); - assert(errno == EILSEQ); - assert((unsigned char)buf[0] == 0xcc); + ATF_REQUIRE(c16rtomb(buf, 0xd83d, &s) == 0); + ATF_REQUIRE(c16rtomb(buf, 0xdca9, &s) == (size_t)-1); + ATF_REQUIRE(errno == EILSEQ); + ATF_REQUIRE((unsigned char)buf[0] == 0xcc); - /* - * ISO8859-1. - */ + /* ISO8859-1. */ - assert(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-1"), + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-1"), "en_US.ISO8859-1") == 0); /* Unicode character 'Euro sign'. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0x20ac, &s) == (size_t)-1); - assert(errno == EILSEQ); - assert((unsigned char)buf[0] == 0xcc); + ATF_REQUIRE(c16rtomb(buf, 0x20ac, &s) == (size_t)-1); + ATF_REQUIRE(errno == EILSEQ); + ATF_REQUIRE((unsigned char)buf[0] == 0xcc); - /* - * ISO8859-15. - */ + /* ISO8859-15. */ - assert(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-15"), + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-15"), "en_US.ISO8859-15") == 0); /* Unicode character 'Euro sign'. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0x20ac, &s) == 1); - assert((unsigned char)buf[0] == 0xa4 && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(c16rtomb(buf, 0x20ac, &s) == 1); + ATF_REQUIRE((unsigned char)buf[0] == 0xa4 && (unsigned char)buf[1] == 0xcc); - /* - * UTF-8. - */ + /* UTF-8. */ - assert(strcmp(setlocale(LC_CTYPE, "en_US.UTF-8"), "en_US.UTF-8") == 0); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "en_US.UTF-8"), "en_US.UTF-8") == 0); /* Unicode character 'Pile of poo'. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0xd83d, &s) == 0); - assert(c16rtomb(buf, 0xdca9, &s) == 4); - assert((unsigned char)buf[0] == 0xf0 && (unsigned char)buf[1] == 0x9f && + ATF_REQUIRE(c16rtomb(buf, 0xd83d, &s) == 0); + ATF_REQUIRE(c16rtomb(buf, 0xdca9, &s) == 4); + ATF_REQUIRE((unsigned char)buf[0] == 0xf0 && (unsigned char)buf[1] == 0x9f && (unsigned char)buf[2] == 0x92 && (unsigned char)buf[3] == 0xa9 && (unsigned char)buf[4] == 0xcc); /* Invalid code; 'Pile of poo' without the trail surrogate. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0xd83d, &s) == 0); - assert(c16rtomb(buf, L'A', &s) == (size_t)-1); - assert(errno == EILSEQ); - assert((unsigned char)buf[0] == 0xcc); + ATF_REQUIRE(c16rtomb(buf, 0xd83d, &s) == 0); + ATF_REQUIRE(c16rtomb(buf, L'A', &s) == (size_t)-1); + ATF_REQUIRE(errno == EILSEQ); + ATF_REQUIRE((unsigned char)buf[0] == 0xcc); /* Invalid code; 'Pile of poo' without the lead surrogate. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); - assert(c16rtomb(buf, 0xdca9, &s) == (size_t)-1); - assert(errno == EILSEQ); - assert((unsigned char)buf[0] == 0xcc); - - printf("ok 1 - c16rtomb()\n"); + ATF_REQUIRE(c16rtomb(buf, 0xdca9, &s) == (size_t)-1); + ATF_REQUIRE(errno == EILSEQ); + ATF_REQUIRE((unsigned char)buf[0] == 0xcc); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, c16rtomb_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-iswctype.c b/lib/libc/tests/locale/iswctype_test.c similarity index 81% rename from tools/regression/lib/libc/locale/test-iswctype.c rename to lib/libc/tests/locale/iswctype_test.c index 1c56b887422d..061f7b1c8bdb 100644 --- a/tools/regression/lib/libc/locale/test-iswctype.c +++ b/lib/libc/tests/locale/iswctype_test.c @@ -34,15 +34,16 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(iswctype_test); +ATF_TC_BODY(iswctype_test, tc) { wctype_t t; int i, j; @@ -64,39 +65,36 @@ main(int argc, char *argv[]) { "xdigit", iswxdigit } }; - printf("1..2\n"); - - /* - * C/POSIX locale. - */ + /* C/POSIX locale. */ for (i = 0; i < sizeof(cls) / sizeof(*cls); i++) { t = wctype(cls[i].name); - assert(t != 0); + ATF_REQUIRE(t != 0); for (j = 0; j < 256; j++) - assert(cls[i].func(j) == iswctype(j, t)); + ATF_REQUIRE(cls[i].func(j) == iswctype(j, t)); } t = wctype("elephant"); - assert(t == 0); + ATF_REQUIRE(t == 0); for (i = 0; i < 256; i++) - assert(iswctype(i, t) == 0); + ATF_REQUIRE(iswctype(i, t) == 0); - /* - * Japanese (EUC) locale. - */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + /* Japanese (EUC) locale. */ + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); for (i = 0; i < sizeof(cls) / sizeof(*cls); i++) { t = wctype(cls[i].name); - assert(t != 0); + ATF_REQUIRE(t != 0); for (j = 0; j < 65536; j++) - assert(cls[i].func(j) == iswctype(j, t)); + ATF_REQUIRE(cls[i].func(j) == iswctype(j, t)); } t = wctype("elephant"); - assert(t == 0); + ATF_REQUIRE(t == 0); for (i = 0; i < 65536; i++) - assert(iswctype(i, t) == 0); - - printf("ok 1 - iswctype()\n"); - printf("ok 2 - wctype()\n"); - - return (0); + ATF_REQUIRE(iswctype(i, t) == 0); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, iswctype_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mblen.c b/lib/libc/tests/locale/mblen_test.c similarity index 76% rename from tools/regression/lib/libc/locale/test-mblen.c rename to lib/libc/tests/locale/mblen_test.c index dd073594b13a..1e8affa93909 100644 --- a/tools/regression/lib/libc/locale/test-mblen.c +++ b/lib/libc/tests/locale/mblen_test.c @@ -35,15 +35,16 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mblen_test); +ATF_TC_BODY(mblen_test, tc) { size_t len; char buf[MB_LEN_MAX + 1]; @@ -54,61 +55,65 @@ main(int argc, char *argv[]) printf("1..1\n"); - assert(MB_CUR_MAX == 1); + ATF_REQUIRE(MB_CUR_MAX == 1); /* No shift states in C locale. */ - assert(mblen(NULL, 0) == 0); + ATF_REQUIRE(mblen(NULL, 0) == 0); /* Null wide character. */ memset(buf, 0xcc, sizeof(buf)); buf[0] = '\0'; - assert(mblen(buf, 1) == 0); + ATF_REQUIRE(mblen(buf, 1) == 0); /* Latin letter A. */ buf[0] = 'A'; - assert(mblen(buf, 1) == 1); + ATF_REQUIRE(mblen(buf, 1) == 1); /* Incomplete character sequence. */ buf[0] = '\0'; - assert(mblen(buf, 0) == -1); - assert(mblen(NULL, 0) == 0); + ATF_REQUIRE(mblen(buf, 0) == -1); + ATF_REQUIRE(mblen(NULL, 0) == 0); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); /* No shift states in EUC. */ - assert(mblen(NULL, 0) == 0); + ATF_REQUIRE(mblen(NULL, 0) == 0); /* Null wide character. */ memset(buf, 0xcc, sizeof(buf)); buf[0] = '\0'; - assert(mblen(buf, 1) == 0); + ATF_REQUIRE(mblen(buf, 1) == 0); /* Latin letter A. */ buf[0] = 'A'; - assert(mblen(buf, 1) == 1); + ATF_REQUIRE(mblen(buf, 1) == 1); /* Incomplete character sequence. */ buf[0] = '\0'; - assert(mblen(buf, 0) == -1); - assert(mblen(NULL, 0) == 0); + ATF_REQUIRE(mblen(buf, 0) == -1); + ATF_REQUIRE(mblen(NULL, 0) == 0); /* Incomplete character sequence (truncated double-byte). */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0xa3; buf[1] = 0x00; - assert(mblen(buf, 1) == -1); - assert(mblen(NULL, 0) == 0); + ATF_REQUIRE(mblen(buf, 1) == -1); + ATF_REQUIRE(mblen(NULL, 0) == 0); /* Same as above, but complete. */ buf[1] = 0xc1; - assert(mblen(buf, 2) == 2); - - printf("ok 1 - mblen()\n"); - - return (0); + ATF_REQUIRE(mblen(buf, 2) == 2); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mblen_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbrlen.c b/lib/libc/tests/locale/mbrlen_test.c similarity index 73% rename from tools/regression/lib/libc/locale/test-mbrlen.c rename to lib/libc/tests/locale/mbrlen_test.c index 3198a77922d5..ffd61431550d 100644 --- a/tools/regression/lib/libc/locale/test-mbrlen.c +++ b/lib/libc/tests/locale/mbrlen_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,86 +43,85 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbrlen_test); +ATF_TC_BODY(mbrlen_test, tc) { mbstate_t s; size_t len; char buf[MB_LEN_MAX + 1]; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); - - assert(MB_CUR_MAX == 1); + /* C/POSIX locale. */ + ATF_REQUIRE(MB_CUR_MAX == 1); /* Null wide character, internal state. */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0; - assert(mbrlen(buf, 1, NULL) == 0); + ATF_REQUIRE(mbrlen(buf, 1, NULL) == 0); /* Null wide character. */ memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 1, &s) == 0); + ATF_REQUIRE(mbrlen(buf, 1, &s) == 0); /* Latin letter A, internal state. */ - assert(mbrlen(NULL, 0, NULL) == 0); + ATF_REQUIRE(mbrlen(NULL, 0, NULL) == 0); buf[0] = 'A'; - assert(mbrlen(buf, 1, NULL) == 1); + ATF_REQUIRE(mbrlen(buf, 1, NULL) == 1); /* Latin letter A. */ memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 1, &s) == 1); + ATF_REQUIRE(mbrlen(buf, 1, &s) == 1); /* Incomplete character sequence. */ memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 0, &s) == (size_t)-2); + ATF_REQUIRE(mbrlen(buf, 0, &s) == (size_t)-2); - /* - * Japanese (EUC) locale. - */ + /* Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); /* Null wide character, internal state. */ - assert(mbrlen(NULL, 0, NULL) == 0); + ATF_REQUIRE(mbrlen(NULL, 0, NULL) == 0); memset(buf, 0xcc, sizeof(buf)); buf[0] = 0; - assert(mbrlen(buf, 1, NULL) == 0); + ATF_REQUIRE(mbrlen(buf, 1, NULL) == 0); /* Null wide character. */ memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 1, &s) == 0); + ATF_REQUIRE(mbrlen(buf, 1, &s) == 0); /* Latin letter A, internal state. */ - assert(mbrlen(NULL, 0, NULL) == 0); + ATF_REQUIRE(mbrlen(NULL, 0, NULL) == 0); buf[0] = 'A'; - assert(mbrlen(buf, 1, NULL) == 1); + ATF_REQUIRE(mbrlen(buf, 1, NULL) == 1); /* Latin letter A. */ memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 1, &s) == 1); + ATF_REQUIRE(mbrlen(buf, 1, &s) == 1); /* Incomplete character sequence (zero length). */ memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 0, &s) == (size_t)-2); + ATF_REQUIRE(mbrlen(buf, 0, &s) == (size_t)-2); /* Incomplete character sequence (truncated double-byte). */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0xa3; buf[1] = 0x00; memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 1, &s) == (size_t)-2); + ATF_REQUIRE(mbrlen(buf, 1, &s) == (size_t)-2); /* Same as above, but complete. */ buf[1] = 0xc1; memset(&s, 0, sizeof(s)); - assert(mbrlen(buf, 2, &s) == 2); - - printf("ok 1 - mbrlen()\n"); - - return (0); + ATF_REQUIRE(mbrlen(buf, 2, &s) == 2); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbrlen_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbrtoc16.c b/lib/libc/tests/locale/mbrtoc16_test.c similarity index 57% rename from tools/regression/lib/libc/locale/test-mbrtoc16.c rename to lib/libc/tests/locale/mbrtoc16_test.c index f709a9c80323..a60563536d76 100644 --- a/tools/regression/lib/libc/locale/test-mbrtoc16.c +++ b/lib/libc/tests/locale/mbrtoc16_test.c @@ -33,7 +33,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -41,8 +40,10 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbrtoc16_test); +ATF_TC_BODY(mbrtoc16_test, tc) { mbstate_t s; size_t len; @@ -55,141 +56,145 @@ main(int argc, char *argv[]) printf("1..1\n"); /* Null wide character, internal state. */ - assert(mbrtoc16(&c16, "", 1, NULL) == 0); - assert(c16 == 0); + ATF_REQUIRE(mbrtoc16(&c16, "", 1, NULL) == 0); + ATF_REQUIRE(c16 == 0); /* Null wide character. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "", 1, &s) == 0); - assert(c16 == 0); + ATF_REQUIRE(mbrtoc16(&c16, "", 1, &s) == 0); + ATF_REQUIRE(c16 == 0); /* Latin letter A, internal state. */ - assert(mbrtoc16(NULL, 0, 0, NULL) == 0); - assert(mbrtoc16(&c16, "A", 1, NULL) == 1); - assert(c16 == L'A'); + ATF_REQUIRE(mbrtoc16(NULL, 0, 0, NULL) == 0); + ATF_REQUIRE(mbrtoc16(&c16, "A", 1, NULL) == 1); + ATF_REQUIRE(c16 == L'A'); /* Latin letter A. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "A", 1, &s) == 1); - assert(c16 == L'A'); + ATF_REQUIRE(mbrtoc16(&c16, "A", 1, &s) == 1); + ATF_REQUIRE(c16 == L'A'); /* Incomplete character sequence. */ c16 = L'z'; memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "", 0, &s) == (size_t)-2); - assert(c16 == L'z'); + ATF_REQUIRE(mbrtoc16(&c16, "", 0, &s) == (size_t)-2); + ATF_REQUIRE(c16 == L'z'); /* Check that mbrtoc16() doesn't access the buffer when n == 0. */ c16 = L'z'; memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "", 0, &s) == (size_t)-2); - assert(c16 == L'z'); + ATF_REQUIRE(mbrtoc16(&c16, "", 0, &s) == (size_t)-2); + ATF_REQUIRE(c16 == L'z'); /* Check that mbrtoc16() doesn't read ahead too aggressively. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "AB", 2, &s) == 1); - assert(c16 == L'A'); - assert(mbrtoc16(&c16, "C", 1, &s) == 1); - assert(c16 == L'C'); + ATF_REQUIRE(mbrtoc16(&c16, "AB", 2, &s) == 1); + ATF_REQUIRE(c16 == L'A'); + ATF_REQUIRE(mbrtoc16(&c16, "C", 1, &s) == 1); + ATF_REQUIRE(c16 == L'C'); /* * ISO-8859-1. */ - assert(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-1"), + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-1"), "en_US.ISO8859-1") == 0); /* Currency sign. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "\xa4", 1, &s) == 1); - assert(c16 == 0xa4); + ATF_REQUIRE(mbrtoc16(&c16, "\xa4", 1, &s) == 1); + ATF_REQUIRE(c16 == 0xa4); /* * ISO-8859-15. */ - assert(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-15"), + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "en_US.ISO8859-15"), "en_US.ISO8859-15") == 0); /* Euro sign. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "\xa4", 1, &s) == 1); - assert(c16 == 0x20ac); + ATF_REQUIRE(mbrtoc16(&c16, "\xa4", 1, &s) == 1); + ATF_REQUIRE(c16 == 0x20ac); /* * UTF-8. */ - assert(strcmp(setlocale(LC_CTYPE, "en_US.UTF-8"), "en_US.UTF-8") == 0); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "en_US.UTF-8"), "en_US.UTF-8") == 0); /* Null wide character, internal state. */ - assert(mbrtoc16(NULL, 0, 0, NULL) == 0); - assert(mbrtoc16(&c16, "", 1, NULL) == 0); - assert(c16 == 0); + ATF_REQUIRE(mbrtoc16(NULL, 0, 0, NULL) == 0); + ATF_REQUIRE(mbrtoc16(&c16, "", 1, NULL) == 0); + ATF_REQUIRE(c16 == 0); /* Null wide character. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "", 1, &s) == 0); - assert(c16 == 0); + ATF_REQUIRE(mbrtoc16(&c16, "", 1, &s) == 0); + ATF_REQUIRE(c16 == 0); /* Latin letter A, internal state. */ - assert(mbrtoc16(NULL, 0, 0, NULL) == 0); - assert(mbrtoc16(&c16, "A", 1, NULL) == 1); - assert(c16 == L'A'); + ATF_REQUIRE(mbrtoc16(NULL, 0, 0, NULL) == 0); + ATF_REQUIRE(mbrtoc16(&c16, "A", 1, NULL) == 1); + ATF_REQUIRE(c16 == L'A'); /* Latin letter A. */ memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "A", 1, &s) == 1); - assert(c16 == L'A'); + ATF_REQUIRE(mbrtoc16(&c16, "A", 1, &s) == 1); + ATF_REQUIRE(c16 == L'A'); /* Incomplete character sequence (zero length). */ c16 = L'z'; memset(&s, 0, sizeof(s)); - assert(mbrtoc16(&c16, "", 0, &s) == (size_t)-2); - assert(c16 == L'z'); + ATF_REQUIRE(mbrtoc16(&c16, "", 0, &s) == (size_t)-2); + ATF_REQUIRE(c16 == L'z'); /* Incomplete character sequence (truncated double-byte). */ memset(&s, 0, sizeof(s)); c16 = 0; - assert(mbrtoc16(&c16, "\xc3", 1, &s) == (size_t)-2); + ATF_REQUIRE(mbrtoc16(&c16, "\xc3", 1, &s) == (size_t)-2); /* Same as above, but complete. */ memset(&s, 0, sizeof(s)); c16 = 0; - assert(mbrtoc16(&c16, "\xc3\x84", 2, &s) == 2); - assert(c16 == 0xc4); + ATF_REQUIRE(mbrtoc16(&c16, "\xc3\x84", 2, &s) == 2); + ATF_REQUIRE(c16 == 0xc4); /* Test restarting behaviour. */ memset(&s, 0, sizeof(s)); c16 = 0; - assert(mbrtoc16(&c16, "\xc3", 1, &s) == (size_t)-2); - assert(c16 == 0); - assert(mbrtoc16(&c16, "\xb7", 1, &s) == 1); - assert(c16 == 0xf7); + ATF_REQUIRE(mbrtoc16(&c16, "\xc3", 1, &s) == (size_t)-2); + ATF_REQUIRE(c16 == 0); + ATF_REQUIRE(mbrtoc16(&c16, "\xb7", 1, &s) == 1); + ATF_REQUIRE(c16 == 0xf7); /* Surrogate pair. */ memset(&s, 0, sizeof(s)); c16 = 0; - assert(mbrtoc16(&c16, "\xf0\x9f\x92\xa9", 4, &s) == 4); - assert(c16 == 0xd83d); - assert(mbrtoc16(&c16, "", 0, &s) == (size_t)-3); - assert(c16 == 0xdca9); + ATF_REQUIRE(mbrtoc16(&c16, "\xf0\x9f\x92\xa9", 4, &s) == 4); + ATF_REQUIRE(c16 == 0xd83d); + ATF_REQUIRE(mbrtoc16(&c16, "", 0, &s) == (size_t)-3); + ATF_REQUIRE(c16 == 0xdca9); /* Letter e with acute, precomposed. */ memset(&s, 0, sizeof(s)); c16 = 0; - assert(mbrtoc16(&c16, "\xc3\xa9", 2, &s) == 2); - assert(c16 == 0xe9); + ATF_REQUIRE(mbrtoc16(&c16, "\xc3\xa9", 2, &s) == 2); + ATF_REQUIRE(c16 == 0xe9); /* Letter e with acute, combined. */ memset(&s, 0, sizeof(s)); c16 = 0; - assert(mbrtoc16(&c16, "\x65\xcc\x81", 3, &s) == 1); - assert(c16 == 0x65); - assert(mbrtoc16(&c16, "\xcc\x81", 2, &s) == 2); - assert(c16 == 0x301); - - printf("ok 1 - mbrtoc16()\n"); - - return (0); + ATF_REQUIRE(mbrtoc16(&c16, "\x65\xcc\x81", 3, &s) == 1); + ATF_REQUIRE(c16 == 0x65); + ATF_REQUIRE(mbrtoc16(&c16, "\xcc\x81", 2, &s) == 2); + ATF_REQUIRE(c16 == 0x301); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbrtoc16_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbrtowc.c b/lib/libc/tests/locale/mbrtowc_test.c similarity index 67% rename from tools/regression/lib/libc/locale/test-mbrtowc.c rename to lib/libc/tests/locale/mbrtowc_test.c index e9a2ea0bfab3..802c7d1015d7 100644 --- a/tools/regression/lib/libc/locale/test-mbrtowc.c +++ b/lib/libc/tests/locale/mbrtowc_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,8 +43,10 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbrtowc_test); +ATF_TC_BODY(mbrtowc_test, tc) { mbstate_t s; size_t len; @@ -58,78 +59,78 @@ main(int argc, char *argv[]) printf("1..1\n"); - assert(MB_CUR_MAX == 1); + ATF_REQUIRE(MB_CUR_MAX == 1); /* Null wide character, internal state. */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0; - assert(mbrtowc(&wc, buf, 1, NULL) == 0); - assert(wc == 0); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, NULL) == 0); + ATF_REQUIRE(wc == 0); /* Null wide character. */ memset(&s, 0, sizeof(s)); - assert(mbrtowc(&wc, buf, 1, &s) == 0); - assert(wc == 0); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == 0); + ATF_REQUIRE(wc == 0); /* Latin letter A, internal state. */ - assert(mbrtowc(NULL, 0, 0, NULL) == 0); + ATF_REQUIRE(mbrtowc(NULL, 0, 0, NULL) == 0); buf[0] = 'A'; - assert(mbrtowc(&wc, buf, 1, NULL) == 1); - assert(wc == L'A'); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, NULL) == 1); + ATF_REQUIRE(wc == L'A'); /* Latin letter A. */ memset(&s, 0, sizeof(s)); - assert(mbrtowc(&wc, buf, 1, &s) == 1); - assert(wc == L'A'); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == 1); + ATF_REQUIRE(wc == L'A'); /* Incomplete character sequence. */ wc = L'z'; memset(&s, 0, sizeof(s)); - assert(mbrtowc(&wc, buf, 0, &s) == (size_t)-2); - assert(wc == L'z'); + ATF_REQUIRE(mbrtowc(&wc, buf, 0, &s) == (size_t)-2); + ATF_REQUIRE(wc == L'z'); /* Check that mbrtowc() doesn't access the buffer when n == 0. */ wc = L'z'; memset(&s, 0, sizeof(s)); buf[0] = '\0'; - assert(mbrtowc(&wc, buf, 0, &s) == (size_t)-2); - assert(wc == L'z'); + ATF_REQUIRE(mbrtowc(&wc, buf, 0, &s) == (size_t)-2); + ATF_REQUIRE(wc == L'z'); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); /* Null wide character, internal state. */ - assert(mbrtowc(NULL, 0, 0, NULL) == 0); + ATF_REQUIRE(mbrtowc(NULL, 0, 0, NULL) == 0); memset(buf, 0xcc, sizeof(buf)); buf[0] = 0; - assert(mbrtowc(&wc, buf, 1, NULL) == 0); - assert(wc == 0); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, NULL) == 0); + ATF_REQUIRE(wc == 0); /* Null wide character. */ memset(&s, 0, sizeof(s)); - assert(mbrtowc(&wc, buf, 1, &s) == 0); - assert(wc == 0); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == 0); + ATF_REQUIRE(wc == 0); /* Latin letter A, internal state. */ - assert(mbrtowc(NULL, 0, 0, NULL) == 0); + ATF_REQUIRE(mbrtowc(NULL, 0, 0, NULL) == 0); buf[0] = 'A'; - assert(mbrtowc(&wc, buf, 1, NULL) == 1); - assert(wc == L'A'); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, NULL) == 1); + ATF_REQUIRE(wc == L'A'); /* Latin letter A. */ memset(&s, 0, sizeof(s)); - assert(mbrtowc(&wc, buf, 1, &s) == 1); - assert(wc == L'A'); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == 1); + ATF_REQUIRE(wc == L'A'); /* Incomplete character sequence (zero length). */ wc = L'z'; memset(&s, 0, sizeof(s)); - assert(mbrtowc(&wc, buf, 0, &s) == (size_t)-2); - assert(wc == L'z'); + ATF_REQUIRE(mbrtowc(&wc, buf, 0, &s) == (size_t)-2); + ATF_REQUIRE(wc == L'z'); /* Incomplete character sequence (truncated double-byte). */ memset(buf, 0xcc, sizeof(buf)); @@ -137,27 +138,31 @@ main(int argc, char *argv[]) buf[1] = 0x00; memset(&s, 0, sizeof(s)); wc = 0; - assert(mbrtowc(&wc, buf, 1, &s) == (size_t)-2); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == (size_t)-2); /* Same as above, but complete. */ buf[1] = 0xc1; memset(&s, 0, sizeof(s)); wc = 0; - assert(mbrtowc(&wc, buf, 2, &s) == 2); - assert(wc == 0xa3c1); + ATF_REQUIRE(mbrtowc(&wc, buf, 2, &s) == 2); + ATF_REQUIRE(wc == 0xa3c1); /* Test restarting behaviour. */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0xa3; memset(&s, 0, sizeof(s)); wc = 0; - assert(mbrtowc(&wc, buf, 1, &s) == (size_t)-2); - assert(wc == 0); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == (size_t)-2); + ATF_REQUIRE(wc == 0); buf[0] = 0xc1; - assert(mbrtowc(&wc, buf, 1, &s) == 1); - assert(wc == 0xa3c1); - - printf("ok 1 - mbrtowc()\n"); - - return (0); + ATF_REQUIRE(mbrtowc(&wc, buf, 1, &s) == 1); + ATF_REQUIRE(wc == 0xa3c1); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbrtowc_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbsnrtowcs.c b/lib/libc/tests/locale/mbsnrtowcs_test.c similarity index 66% rename from tools/regression/lib/libc/locale/test-mbsnrtowcs.c rename to lib/libc/tests/locale/mbsnrtowcs_test.c index 585dd4eb116b..4012b7e99720 100644 --- a/tools/regression/lib/libc/locale/test-mbsnrtowcs.c +++ b/lib/libc/tests/locale/mbsnrtowcs_test.c @@ -34,7 +34,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -43,19 +42,17 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbsnrtowcs_test); +ATF_TC_BODY(mbsnrtowcs_test, tc) { char srcbuf[128]; wchar_t dstbuf[128]; char *src; mbstate_t s; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); + /* C/POSIX locale. */ /* Simple null terminated string. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -63,11 +60,11 @@ main(int argc, char *argv[]) wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 6, sizeof(dstbuf) / + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 6, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 5); - assert(wcscmp(dstbuf, L"hello") == 0); - assert(dstbuf[6] == 0xcccc); - assert(src == NULL); + ATF_REQUIRE(wcscmp(dstbuf, L"hello") == 0); + ATF_REQUIRE(dstbuf[6] == 0xcccc); + ATF_REQUIRE(src == NULL); /* Simple null terminated string, stopping early. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -75,11 +72,11 @@ main(int argc, char *argv[]) wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 4, sizeof(dstbuf) / + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 4, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 4); - assert(wmemcmp(dstbuf, L"hell", 4) == 0); - assert(dstbuf[5] == 0xcccc); - assert(src == srcbuf + 4); + ATF_REQUIRE(wmemcmp(dstbuf, L"hell", 4) == 0); + ATF_REQUIRE(dstbuf[5] == 0xcccc); + ATF_REQUIRE(src == srcbuf + 4); /* Not enough space in destination buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -87,41 +84,41 @@ main(int argc, char *argv[]) wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 6, 4, &s) == 4); - assert(wmemcmp(dstbuf, L"hell", 4) == 0); - assert(dstbuf[5] == 0xcccc); - assert(src == srcbuf + 4); + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 6, 4, &s) == 4); + ATF_REQUIRE(wmemcmp(dstbuf, L"hell", 4) == 0); + ATF_REQUIRE(dstbuf[5] == 0xcccc); + ATF_REQUIRE(src == srcbuf + 4); /* Null terminated string, internal dest. buffer */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsnrtowcs(NULL, (const char **)&src, 6, 0, &s) == 5); + ATF_REQUIRE(mbsnrtowcs(NULL, (const char **)&src, 6, 0, &s) == 5); /* Null terminated string, internal dest. buffer, stopping early */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsnrtowcs(NULL, (const char **)&src, 4, 0, &s) == 4); + ATF_REQUIRE(mbsnrtowcs(NULL, (const char **)&src, 4, 0, &s) == 4); /* Null terminated string, internal state. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; - assert(mbsnrtowcs(dstbuf, (const char **)&src, 6, sizeof(dstbuf) / + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 6, sizeof(dstbuf) / sizeof(*dstbuf), NULL) == 5); - assert(wcscmp(dstbuf, L"hello") == 0); - assert(dstbuf[6] == 0xcccc); - assert(src == NULL); + ATF_REQUIRE(wcscmp(dstbuf, L"hello") == 0); + ATF_REQUIRE(dstbuf[6] == 0xcccc); + ATF_REQUIRE(src == NULL); /* Null terminated string, internal state, internal dest. buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); src = srcbuf; - assert(mbsnrtowcs(NULL, (const char **)&src, 6, 0, NULL) == 5); + ATF_REQUIRE(mbsnrtowcs(NULL, (const char **)&src, 6, 0, NULL) == 5); /* Empty source buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -129,10 +126,10 @@ main(int argc, char *argv[]) src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 1, 1, &s) == 0); - assert(dstbuf[0] == 0); - assert(dstbuf[1] == 0xcccc); - assert(src == NULL); + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 1, 1, &s) == 0); + ATF_REQUIRE(dstbuf[0] == 0); + ATF_REQUIRE(dstbuf[1] == 0xcccc); + ATF_REQUIRE(src == NULL); /* Zero length destination buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -140,36 +137,36 @@ main(int argc, char *argv[]) src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 1, 0, &s) == 0); - assert(dstbuf[0] == 0xcccc); - assert(src == srcbuf); + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 1, 0, &s) == 0); + ATF_REQUIRE(dstbuf[0] == 0xcccc); + ATF_REQUIRE(src == srcbuf); /* Zero length source buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 0, 1, &s) == 0); - assert(dstbuf[0] == 0xcccc); - assert(src == srcbuf); + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 0, 1, &s) == 0); + ATF_REQUIRE(dstbuf[0] == 0xcccc); + ATF_REQUIRE(src == srcbuf); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "\xA3\xC1 B \xA3\xC3"); src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 8, sizeof(dstbuf) / + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 8, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 5); - assert(dstbuf[0] == 0xA3C1 && dstbuf[1] == 0x20 && dstbuf[2] == 0x42 && + ATF_REQUIRE(dstbuf[0] == 0xA3C1 && dstbuf[1] == 0x20 && dstbuf[2] == 0x42 && dstbuf[3] == 0x20 && dstbuf[4] == 0xA3C3 && dstbuf[5] == 0); - assert(src == NULL); + ATF_REQUIRE(src == NULL); /* Partial character. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -177,18 +174,22 @@ main(int argc, char *argv[]) src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 6, sizeof(dstbuf) / + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 6, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 4); - assert(src == srcbuf + 6); - assert(!mbsinit(&s)); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 1, sizeof(dstbuf) / + ATF_REQUIRE(src == srcbuf + 6); + ATF_REQUIRE(!mbsinit(&s)); + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 1, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 1); - assert(src == srcbuf + 7); - assert(mbsnrtowcs(dstbuf, (const char **)&src, 1, sizeof(dstbuf) / + ATF_REQUIRE(src == srcbuf + 7); + ATF_REQUIRE(mbsnrtowcs(dstbuf, (const char **)&src, 1, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 0); - assert(src == NULL); - - printf("ok 1 - mbsnrtowcs()\n"); - - return (0); + ATF_REQUIRE(src == NULL); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbsnrtowcs_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbsrtowcs.c b/lib/libc/tests/locale/mbsrtowcs_test.c similarity index 71% rename from tools/regression/lib/libc/locale/test-mbsrtowcs.c rename to lib/libc/tests/locale/mbsrtowcs_test.c index dd6a7e10c02c..3f39fc76cdd4 100644 --- a/tools/regression/lib/libc/locale/test-mbsrtowcs.c +++ b/lib/libc/tests/locale/mbsrtowcs_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,8 +43,10 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbsrtowcs_test); +ATF_TC_BODY(mbsrtowcs_test, tc) { char srcbuf[128]; wchar_t dstbuf[128]; @@ -64,11 +65,11 @@ main(int argc, char *argv[]) wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsrtowcs(dstbuf, (const char **)&src, sizeof(dstbuf) / + ATF_REQUIRE(mbsrtowcs(dstbuf, (const char **)&src, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 5); - assert(wcscmp(dstbuf, L"hello") == 0); - assert(dstbuf[6] == 0xcccc); - assert(src == NULL); + ATF_REQUIRE(wcscmp(dstbuf, L"hello") == 0); + ATF_REQUIRE(dstbuf[6] == 0xcccc); + ATF_REQUIRE(src == NULL); /* Not enough space in destination buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -76,34 +77,34 @@ main(int argc, char *argv[]) wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsrtowcs(dstbuf, (const char **)&src, 4, &s) == 4); - assert(wmemcmp(dstbuf, L"hell", 4) == 0); - assert(dstbuf[5] == 0xcccc); - assert(src == srcbuf + 4); + ATF_REQUIRE(mbsrtowcs(dstbuf, (const char **)&src, 4, &s) == 4); + ATF_REQUIRE(wmemcmp(dstbuf, L"hell", 4) == 0); + ATF_REQUIRE(dstbuf[5] == 0xcccc); + ATF_REQUIRE(src == srcbuf + 4); /* Null terminated string, internal dest. buffer */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(mbsrtowcs(NULL, (const char **)&src, 0, &s) == 5); + ATF_REQUIRE(mbsrtowcs(NULL, (const char **)&src, 0, &s) == 5); /* Null terminated string, internal state. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); src = srcbuf; - assert(mbsrtowcs(dstbuf, (const char **)&src, sizeof(dstbuf) / + ATF_REQUIRE(mbsrtowcs(dstbuf, (const char **)&src, sizeof(dstbuf) / sizeof(*dstbuf), NULL) == 5); - assert(wcscmp(dstbuf, L"hello") == 0); - assert(dstbuf[6] == 0xcccc); - assert(src == NULL); + ATF_REQUIRE(wcscmp(dstbuf, L"hello") == 0); + ATF_REQUIRE(dstbuf[6] == 0xcccc); + ATF_REQUIRE(src == NULL); /* Null terminated string, internal state, internal dest. buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); src = srcbuf; - assert(mbsrtowcs(NULL, (const char **)&src, 0, NULL) == 5); + ATF_REQUIRE(mbsrtowcs(NULL, (const char **)&src, 0, NULL) == 5); /* Empty source buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -111,10 +112,10 @@ main(int argc, char *argv[]) src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsrtowcs(dstbuf, (const char **)&src, 1, &s) == 0); - assert(dstbuf[0] == 0); - assert(dstbuf[1] == 0xcccc); - assert(src == NULL); + ATF_REQUIRE(mbsrtowcs(dstbuf, (const char **)&src, 1, &s) == 0); + ATF_REQUIRE(dstbuf[0] == 0); + ATF_REQUIRE(dstbuf[1] == 0xcccc); + ATF_REQUIRE(src == NULL); /* Zero length destination buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); @@ -122,29 +123,33 @@ main(int argc, char *argv[]) src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsrtowcs(dstbuf, (const char **)&src, 0, &s) == 0); - assert(dstbuf[0] == 0xcccc); - assert(src == srcbuf); + ATF_REQUIRE(mbsrtowcs(dstbuf, (const char **)&src, 0, &s) == 0); + ATF_REQUIRE(dstbuf[0] == 0xcccc); + ATF_REQUIRE(src == srcbuf); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "\xA3\xC1 B \xA3\xC3"); src = srcbuf; memset(&s, 0, sizeof(s)); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbsrtowcs(dstbuf, (const char **)&src, sizeof(dstbuf) / + ATF_REQUIRE(mbsrtowcs(dstbuf, (const char **)&src, sizeof(dstbuf) / sizeof(*dstbuf), &s) == 5); - assert(dstbuf[0] == 0xA3C1 && dstbuf[1] == 0x20 && dstbuf[2] == 0x42 && + ATF_REQUIRE(dstbuf[0] == 0xA3C1 && dstbuf[1] == 0x20 && dstbuf[2] == 0x42 && dstbuf[3] == 0x20 && dstbuf[4] == 0xA3C3 && dstbuf[5] == 0); - assert(src == NULL); - - printf("ok 1 - mbsrtowcs()\n"); - - return (0); + ATF_REQUIRE(src == NULL); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbsrtowcs_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbstowcs.c b/lib/libc/tests/locale/mbstowcs_test.c similarity index 73% rename from tools/regression/lib/libc/locale/test-mbstowcs.c rename to lib/libc/tests/locale/mbstowcs_test.c index 18039dd9e66c..77b0e9e52f35 100644 --- a/tools/regression/lib/libc/locale/test-mbstowcs.c +++ b/lib/libc/tests/locale/mbstowcs_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,69 +43,69 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbstowcs_test); +ATF_TC_BODY(mbstowcs_test, tc) { char srcbuf[128]; wchar_t dstbuf[128]; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); + /* C/POSIX locale. */ /* Simple null terminated string. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbstowcs(dstbuf, srcbuf, sizeof(dstbuf) / sizeof(*dstbuf)) == 5); - assert(wcscmp(dstbuf, L"hello") == 0); - assert(dstbuf[6] == 0xcccc); + ATF_REQUIRE(mbstowcs(dstbuf, srcbuf, sizeof(dstbuf) / sizeof(*dstbuf)) == 5); + ATF_REQUIRE(wcscmp(dstbuf, L"hello") == 0); + ATF_REQUIRE(dstbuf[6] == 0xcccc); /* Not enough space in destination buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbstowcs(dstbuf, srcbuf, 4) == 4); - assert(wmemcmp(dstbuf, L"hell", 4) == 0); - assert(dstbuf[5] == 0xcccc); + ATF_REQUIRE(mbstowcs(dstbuf, srcbuf, 4) == 4); + ATF_REQUIRE(wmemcmp(dstbuf, L"hell", 4) == 0); + ATF_REQUIRE(dstbuf[5] == 0xcccc); /* Null terminated string, internal dest. buffer (XSI extension) */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); - assert(mbstowcs(NULL, srcbuf, 0) == 5); + ATF_REQUIRE(mbstowcs(NULL, srcbuf, 0) == 5); /* Empty source buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); srcbuf[0] = '\0'; wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbstowcs(dstbuf, srcbuf, 1) == 0); - assert(dstbuf[0] == 0); - assert(dstbuf[1] == 0xcccc); + ATF_REQUIRE(mbstowcs(dstbuf, srcbuf, 1) == 0); + ATF_REQUIRE(dstbuf[0] == 0); + ATF_REQUIRE(dstbuf[1] == 0xcccc); /* Zero length destination buffer. */ memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "hello"); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbstowcs(dstbuf, srcbuf, 0) == 0); - assert(dstbuf[0] == 0xcccc); + ATF_REQUIRE(mbstowcs(dstbuf, srcbuf, 0) == 0); + ATF_REQUIRE(dstbuf[0] == 0xcccc); - /* - * Japanese (EUC) locale. - */ + /* Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); memset(srcbuf, 0xcc, sizeof(srcbuf)); strcpy(srcbuf, "\xA3\xC1 B \xA3\xC3"); wmemset(dstbuf, 0xcccc, sizeof(dstbuf) / sizeof(*dstbuf)); - assert(mbstowcs(dstbuf, srcbuf, sizeof(dstbuf) / sizeof(*dstbuf)) == 5); - assert(dstbuf[0] == 0xA3C1 && dstbuf[1] == 0x20 && dstbuf[2] == 0x42 && + ATF_REQUIRE(mbstowcs(dstbuf, srcbuf, sizeof(dstbuf) / sizeof(*dstbuf)) == 5); + ATF_REQUIRE(dstbuf[0] == 0xA3C1 && dstbuf[1] == 0x20 && dstbuf[2] == 0x42 && dstbuf[3] == 0x20 && dstbuf[4] == 0xA3C3 && dstbuf[5] == 0); - - printf("ok 1 - mbstowcs()\n"); - - return (0); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbstowcs_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-mbtowc.c b/lib/libc/tests/locale/mbtowc_test.c similarity index 69% rename from tools/regression/lib/libc/locale/test-mbtowc.c rename to lib/libc/tests/locale/mbtowc_test.c index 5ee070c57e26..1f64fe1c4b19 100644 --- a/tools/regression/lib/libc/locale/test-mbtowc.c +++ b/lib/libc/tests/locale/mbtowc_test.c @@ -35,90 +35,89 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(mbtowc_test); +ATF_TC_BODY(mbtowc_test, tc) { size_t len; wchar_t wc; char buf[MB_LEN_MAX + 1]; - /* - * C/POSIX locale. - */ + /* C/POSIX locale. */ - printf("1..1\n"); - - assert(MB_CUR_MAX == 1); + ATF_REQUIRE(MB_CUR_MAX == 1); /* No shift states in C locale. */ - assert(mbtowc(NULL, NULL, 0) == 0); + ATF_REQUIRE(mbtowc(NULL, NULL, 0) == 0); /* Null wide character. */ wc = 0xcccc; memset(buf, 0, sizeof(buf)); - assert(mbtowc(&wc, buf, 1) == 0); - assert(wc == 0); + ATF_REQUIRE(mbtowc(&wc, buf, 1) == 0); + ATF_REQUIRE(wc == 0); /* Latin letter A. */ buf[0] = 'A'; - assert(mbtowc(&wc, buf, 1) == 1); - assert(wc == L'A'); + ATF_REQUIRE(mbtowc(&wc, buf, 1) == 1); + ATF_REQUIRE(wc == L'A'); /* Incomplete character sequence. */ wc = L'z'; buf[0] = '\0'; - assert(mbtowc(&wc, buf, 0) == -1); - assert(wc == L'z'); - assert(mbtowc(NULL, NULL, 0) == 0); + ATF_REQUIRE(mbtowc(&wc, buf, 0) == -1); + ATF_REQUIRE(wc == L'z'); + ATF_REQUIRE(mbtowc(NULL, NULL, 0) == 0); - /* - * Japanese (EUC) locale. - */ + /* Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); /* Null wide character */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0; wc = 0xcccc; - assert(mbtowc(&wc, buf, 1) == 0); - assert(wc == 0); + ATF_REQUIRE(mbtowc(&wc, buf, 1) == 0); + ATF_REQUIRE(wc == 0); /* Latin letter A. */ buf[0] = 'A'; - assert(mbtowc(&wc, buf, 1) == 1); - assert(wc == L'A'); + ATF_REQUIRE(mbtowc(&wc, buf, 1) == 1); + ATF_REQUIRE(wc == L'A'); /* Incomplete character sequence (zero length). */ wc = L'z'; buf[0] = '\0'; - assert(mbtowc(&wc, buf, 0) == -1); - assert(wc == L'z'); - assert(mbtowc(NULL, NULL, 0) == 0); + ATF_REQUIRE(mbtowc(&wc, buf, 0) == -1); + ATF_REQUIRE(wc == L'z'); + ATF_REQUIRE(mbtowc(NULL, NULL, 0) == 0); /* Incomplete character sequence (truncated double-byte). */ memset(buf, 0xcc, sizeof(buf)); buf[0] = 0xa3; buf[1] = 0x00; wc = L'z'; - assert(mbtowc(&wc, buf, 1) == -1); - assert(wc == L'z'); - assert(mbtowc(NULL, NULL, 0) == 0); + ATF_REQUIRE(mbtowc(&wc, buf, 1) == -1); + ATF_REQUIRE(wc == L'z'); + ATF_REQUIRE(mbtowc(NULL, NULL, 0) == 0); /* Same as above, but complete. */ buf[1] = 0xc1; - assert(mbtowc(&wc, buf, 2) == 2); - assert(wc == 0xa3c1); - - printf("ok 1 - mbtowc()\n"); - - return (0); + ATF_REQUIRE(mbtowc(&wc, buf, 2) == 2); + ATF_REQUIRE(wc == 0xa3c1); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, mbtowc_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-towctrans.c b/lib/libc/tests/locale/towctrans_test.c similarity index 79% rename from tools/regression/lib/libc/locale/test-towctrans.c rename to lib/libc/tests/locale/towctrans_test.c index fabb343bc6d9..bb9d97ca2e54 100644 --- a/tools/regression/lib/libc/locale/test-towctrans.c +++ b/lib/libc/tests/locale/towctrans_test.c @@ -34,15 +34,16 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(towctrans_test); +ATF_TC_BODY(towctrans_test, tc) { wctype_t t; int i, j; @@ -54,39 +55,36 @@ main(int argc, char *argv[]) { "toupper", towupper }, }; - printf("1..2\n"); - - /* - * C/POSIX locale. - */ + /* C/POSIX locale. */ for (i = 0; i < sizeof(tran) / sizeof(*tran); i++) { t = wctrans(tran[i].name); - assert(t != 0); + ATF_REQUIRE(t != 0); for (j = 0; j < 256; j++) - assert(tran[i].func(j) == towctrans(j, t)); + ATF_REQUIRE(tran[i].func(j) == towctrans(j, t)); } t = wctrans("elephant"); - assert(t == 0); + ATF_REQUIRE(t == 0); for (i = 0; i < 256; i++) - assert(towctrans(i, t) == i); + ATF_REQUIRE(towctrans(i, t) == i); - /* - * Japanese (EUC) locale. - */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + /* Japanese (EUC) locale. */ + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); for (i = 0; i < sizeof(tran) / sizeof(*tran); i++) { t = wctrans(tran[i].name); - assert(t != 0); + ATF_REQUIRE(t != 0); for (j = 0; j < 65536; j++) - assert(tran[i].func(j) == towctrans(j, t)); + ATF_REQUIRE(tran[i].func(j) == towctrans(j, t)); } t = wctrans("elephant"); - assert(t == 0); + ATF_REQUIRE(t == 0); for (i = 0; i < 65536; i++) - assert(towctrans(i, t) == i); - - printf("ok 1 - towctrans()\n"); - printf("ok 2 - wctrans()\n"); - - return (0); + ATF_REQUIRE(towctrans(i, t) == i); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, towctrans_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-wcrtomb.c b/lib/libc/tests/locale/wcrtomb_test.c similarity index 69% rename from tools/regression/lib/libc/locale/test-wcrtomb.c rename to lib/libc/tests/locale/wcrtomb_test.c index d7ec029e8c68..09199ba97c99 100644 --- a/tools/regression/lib/libc/locale/test-wcrtomb.c +++ b/lib/libc/tests/locale/wcrtomb_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,91 +43,93 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(wcrtomb_test); +ATF_TC_BODY(wcrtomb_test, tc) { mbstate_t s; size_t len; char buf[MB_LEN_MAX + 1]; - /* - * C/POSIX locale. - */ + /* C/POSIX locale. */ - printf("1..1\n"); - - assert(MB_CUR_MAX == 1); + ATF_REQUIRE(MB_CUR_MAX == 1); /* * If the buffer argument is NULL, wc is implicitly L'\0', * wcrtomb() resets its internal state. */ - assert(wcrtomb(NULL, L'\0', NULL) == 1); - assert(wcrtomb(NULL, UCHAR_MAX + 1, NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, L'\0', NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, UCHAR_MAX + 1, NULL) == 1); /* Null wide character. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); len = wcrtomb(buf, L'\0', &s); - assert(len == 1); - assert((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); /* Latin letter A, internal state. */ - assert(wcrtomb(NULL, L'\0', NULL) == 1); - assert(wcrtomb(NULL, L'A', NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, L'\0', NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, L'A', NULL) == 1); /* Latin letter A. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); len = wcrtomb(buf, L'A', &s); - assert(len == 1); - assert((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); /* Invalid code. */ - assert(wcrtomb(buf, UCHAR_MAX + 1, NULL) == (size_t)-1); - assert(errno == EILSEQ); + ATF_REQUIRE(wcrtomb(buf, UCHAR_MAX + 1, NULL) == (size_t)-1); + ATF_REQUIRE(errno == EILSEQ); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX == 3); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX == 3); /* * If the buffer argument is NULL, wc is implicitly L'\0', * wcrtomb() resets its internal state. */ - assert(wcrtomb(NULL, L'\0', NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, L'\0', NULL) == 1); /* Null wide character. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); len = wcrtomb(buf, L'\0', &s); - assert(len == 1); - assert((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); /* Latin letter A, internal state. */ - assert(wcrtomb(NULL, L'\0', NULL) == 1); - assert(wcrtomb(NULL, L'A', NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, L'\0', NULL) == 1); + ATF_REQUIRE(wcrtomb(NULL, L'A', NULL) == 1); /* Latin letter A. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); len = wcrtomb(buf, L'A', &s); - assert(len == 1); - assert((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); /* Full width letter A. */ memset(&s, 0, sizeof(s)); memset(buf, 0xcc, sizeof(buf)); len = wcrtomb(buf, 0xa3c1, &s); - assert(len == 2); - assert((unsigned char)buf[0] == 0xa3 && + ATF_REQUIRE(len == 2); + ATF_REQUIRE((unsigned char)buf[0] == 0xa3 && (unsigned char)buf[1] == 0xc1 && (unsigned char)buf[2] == 0xcc); - - printf("ok 1 - wcrtomb()\n"); - - return (0); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, wcrtomb_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-wcsnrtombs.c b/lib/libc/tests/locale/wcsnrtombs_test.c similarity index 67% rename from tools/regression/lib/libc/locale/test-wcsnrtombs.c rename to lib/libc/tests/locale/wcsnrtombs_test.c index 2290cac06784..2e330a10ad83 100644 --- a/tools/regression/lib/libc/locale/test-wcsnrtombs.c +++ b/lib/libc/tests/locale/wcsnrtombs_test.c @@ -34,7 +34,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -43,19 +42,17 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(wcsnrtombs_test); +ATF_TC_BODY(wcsnrtombs_test, tc) { wchar_t srcbuf[128]; char dstbuf[128]; wchar_t *src; mbstate_t s; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); + /* C/POSIX locale. */ /* Simple null terminated string. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -63,11 +60,11 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, sizeof(dstbuf), &s) == 5); - assert(strcmp(dstbuf, "hello") == 0); - assert((unsigned char)dstbuf[6] == 0xcc); - assert(src == NULL); + ATF_REQUIRE(strcmp(dstbuf, "hello") == 0); + ATF_REQUIRE((unsigned char)dstbuf[6] == 0xcc); + ATF_REQUIRE(src == NULL); /* Simple null terminated string, stopping early. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -75,11 +72,11 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 4, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 4, sizeof(dstbuf), &s) == 4); - assert(memcmp(dstbuf, "hell", 4) == 0); - assert((unsigned char)dstbuf[5] == 0xcc); - assert(src == srcbuf + 4); + ATF_REQUIRE(memcmp(dstbuf, "hell", 4) == 0); + ATF_REQUIRE((unsigned char)dstbuf[5] == 0xcc); + ATF_REQUIRE(src == srcbuf + 4); /* Not enough space in destination buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -87,18 +84,18 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, 4, + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, 4, &s) == 4); - assert(memcmp(dstbuf, "hell", 4) == 0); - assert((unsigned char)dstbuf[5] == 0xcc); - assert(src == srcbuf + 4); + ATF_REQUIRE(memcmp(dstbuf, "hell", 4) == 0); + ATF_REQUIRE((unsigned char)dstbuf[5] == 0xcc); + ATF_REQUIRE(src == srcbuf + 4); /* Null terminated string, internal dest. buffer */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(NULL, (const wchar_t **)&src, 6, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(NULL, (const wchar_t **)&src, 6, sizeof(dstbuf), &s) == 5); /* Null terminated string, internal dest. buffer, stopping early. */ @@ -106,7 +103,7 @@ main(int argc, char *argv[]) wcscpy(srcbuf, L"hello"); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(NULL, (const wchar_t **)&src, 4, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(NULL, (const wchar_t **)&src, 4, sizeof(dstbuf), &s) == 4); /* Null terminated string, internal state. */ @@ -114,17 +111,17 @@ main(int argc, char *argv[]) wcscpy(srcbuf, L"hello"); memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, sizeof(dstbuf), NULL) == 5); - assert(strcmp(dstbuf, "hello") == 0); - assert((unsigned char)dstbuf[6] == 0xcc); - assert(src == NULL); + ATF_REQUIRE(strcmp(dstbuf, "hello") == 0); + ATF_REQUIRE((unsigned char)dstbuf[6] == 0xcc); + ATF_REQUIRE(src == NULL); /* Null terminated string, internal state, internal dest. buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); src = srcbuf; - assert(wcsnrtombs(NULL, (const wchar_t **)&src, 6, 0, NULL) == 5); + ATF_REQUIRE(wcsnrtombs(NULL, (const wchar_t **)&src, 6, 0, NULL) == 5); /* Empty source buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -132,9 +129,9 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 1, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 1, sizeof(dstbuf), &s) == 0); - assert(dstbuf[0] == L'\0'); + ATF_REQUIRE(dstbuf[0] == L'\0'); /* Zero length destination buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -142,25 +139,25 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, 0, &s) == 0); - assert((unsigned char)dstbuf[0] == 0xcc); + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, 0, &s) == 0); + ATF_REQUIRE((unsigned char)dstbuf[0] == 0xcc); /* Zero length source buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 0, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 0, sizeof(dstbuf), &s) == 0); - assert((unsigned char)dstbuf[0] == 0xcc); - assert(src == srcbuf); + ATF_REQUIRE((unsigned char)dstbuf[0] == 0xcc); + ATF_REQUIRE(src == srcbuf); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); srcbuf[0] = 0xA3C1; @@ -172,23 +169,27 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, sizeof(dstbuf), + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, sizeof(dstbuf), &s) == 7); - assert(strcmp(dstbuf, "\xA3\xC1 B \xA3\xC3") == 0); - assert((unsigned char)dstbuf[8] == 0xcc); - assert(src == NULL); + ATF_REQUIRE(strcmp(dstbuf, "\xA3\xC1 B \xA3\xC3") == 0); + ATF_REQUIRE((unsigned char)dstbuf[8] == 0xcc); + ATF_REQUIRE(src == NULL); /* Stopping early. */ memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, 6, + ATF_REQUIRE(wcsnrtombs(dstbuf, (const wchar_t **)&src, 6, 6, &s) == 5); - assert(memcmp(dstbuf, "\xA3\xC1 B ", 5) == 0); - assert((unsigned char)dstbuf[5] == 0xcc); - assert(src == srcbuf + 4); - - printf("ok 1 - wcsnrtombs()\n"); - - return (0); + ATF_REQUIRE(memcmp(dstbuf, "\xA3\xC1 B ", 5) == 0); + ATF_REQUIRE((unsigned char)dstbuf[5] == 0xcc); + ATF_REQUIRE(src == srcbuf + 4); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, wcsnrtombs_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-wcsrtombs.c b/lib/libc/tests/locale/wcsrtombs_test.c similarity index 71% rename from tools/regression/lib/libc/locale/test-wcsrtombs.c rename to lib/libc/tests/locale/wcsrtombs_test.c index 48fe3668f5a6..4c3455a87769 100644 --- a/tools/regression/lib/libc/locale/test-wcsrtombs.c +++ b/lib/libc/tests/locale/wcsrtombs_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,19 +43,17 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(wcsrtombs_test); +ATF_TC_BODY(wcsrtombs_test, tc) { wchar_t srcbuf[128]; char dstbuf[128]; wchar_t *src; mbstate_t s; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); + /* C/POSIX locale. */ /* Simple null terminated string. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -64,11 +61,11 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), + ATF_REQUIRE(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), &s) == 5); - assert(strcmp(dstbuf, "hello") == 0); - assert((unsigned char)dstbuf[6] == 0xcc); - assert(src == NULL); + ATF_REQUIRE(strcmp(dstbuf, "hello") == 0); + ATF_REQUIRE((unsigned char)dstbuf[6] == 0xcc); + ATF_REQUIRE(src == NULL); /* Not enough space in destination buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -76,18 +73,18 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsrtombs(dstbuf, (const wchar_t **)&src, 4, + ATF_REQUIRE(wcsrtombs(dstbuf, (const wchar_t **)&src, 4, &s) == 4); - assert(memcmp(dstbuf, "hell", 4) == 0); - assert((unsigned char)dstbuf[5] == 0xcc); - assert(src == srcbuf + 4); + ATF_REQUIRE(memcmp(dstbuf, "hell", 4) == 0); + ATF_REQUIRE((unsigned char)dstbuf[5] == 0xcc); + ATF_REQUIRE(src == srcbuf + 4); /* Null terminated string, internal dest. buffer */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsrtombs(NULL, (const wchar_t **)&src, sizeof(dstbuf), + ATF_REQUIRE(wcsrtombs(NULL, (const wchar_t **)&src, sizeof(dstbuf), &s) == 5); /* Null terminated string, internal state. */ @@ -95,17 +92,17 @@ main(int argc, char *argv[]) wcscpy(srcbuf, L"hello"); memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; - assert(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), + ATF_REQUIRE(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), NULL) == 5); - assert(strcmp(dstbuf, "hello") == 0); - assert((unsigned char)dstbuf[6] == 0xcc); - assert(src == NULL); + ATF_REQUIRE(strcmp(dstbuf, "hello") == 0); + ATF_REQUIRE((unsigned char)dstbuf[6] == 0xcc); + ATF_REQUIRE(src == NULL); /* Null terminated string, internal state, internal dest. buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); src = srcbuf; - assert(wcsrtombs(NULL, (const wchar_t **)&src, 0, NULL) == 5); + ATF_REQUIRE(wcsrtombs(NULL, (const wchar_t **)&src, 0, NULL) == 5); /* Empty source buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -113,9 +110,9 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), + ATF_REQUIRE(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), &s) == 0); - assert(dstbuf[0] == L'\0'); + ATF_REQUIRE(dstbuf[0] == L'\0'); /* Zero length destination buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); @@ -123,15 +120,15 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsrtombs(dstbuf, (const wchar_t **)&src, 0, &s) == 0); - assert((unsigned char)dstbuf[0] == 0xcc); + ATF_REQUIRE(wcsrtombs(dstbuf, (const wchar_t **)&src, 0, &s) == 0); + ATF_REQUIRE((unsigned char)dstbuf[0] == 0xcc); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); srcbuf[0] = 0xA3C1; @@ -143,13 +140,17 @@ main(int argc, char *argv[]) memset(dstbuf, 0xcc, sizeof(dstbuf)); src = srcbuf; memset(&s, 0, sizeof(s)); - assert(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), + ATF_REQUIRE(wcsrtombs(dstbuf, (const wchar_t **)&src, sizeof(dstbuf), &s) == 7); - assert(strcmp(dstbuf, "\xA3\xC1 B \xA3\xC3") == 0); - assert((unsigned char)dstbuf[8] == 0xcc); - assert(src == NULL); - - printf("ok 1 - wcsrtombs()\n"); - - return (0); + ATF_REQUIRE(strcmp(dstbuf, "\xA3\xC1 B \xA3\xC3") == 0); + ATF_REQUIRE((unsigned char)dstbuf[8] == 0xcc); + ATF_REQUIRE(src == NULL); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, wcsrtombs_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-wcstombs.c b/lib/libc/tests/locale/wcstombs_test.c similarity index 72% rename from tools/regression/lib/libc/locale/test-wcstombs.c rename to lib/libc/tests/locale/wcstombs_test.c index f4a57700f7c4..f3fcd81001f1 100644 --- a/tools/regression/lib/libc/locale/test-wcstombs.c +++ b/lib/libc/tests/locale/wcstombs_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -44,72 +43,70 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(wcstombs_test); +ATF_TC_BODY(wcstombs_test, tc) { wchar_t srcbuf[128]; char dstbuf[128]; - /* - * C/POSIX locale. - */ - - printf("1..1\n"); + /* C/POSIX locale. */ /* Simple null terminated string. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); memset(dstbuf, 0xcc, sizeof(dstbuf)); - assert(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 5); - assert(strcmp(dstbuf, "hello") == 0); - assert((unsigned char)dstbuf[6] == 0xcc); + ATF_REQUIRE(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 5); + ATF_REQUIRE(strcmp(dstbuf, "hello") == 0); + ATF_REQUIRE((unsigned char)dstbuf[6] == 0xcc); /* Not enough space in destination buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); memset(dstbuf, 0xcc, sizeof(dstbuf)); - assert(wcstombs(dstbuf, srcbuf, 4) == 4); - assert(memcmp(dstbuf, "hell", 4) == 0); - assert((unsigned char)dstbuf[5] == 0xcc); + ATF_REQUIRE(wcstombs(dstbuf, srcbuf, 4) == 4); + ATF_REQUIRE(memcmp(dstbuf, "hell", 4) == 0); + ATF_REQUIRE((unsigned char)dstbuf[5] == 0xcc); /* Null terminated string, internal dest. buffer */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); - assert(wcstombs(NULL, srcbuf, sizeof(dstbuf)) == 5); + ATF_REQUIRE(wcstombs(NULL, srcbuf, sizeof(dstbuf)) == 5); /* Null terminated string, internal state. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); memset(dstbuf, 0xcc, sizeof(dstbuf)); - assert(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 5); - assert(strcmp(dstbuf, "hello") == 0); - assert((unsigned char)dstbuf[6] == 0xcc); + ATF_REQUIRE(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 5); + ATF_REQUIRE(strcmp(dstbuf, "hello") == 0); + ATF_REQUIRE((unsigned char)dstbuf[6] == 0xcc); /* Null terminated string, internal state, internal dest. buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); - assert(wcstombs(NULL, srcbuf, 0) == 5); + ATF_REQUIRE(wcstombs(NULL, srcbuf, 0) == 5); /* Empty source buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); srcbuf[0] = L'\0'; memset(dstbuf, 0xcc, sizeof(dstbuf)); - assert(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 0); - assert(dstbuf[0] == L'\0'); + ATF_REQUIRE(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 0); + ATF_REQUIRE(dstbuf[0] == L'\0'); /* Zero length destination buffer. */ wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); wcscpy(srcbuf, L"hello"); memset(dstbuf, 0xcc, sizeof(dstbuf)); - assert(wcstombs(dstbuf, srcbuf, 0) == 0); - assert((unsigned char)dstbuf[0] == 0xcc); + ATF_REQUIRE(wcstombs(dstbuf, srcbuf, 0) == 0); + ATF_REQUIRE((unsigned char)dstbuf[0] == 0xcc); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX > 1); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX > 1); wmemset(srcbuf, 0xcc, sizeof(srcbuf) / sizeof(*srcbuf)); srcbuf[0] = 0xA3C1; @@ -119,11 +116,15 @@ main(int argc, char *argv[]) srcbuf[4] = 0xA3C3; srcbuf[5] = 0x0000; memset(dstbuf, 0xcc, sizeof(dstbuf)); - assert(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 7); - assert(strcmp(dstbuf, "\xA3\xC1 B \xA3\xC3") == 0); - assert((unsigned char)dstbuf[8] == 0xcc); - - printf("ok 1 - wcstombs()\n"); - - return (0); + ATF_REQUIRE(wcstombs(dstbuf, srcbuf, sizeof(dstbuf)) == 7); + ATF_REQUIRE(strcmp(dstbuf, "\xA3\xC1 B \xA3\xC3") == 0); + ATF_REQUIRE((unsigned char)dstbuf[8] == 0xcc); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, wcstombs_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/test-wctomb.c b/lib/libc/tests/locale/wctomb_test.c similarity index 71% rename from tools/regression/lib/libc/locale/test-wctomb.c rename to lib/libc/tests/locale/wctomb_test.c index d55b3db9ec4d..255cda432d7d 100644 --- a/tools/regression/lib/libc/locale/test-wctomb.c +++ b/lib/libc/tests/locale/wctomb_test.c @@ -35,7 +35,6 @@ #include __FBSDID("$FreeBSD$"); -#include #include #include #include @@ -43,70 +42,72 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(wctomb_test); +ATF_TC_BODY(wctomb_test, tc) { size_t len; char buf[MB_LEN_MAX + 1]; - /* - * C/POSIX locale. - */ + /* C/POSIX locale. */ - printf("1..1\n"); - - assert(MB_CUR_MAX == 1); + ATF_REQUIRE(MB_CUR_MAX == 1); /* No shift states in C locale. */ - assert(wctomb(NULL, L'\0') == 0); + ATF_REQUIRE(wctomb(NULL, L'\0') == 0); /* Null wide character. */ memset(buf, 0xcc, sizeof(buf)); len = wctomb(buf, L'\0'); - assert(len == 1); - assert((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); /* Latin letter A. */ memset(buf, 0xcc, sizeof(buf)); len = wctomb(buf, L'A'); - assert(len == 1); - assert((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); /* Invalid code. */ - assert(wctomb(buf, UCHAR_MAX + 1) == -1); - assert(wctomb(NULL, 0) == 0); + ATF_REQUIRE(wctomb(buf, UCHAR_MAX + 1) == -1); + ATF_REQUIRE(wctomb(NULL, 0) == 0); /* * Japanese (EUC) locale. */ - assert(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); - assert(MB_CUR_MAX == 3); + ATF_REQUIRE(strcmp(setlocale(LC_CTYPE, "ja_JP.eucJP"), "ja_JP.eucJP") == 0); + ATF_REQUIRE(MB_CUR_MAX == 3); /* No shift states in EUC encoding. */ - assert(wctomb(NULL, L'\0') == 0); + ATF_REQUIRE(wctomb(NULL, L'\0') == 0); /* Null wide character. */ memset(buf, 0xcc, sizeof(buf)); len = wctomb(buf, L'\0'); - assert(len == 1); - assert((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 0 && (unsigned char)buf[1] == 0xcc); /* Latin letter A. */ memset(buf, 0xcc, sizeof(buf)); len = wctomb(buf, L'A'); - assert(len == 1); - assert((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); + ATF_REQUIRE(len == 1); + ATF_REQUIRE((unsigned char)buf[0] == 'A' && (unsigned char)buf[1] == 0xcc); /* Full width letter A. */ memset(buf, 0xcc, sizeof(buf)); len = wctomb(buf, 0xa3c1); - assert(len == 2); - assert((unsigned char)buf[0] == 0xa3 && + ATF_REQUIRE(len == 2); + ATF_REQUIRE((unsigned char)buf[0] == 0xa3 && (unsigned char)buf[1] == 0xc1 && (unsigned char)buf[2] == 0xcc); - - printf("ok 1 - wctomb()\n"); - - return (0); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, wctomb_test); + + return (atf_no_error()); } diff --git a/tools/regression/lib/libc/locale/Makefile b/tools/regression/lib/libc/locale/Makefile deleted file mode 100644 index ebbd537801cd..000000000000 --- a/tools/regression/lib/libc/locale/Makefile +++ /dev/null @@ -1,27 +0,0 @@ -# $FreeBSD$ - -TESTS= test-mbrtowc \ - test-wcrtomb \ - test-mbsnrtowcs \ - test-mbsrtowcs \ - test-wcsnrtombs \ - test-wcsrtombs \ - test-btowc \ - test-mbrlen \ - test-mbtowc \ - test-wctomb \ - test-mbstowcs \ - test-wcstombs \ - test-mblen \ - test-iswctype \ - test-towctrans \ - test-c16rtomb \ - test-mbrtoc16 - -.PHONY: tests -tests: ${TESTS} - for p in ${TESTS}; do ${.OBJDIR}/$$p; done - -.PHONY: clean -clean: - -rm -f ${TESTS} diff --git a/tools/regression/lib/libc/locale/test-btowc.t b/tools/regression/lib/libc/locale/test-btowc.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-btowc.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-iswctype.t b/tools/regression/lib/libc/locale/test-iswctype.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-iswctype.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mblen.t b/tools/regression/lib/libc/locale/test-mblen.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mblen.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mbrlen.t b/tools/regression/lib/libc/locale/test-mbrlen.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mbrlen.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mbrtowc.t b/tools/regression/lib/libc/locale/test-mbrtowc.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mbrtowc.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mbsnrtowcs.t b/tools/regression/lib/libc/locale/test-mbsnrtowcs.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mbsnrtowcs.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mbsrtowcs.t b/tools/regression/lib/libc/locale/test-mbsrtowcs.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mbsrtowcs.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mbstowcs.t b/tools/regression/lib/libc/locale/test-mbstowcs.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mbstowcs.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-mbtowc.t b/tools/regression/lib/libc/locale/test-mbtowc.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-mbtowc.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-towctrans.t b/tools/regression/lib/libc/locale/test-towctrans.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-towctrans.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-wcrtomb.t b/tools/regression/lib/libc/locale/test-wcrtomb.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-wcrtomb.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-wcsnrtombs.t b/tools/regression/lib/libc/locale/test-wcsnrtombs.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-wcsnrtombs.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-wcsrtombs.t b/tools/regression/lib/libc/locale/test-wcsrtombs.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-wcsrtombs.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-wcstombs.t b/tools/regression/lib/libc/locale/test-wcstombs.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-wcstombs.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable diff --git a/tools/regression/lib/libc/locale/test-wctomb.t b/tools/regression/lib/libc/locale/test-wctomb.t deleted file mode 100644 index 8bdfd03be81b..000000000000 --- a/tools/regression/lib/libc/locale/test-wctomb.t +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh -# $FreeBSD$ - -cd `dirname $0` - -executable=`basename $0 .t` - -make $executable 2>&1 > /dev/null - -exec ./$executable