Add a simple collation test. This test is expected to fail on HEAD since

we do not yet have a working implementation of wcscoll.
This commit is contained in:
perseant 2017-07-14 14:57:43 +00:00
parent 3d39ee5ed6
commit 4a641438c8
4 changed files with 157 additions and 3 deletions

View File

@ -1,4 +1,4 @@
# $NetBSD: mi,v 1.219 2017/07/11 15:21:31 joerg Exp $
# $NetBSD: mi,v 1.220 2017/07/14 14:57:43 perseant Exp $
./etc/mtree/set.debug comp-sys-root
./usr/lib comp-sys-usr compatdir
./usr/lib/i18n/libBIG5_g.a comp-c-debuglib debuglib,compatfile
@ -1954,6 +1954,7 @@
./usr/libdata/debug/usr/tests/lib/libc/locale/t_mbtowc.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libc/locale/t_sprintf.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libc/locale/t_toupper.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libc/locale/t_wcscoll.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libc/locale/t_wcscspn.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libc/locale/t_wcspbrk.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libc/locale/t_wcsspn.debug tests-lib-debug debug,atf,compattestfile

View File

@ -1,4 +1,4 @@
# $NetBSD: mi,v 1.755 2017/07/11 15:21:32 joerg Exp $
# $NetBSD: mi,v 1.756 2017/07/14 14:57:43 perseant Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@ -2551,6 +2551,7 @@
./usr/tests/lib/libc/locale/t_mbtowc tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/locale/t_sprintf tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/locale/t_toupper tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/locale/t_wcscoll tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/locale/t_wcscspn tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/locale/t_wcspbrk tests-lib-tests compattestfile,atf
./usr/tests/lib/libc/locale/t_wcsspn tests-lib-tests compattestfile,atf

View File

@ -1,4 +1,4 @@
# $NetBSD: Makefile,v 1.9 2017/06/01 15:45:02 perseant Exp $
# $NetBSD: Makefile,v 1.10 2017/07/14 14:57:43 perseant Exp $
.include <bsd.own.mk>
@ -19,6 +19,7 @@ TESTS_C+= t_digittoint
TESTS_C+= t_sprintf
TESTS_C+= t_wctype
TESTS_C+= t_btowc
TESTS_C+= t_wcscoll
COPTS.t_wctomb.c += -Wno-stack-protector
COPTS.t_digittoint.c += -Wno-unused-variable

View File

@ -0,0 +1,151 @@
/* $NetBSD: t_wcscoll.c,v 1.1 2017/07/14 14:57:43 perseant Exp $ */
/*-
* Copyright (c) 2017 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Konrad Schroder.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#include <sys/cdefs.h>
__COPYRIGHT("@(#) Copyright (c) 2017\
The NetBSD Foundation, inc. All rights reserved.");
__RCSID("$NetBSD: t_wcscoll.c,v 1.1 2017/07/14 14:57:43 perseant Exp $");
#include <locale.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <limits.h>
#include <wchar.h>
#include <atf-c.h>
static struct test {
const char *locale;
const wchar_t *in_order[10];
} tests[] = {
{
"C", {
L"A string beginning with a"
L"Capital Letter",
L"always comes before",
L"another beginning lowercase",
L"assuming ASCII of course",
NULL }
} , {
"en_US.UTF-8", {
L"A string beginning with a"
L"Capital Letter",
L"always comes before",
L"another beginning lowercase",
L"assuming ASCII of course",
NULL }
},
/*
* The rest of these examples are from Wikipedia.
*/
{
"de_DE.UTF-8", {
L"Arg",
L"Ärgerlich",
L"Arm",
L"Assistent",
L"Aßlar",
L"Assoziation",
NULL }
}, {
"ru_RU.KOI-8", {
L"едок",
L"ёж",
L"ездить",
NULL }
}, { /* Old-style Spanish collation, expect fail with DUCET */
"es_ES.UTF-8", {
L"cinco",
L"credo",
L"chispa",
L"lomo",
L"luz",
L"llama",
NULL }
}, { /* We don't have Slovak locale files, expect fail */
"sk_SK.UTF-8", {
L"baa",
L"baá",
L"báa",
L"bab",
L"báb",
L"bac",
L"bác",
L"bač",
L"báč",
NULL }
}, {
NULL,
{ NULL }
}
};
static void
h_wcscoll(const struct test *t)
{
const wchar_t * const *wcp;
const wchar_t * const *owcp;
ATF_REQUIRE_STREQ(setlocale(LC_ALL, "C"), "C");
printf("Trying locale %s...\n", t->locale);
ATF_REQUIRE(setlocale(LC_COLLATE, t->locale) != NULL);
printf("Using locale: %s\n", setlocale(LC_ALL, NULL));
for (wcp = &t->in_order[0], owcp = wcp++;
*wcp != NULL; owcp = wcp++) {
printf("Check L\"%S\" < L\"%S\"\n", *owcp, *wcp);
ATF_CHECK(wcscoll(*owcp, *wcp) < 0);
}
}
ATF_TC(wcscoll);
ATF_TC_HEAD(wcscoll, tc)
{
atf_tc_set_md_var(tc, "descr",
"Checks collation using wcscoll(3) under different locales");
}
ATF_TC_BODY(wcscoll, tc)
{
struct test *t;
atf_tc_expect_fail("LC_COLLATE support is not yet fully implemented");
for (t = &tests[0]; t->locale != NULL; ++t)
h_wcscoll(t);
}
ATF_TP_ADD_TCS(tp)
{
ATF_TP_ADD_TC(tp, wcscoll);
return atf_no_error();
}