From owner-svn-src-head@freebsd.org Sun Nov 8 07:53:32 2015 Return-Path: Delivered-To: svn-src-head@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id D24C3A29230; Sun, 8 Nov 2015 07:53:32 +0000 (UTC) (envelope-from ngie@FreeBSD.org) Received: from repo.freebsd.org (repo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 89750181B; Sun, 8 Nov 2015 07:53:32 +0000 (UTC) (envelope-from ngie@FreeBSD.org) Received: from repo.freebsd.org ([127.0.1.37]) by repo.freebsd.org (8.15.2/8.15.2) with ESMTP id tA87rV7H072800; Sun, 8 Nov 2015 07:53:31 GMT (envelope-from ngie@FreeBSD.org) Received: (from ngie@localhost) by repo.freebsd.org (8.15.2/8.15.2/Submit) id tA87rVa4072795; Sun, 8 Nov 2015 07:53:31 GMT (envelope-from ngie@FreeBSD.org) Message-Id: <201511080753.tA87rVa4072795@repo.freebsd.org> X-Authentication-Warning: repo.freebsd.org: ngie set sender to ngie@FreeBSD.org using -f From: Garrett Cooper Date: Sun, 8 Nov 2015 07:53:31 +0000 (UTC) To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r290539 - in head: lib/libc/tests/string tools/regression/lib/libc/string X-SVN-Group: head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-head@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: SVN commit messages for the src tree for head/-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 08 Nov 2015 07:53:33 -0000 Author: ngie Date: Sun Nov 8 07:53:31 2015 New Revision: 290539 URL: https://svnweb.freebsd.org/changeset/base/290539 Log: Integrate tools/regression/lib/libc/string into the FreeBSD test suite as lib/libc/tests/string MFC after: 1 week Sponsored by: EMC / Isilon Storage Division Added: head/lib/libc/tests/string/stpncpy_test.c - copied, changed from r290538, head/tools/regression/lib/libc/string/test-stpncpy.c head/lib/libc/tests/string/strerror_test.c - copied, changed from r290538, head/tools/regression/lib/libc/string/test-strerror.c head/lib/libc/tests/string/wcscasecmp_test.c - copied, changed from r290538, head/tools/regression/lib/libc/string/test-wcscasecmp.c head/lib/libc/tests/string/wcsnlen_test.c - copied, changed from r290538, head/tools/regression/lib/libc/string/test-wcsnlen.c Deleted: head/tools/regression/lib/libc/string/ Modified: head/lib/libc/tests/string/Makefile Modified: head/lib/libc/tests/string/Makefile ============================================================================== --- head/lib/libc/tests/string/Makefile Sun Nov 8 07:03:17 2015 (r290538) +++ head/lib/libc/tests/string/Makefile Sun Nov 8 07:53:31 2015 (r290539) @@ -1,6 +1,9 @@ # $FreeBSD$ -.include +ATF_TESTS_C+= stpncpy_test +ATF_TESTS_C+= strerror2_test +ATF_TESTS_C+= wcscasecmp_test +ATF_TESTS_C+= wcsnlen_test # TODO: popcount, stresep @@ -20,6 +23,8 @@ NETBSD_ATF_TESTS_C+= strrchr_test NETBSD_ATF_TESTS_C+= strspn_test NETBSD_ATF_TESTS_C+= swab_test +SRCS.strerror2_test= strerror_test.c + .include "../Makefile.netbsd-tests" LDADD.memchr_test+= -lmd Copied and modified: head/lib/libc/tests/string/stpncpy_test.c (from r290538, head/tools/regression/lib/libc/string/test-stpncpy.c) ============================================================================== --- head/tools/regression/lib/libc/string/test-stpncpy.c Sun Nov 8 07:03:17 2015 (r290538, copy source) +++ head/lib/libc/tests/string/stpncpy_test.c Sun Nov 8 07:53:31 2015 (r290539) @@ -27,13 +27,15 @@ #include __FBSDID("$FreeBSD$"); -#include #include +#include #include #include #include #include +#include + static char * makebuf(size_t len, int guard_at_end) { @@ -76,18 +78,33 @@ test_stpncpy(const char *s) } } -int -main(int argc, char *argv[]) +ATF_TC_WITHOUT_HEAD(nul); +ATF_TC_BODY(nul, tc) { - printf("1..3\n"); - test_stpncpy(""); - printf("ok 1 - stpncpy\n"); +} + +ATF_TC_WITHOUT_HEAD(foo); +ATF_TC_BODY(foo, tc) +{ + test_stpncpy("foo"); - printf("ok 2 - stpncpy\n"); +} + +ATF_TC_WITHOUT_HEAD(glorp); +ATF_TC_BODY(glorp, tc) +{ + test_stpncpy("glorp"); - printf("ok 3 - stpncpy\n"); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, nul); + ATF_TP_ADD_TC(tp, foo); + ATF_TP_ADD_TC(tp, glorp); - exit(0); + return (atf_no_error()); } Copied and modified: head/lib/libc/tests/string/strerror_test.c (from r290538, head/tools/regression/lib/libc/string/test-strerror.c) ============================================================================== --- head/tools/regression/lib/libc/string/test-strerror.c Sun Nov 8 07:03:17 2015 (r290538, copy source) +++ head/lib/libc/tests/string/strerror_test.c Sun Nov 8 07:53:31 2015 (r290539) @@ -33,115 +33,174 @@ #include #include -static int test_count = 1; -static int exit_status = EXIT_SUCCESS; +#include + +static char buf[64]; +static char *sret; +static int iret; + +ATF_TC_WITHOUT_HEAD(strerror_unknown_error); +ATF_TC_BODY(strerror_unknown_error, tc) +{ -#define CHECK(x) \ - do { \ - if (x) { \ - printf("ok %d\n", test_count); \ - } else { \ - printf("not ok %d # %s\n", test_count, #x); \ - exit_status = EXIT_FAILURE; \ - } \ - ++test_count; \ - } while (0) - -int -main(void) -{ - char buf[64]; - char *sret; - int iret; - - printf("1..27\n"); - - /* - * strerror() failure tests. - */ errno = 0; sret = strerror(INT_MAX); snprintf(buf, sizeof(buf), "Unknown error: %d", INT_MAX); - CHECK(strcmp(sret, buf) == 0); - CHECK(errno == EINVAL); + ATF_CHECK(strcmp(sret, buf) == 0); + ATF_CHECK(errno == EINVAL); +} + +ATF_TC_WITHOUT_HEAD(strerror_no_error); +ATF_TC_BODY(strerror_no_error, tc) +{ - /* - * strerror() success tests. - */ errno = 0; sret = strerror(0); - CHECK(strcmp(sret, "No error: 0") == 0); - CHECK(errno == 0); + ATF_CHECK(strcmp(sret, "No error: 0") == 0); + ATF_CHECK(errno == 0); +} + +ATF_TC_WITHOUT_HEAD(strerror_EPERM_test); +ATF_TC_BODY(strerror_EPERM_test, tc) +{ errno = 0; sret = strerror(EPERM); - CHECK(strcmp(sret, "Operation not permitted") == 0); - CHECK(errno == 0); + ATF_CHECK(strcmp(sret, "Operation not permitted") == 0); + ATF_CHECK(errno == 0); +} + +ATF_TC_WITHOUT_HEAD(strerror_EPFNOSUPPORT_test); +ATF_TC_BODY(strerror_EPFNOSUPPORT_test, tc) +{ errno = 0; sret = strerror(EPFNOSUPPORT); - CHECK(strcmp(sret, "Protocol family not supported") == 0); - CHECK(errno == 0); + ATF_CHECK(strcmp(sret, "Protocol family not supported") == 0); + ATF_CHECK(errno == 0); +} + +ATF_TC_WITHOUT_HEAD(strerror_ELAST_test); +ATF_TC_BODY(strerror_ELAST_test, tc) +{ errno = 0; sret = strerror(ELAST); - CHECK(errno == 0); + ATF_CHECK(errno == 0); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__unknown_error); +ATF_TC_BODY(strerror_r__unknown_error, tc) +{ - /* - * strerror_r() failure tests. - */ memset(buf, '*', sizeof(buf)); iret = strerror_r(-1, buf, sizeof(buf)); - CHECK(strcmp(buf, "Unknown error: -1") == 0); - CHECK(iret == EINVAL); + ATF_CHECK(strcmp(buf, "Unknown error: -1") == 0); + ATF_CHECK(iret == EINVAL); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EPERM_one_byte_short); +ATF_TC_BODY(strerror_r__EPERM_one_byte_short, tc) +{ memset(buf, '*', sizeof(buf)); /* One byte too short. */ iret = strerror_r(EPERM, buf, strlen("Operation not permitted")); - CHECK(strcmp(buf, "Operation not permitte") == 0); - CHECK(iret == ERANGE); + ATF_CHECK(strcmp(buf, "Operation not permitte") == 0); + ATF_CHECK(iret == ERANGE); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EPERM_unknown_error_one_byte_short); +ATF_TC_BODY(strerror_r__EPERM_unknown_error_one_byte_short, tc) +{ memset(buf, '*', sizeof(buf)); /* One byte too short. */ iret = strerror_r(-1, buf, strlen("Unknown error: -1")); - CHECK(strcmp(buf, "Unknown error: -") == 0); - CHECK(iret == EINVAL); + ATF_CHECK(strcmp(buf, "Unknown error: -") == 0); + ATF_CHECK(iret == EINVAL); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EPERM_unknown_error_two_bytes_short); +ATF_TC_BODY(strerror_r__EPERM_unknown_error_two_bytes_short, tc) +{ memset(buf, '*', sizeof(buf)); /* Two bytes too short. */ iret = strerror_r(-2, buf, strlen("Unknown error: -2") - 1); - CHECK(strcmp(buf, "Unknown error: ") == 0); - CHECK(iret == EINVAL); + ATF_CHECK(strcmp(buf, "Unknown error: ") == 0); + ATF_CHECK(iret == EINVAL); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EPERM_unknown_error_three_bytes_short); +ATF_TC_BODY(strerror_r__EPERM_unknown_error_three_bytes_short, tc) +{ memset(buf, '*', sizeof(buf)); /* Three bytes too short. */ iret = strerror_r(-2, buf, strlen("Unknown error: -2") - 2); - CHECK(strcmp(buf, "Unknown error:") == 0); - CHECK(iret == EINVAL); + ATF_CHECK(strcmp(buf, "Unknown error:") == 0); + ATF_CHECK(iret == EINVAL); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EPERM_unknown_error_12345_one_byte_short); +ATF_TC_BODY(strerror_r__EPERM_unknown_error_12345_one_byte_short, tc) +{ memset(buf, '*', sizeof(buf)); /* One byte too short. */ iret = strerror_r(12345, buf, strlen("Unknown error: 12345")); - CHECK(strcmp(buf, "Unknown error: 1234") == 0); - CHECK(iret == EINVAL); + ATF_CHECK(strcmp(buf, "Unknown error: 1234") == 0); + ATF_CHECK(iret == EINVAL); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__no_error); +ATF_TC_BODY(strerror_r__no_error, tc) +{ - /* - * strerror_r() success tests. - */ memset(buf, '*', sizeof(buf)); iret = strerror_r(0, buf, sizeof(buf)); - CHECK(strcmp(buf, "No error: 0") == 0); - CHECK(iret == 0); + ATF_CHECK(strcmp(buf, "No error: 0") == 0); + ATF_CHECK(iret == 0); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EDEADLK); +ATF_TC_BODY(strerror_r__EDEADLK, tc) +{ memset(buf, '*', sizeof(buf)); iret = strerror_r(EDEADLK, buf, sizeof(buf)); - CHECK(strcmp(buf, "Resource deadlock avoided") == 0); - CHECK(iret == 0); + ATF_CHECK(strcmp(buf, "Resource deadlock avoided") == 0); + ATF_CHECK(iret == 0); +} + +ATF_TC_WITHOUT_HEAD(strerror_r__EPROCLIM); +ATF_TC_BODY(strerror_r__EPROCLIM, tc) +{ memset(buf, '*', sizeof(buf)); iret = strerror_r(EPROCLIM, buf, sizeof(buf)); - CHECK(strcmp(buf, "Too many processes") == 0); - CHECK(iret == 0); + ATF_CHECK(strcmp(buf, "Too many processes") == 0); + ATF_CHECK(iret == 0); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, strerror_unknown_error); + ATF_TP_ADD_TC(tp, strerror_no_error); + ATF_TP_ADD_TC(tp, strerror_EPERM_test); + ATF_TP_ADD_TC(tp, strerror_EPFNOSUPPORT_test); + ATF_TP_ADD_TC(tp, strerror_ELAST_test); + ATF_TP_ADD_TC(tp, strerror_r__unknown_error); + ATF_TP_ADD_TC(tp, strerror_r__EPERM_one_byte_short); + ATF_TP_ADD_TC(tp, strerror_r__EPERM_unknown_error_one_byte_short); + ATF_TP_ADD_TC(tp, strerror_r__EPERM_unknown_error_two_bytes_short); + ATF_TP_ADD_TC(tp, strerror_r__EPERM_unknown_error_three_bytes_short); + ATF_TP_ADD_TC(tp, strerror_r__EPERM_unknown_error_12345_one_byte_short); + ATF_TP_ADD_TC(tp, strerror_r__no_error); + ATF_TP_ADD_TC(tp, strerror_r__EDEADLK); + ATF_TP_ADD_TC(tp, strerror_r__EPROCLIM); - return exit_status; + return (atf_no_error()); } Copied and modified: head/lib/libc/tests/string/wcscasecmp_test.c (from r290538, head/tools/regression/lib/libc/string/test-wcscasecmp.c) ============================================================================== --- head/tools/regression/lib/libc/string/test-wcscasecmp.c Sun Nov 8 07:03:17 2015 (r290538, copy source) +++ head/lib/libc/tests/string/wcscasecmp_test.c Sun Nov 8 07:53:31 2015 (r290539) @@ -34,55 +34,95 @@ __FBSDID("$FreeBSD$"); #include #include -int -main(int argc, char *argv[]) +#include + +ATF_TC_WITHOUT_HEAD(nul); +ATF_TC_BODY(nul, tc) +{ + + ATF_REQUIRE(setlocale(LC_CTYPE, "C") != NULL); + + ATF_CHECK(wcscasecmp(L"", L"") == 0); + ATF_CHECK(wcsncasecmp(L"", L"", 50) == 0); + ATF_CHECK(wcsncasecmp(L"", L"", 0) == 0); +} + +ATF_TC_WITHOUT_HEAD(wcscasecmp_equal); +ATF_TC_BODY(wcscasecmp_equal, tc) { - printf("1..6\n"); + ATF_REQUIRE(setlocale(LC_CTYPE, "C") != NULL); + + ATF_CHECK(wcscasecmp(L"abc", L"abc") == 0); + ATF_CHECK(wcscasecmp(L"ABC", L"ABC") == 0); + ATF_CHECK(wcscasecmp(L"abc", L"ABC") == 0); + ATF_CHECK(wcscasecmp(L"ABC", L"abc") == 0); +} + +ATF_TC_WITHOUT_HEAD(wcscasecmp_same_len_buffers); +ATF_TC_BODY(wcscasecmp_same_len_buffers, tc) +{ + + ATF_REQUIRE(setlocale(LC_CTYPE, "C") != NULL); + + ATF_CHECK(wcscasecmp(L"abc", L"xyz") < 0); + ATF_CHECK(wcscasecmp(L"ABC", L"xyz") < 0); + ATF_CHECK(wcscasecmp(L"abc", L"XYZ") < 0); + ATF_CHECK(wcscasecmp(L"ABC", L"XYZ") < 0); + ATF_CHECK(wcscasecmp(L"xyz", L"abc") > 0); + ATF_CHECK(wcscasecmp(L"XYZ", L"abc") > 0); + ATF_CHECK(wcscasecmp(L"xyz", L"ABC") > 0); + ATF_CHECK(wcscasecmp(L"XYZ", L"ABC") > 0); +} + +ATF_TC_WITHOUT_HEAD(wcscasecmp_mismatched_len_buffers); +ATF_TC_BODY(wcscasecmp_mismatched_len_buffers, tc) +{ - setlocale(LC_CTYPE, "C"); + ATF_REQUIRE(setlocale(LC_CTYPE, "C") != NULL); + + ATF_CHECK(wcscasecmp(L"abc", L"ABCD") < 0); + ATF_CHECK(wcscasecmp(L"ABC", L"abcd") < 0); + ATF_CHECK(wcscasecmp(L"abcd", L"ABC") > 0); + ATF_CHECK(wcscasecmp(L"ABCD", L"abc") > 0); +} + +ATF_TC_WITHOUT_HEAD(wcsncasecmp); +ATF_TC_BODY(wcsncasecmp, tc) +{ + + ATF_REQUIRE(setlocale(LC_CTYPE, "C") != NULL); + + ATF_CHECK(wcsncasecmp(L"abc", L"ABCD", 4) < 0); + ATF_CHECK(wcsncasecmp(L"ABC", L"abcd", 4) < 0); + ATF_CHECK(wcsncasecmp(L"abcd", L"ABC", 4) > 0); + ATF_CHECK(wcsncasecmp(L"ABCD", L"abc", 4) > 0); + ATF_CHECK(wcsncasecmp(L"abc", L"ABCD", 3) == 0); + ATF_CHECK(wcsncasecmp(L"ABC", L"abcd", 3) == 0); +} + +ATF_TC_WITHOUT_HEAD(wcscasecmp_greek); +ATF_TC_BODY(wcscasecmp_greek, tc) +{ + + ATF_REQUIRE(setlocale(LC_CTYPE, "C") != NULL); + + ATF_CHECK(wcscasecmp(L"λ", L"Λ") != 0); + ATF_REQUIRE(setlocale(LC_CTYPE, "el_GR.UTF-8") != NULL); + ATF_CHECK(wcscasecmp(L"λ", L"Λ") == 0); + ATF_CHECK(wcscasecmp(L"λ", L"Ω") < 0); + ATF_CHECK(wcscasecmp(L"Ω", L"λ") > 0); +} + +ATF_TP_ADD_TCS(tp) +{ - assert(wcscasecmp(L"", L"") == 0); - assert(wcsncasecmp(L"", L"", 50) == 0); - assert(wcsncasecmp(L"", L"", 0) == 0); - printf("ok 1 - wcscasecmp\n"); - - assert(wcscasecmp(L"abc", L"abc") == 0); - assert(wcscasecmp(L"ABC", L"ABC") == 0); - assert(wcscasecmp(L"abc", L"ABC") == 0); - assert(wcscasecmp(L"ABC", L"abc") == 0); - printf("ok 2 - wcscasecmp\n"); - - assert(wcscasecmp(L"abc", L"xyz") < 0); - assert(wcscasecmp(L"ABC", L"xyz") < 0); - assert(wcscasecmp(L"abc", L"XYZ") < 0); - assert(wcscasecmp(L"ABC", L"XYZ") < 0); - assert(wcscasecmp(L"xyz", L"abc") > 0); - assert(wcscasecmp(L"XYZ", L"abc") > 0); - assert(wcscasecmp(L"xyz", L"ABC") > 0); - assert(wcscasecmp(L"XYZ", L"ABC") > 0); - printf("ok 3 - wcscasecmp\n"); - - assert(wcscasecmp(L"abc", L"ABCD") < 0); - assert(wcscasecmp(L"ABC", L"abcd") < 0); - assert(wcscasecmp(L"abcd", L"ABC") > 0); - assert(wcscasecmp(L"ABCD", L"abc") > 0); - printf("ok 4 - wcscasecmp\n"); - - assert(wcsncasecmp(L"abc", L"ABCD", 4) < 0); - assert(wcsncasecmp(L"ABC", L"abcd", 4) < 0); - assert(wcsncasecmp(L"abcd", L"ABC", 4) > 0); - assert(wcsncasecmp(L"ABCD", L"abc", 4) > 0); - assert(wcsncasecmp(L"abc", L"ABCD", 3) == 0); - assert(wcsncasecmp(L"ABC", L"abcd", 3) == 0); - printf("ok 5 - wcsncasecmp\n"); - - assert(wcscasecmp(L"λ", L"Λ") != 0); - setlocale(LC_CTYPE, "el_GR.UTF-8"); - assert(wcscasecmp(L"λ", L"Λ") == 0); - assert(wcscasecmp(L"λ", L"Ω") < 0); - assert(wcscasecmp(L"Ω", L"λ") > 0); - printf("ok 6 - greek\n"); + ATF_TP_ADD_TC(tp, nul); + ATF_TP_ADD_TC(tp, wcscasecmp_equal); + ATF_TP_ADD_TC(tp, wcscasecmp_same_len_buffers); + ATF_TP_ADD_TC(tp, wcscasecmp_mismatched_len_buffers); + ATF_TP_ADD_TC(tp, wcsncasecmp); + ATF_TP_ADD_TC(tp, wcscasecmp_greek); - exit(0); + return (atf_no_error()); } Copied and modified: head/lib/libc/tests/string/wcsnlen_test.c (from r290538, head/tools/regression/lib/libc/string/test-wcsnlen.c) ============================================================================== --- head/tools/regression/lib/libc/string/test-wcsnlen.c Sun Nov 8 07:03:17 2015 (r290538, copy source) +++ head/lib/libc/tests/string/wcsnlen_test.c Sun Nov 8 07:53:31 2015 (r290539) @@ -27,14 +27,16 @@ #include __FBSDID("$FreeBSD$"); -#include #include +#include #include #include #include #include #include +#include + static void * makebuf(size_t len, int guard_at_end) { @@ -42,12 +44,12 @@ makebuf(size_t len, int guard_at_end) size_t alloc_size = roundup2(len, PAGE_SIZE) + PAGE_SIZE; buf = mmap(NULL, alloc_size, PROT_READ | PROT_WRITE, MAP_ANON, -1, 0); - assert(buf); + ATF_CHECK(buf); if (guard_at_end) { - assert(munmap(buf + alloc_size - PAGE_SIZE, PAGE_SIZE) == 0); + ATF_CHECK(munmap(buf + alloc_size - PAGE_SIZE, PAGE_SIZE) == 0); return (buf + alloc_size - PAGE_SIZE - len); } else { - assert(munmap(buf, PAGE_SIZE) == 0); + ATF_CHECK(munmap(buf, PAGE_SIZE) == 0); return (buf + PAGE_SIZE); } } @@ -61,27 +63,42 @@ test_wcsnlen(const wchar_t *s) size = wcslen(s) + 1; for (i = 0; i <= 1; i++) { - for (bufsize = 0; bufsize <= size + 10; bufsize++) { - s1 = makebuf(bufsize * sizeof(wchar_t), i); - wmemcpy(s1, s, bufsize); - len = (size > bufsize) ? bufsize : size - 1; - assert(wcsnlen(s1, bufsize) == len); - } + for (bufsize = 0; bufsize <= size + 10; bufsize++) { + s1 = makebuf(bufsize * sizeof(wchar_t), i); + wmemcpy(s1, s, bufsize); + len = (size > bufsize) ? bufsize : size - 1; + ATF_CHECK(wcsnlen(s1, bufsize) == len); + } } } -int -main(int argc, char *argv[]) +ATF_TC_WITHOUT_HEAD(nul); +ATF_TC_BODY(nul, tc) { - printf("1..3\n"); - test_wcsnlen(L""); - printf("ok 1 - wcsnlen\n"); +} + +ATF_TC_WITHOUT_HEAD(foo); +ATF_TC_BODY(foo, tc) +{ + test_wcsnlen(L"foo"); - printf("ok 2 - wcsnlen\n"); +} + +ATF_TC_WITHOUT_HEAD(glorp); +ATF_TC_BODY(glorp, tc) +{ + test_wcsnlen(L"glorp"); - printf("ok 3 - wcsnlen\n"); +} + +ATF_TP_ADD_TCS(tp) +{ + + ATF_TP_ADD_TC(tp, nul); + ATF_TP_ADD_TC(tp, foo); + ATF_TP_ADD_TC(tp, glorp); - exit(0); + return (atf_no_error()); }