From e5492d74d7b1b6c707de71511eac1bb33025a610 Mon Sep 17 00:00:00 2001 From: Bruno Haible Date: Fri, 6 Mar 2009 19:26:14 +0100 Subject: [PATCH] Tests for module 'uninorm/u16-normcmp'. --- ChangeLog | 4 ++ modules/uninorm/u16-normcmp-tests | 14 +++++ tests/uninorm/test-u16-normcmp.c | 111 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 129 insertions(+) create mode 100644 modules/uninorm/u16-normcmp-tests create mode 100644 tests/uninorm/test-u16-normcmp.c diff --git a/ChangeLog b/ChangeLog index 40769ca74..faa9ee489 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,9 @@ 2009-03-06 Bruno Haible + Tests for module 'uninorm/u16-normcmp'. + * tests/uninorm/test-u16-normcmp.c: New file. + * modules/uninorm/u16-normcmp-tests: New file. + Tests for module 'uninorm/u8-normcmp'. * tests/uninorm/test-u8-normcmp.c: New file. * modules/uninorm/u8-normcmp-tests: New file. diff --git a/modules/uninorm/u16-normcmp-tests b/modules/uninorm/u16-normcmp-tests new file mode 100644 index 000000000..83943f259 --- /dev/null +++ b/modules/uninorm/u16-normcmp-tests @@ -0,0 +1,14 @@ +Files: +tests/uninorm/test-u16-normcmp.c + +Depends-on: +uninorm/u16-normcmp +uninorm/nfd + +configure.ac: + +Makefile.am: +TESTS += test-u16-normcmp +check_PROGRAMS += test-u16-normcmp +test_u16_normcmp_SOURCES = uninorm/test-u16-normcmp.c + diff --git a/tests/uninorm/test-u16-normcmp.c b/tests/uninorm/test-u16-normcmp.c new file mode 100644 index 000000000..a1b244154 --- /dev/null +++ b/tests/uninorm/test-u16-normcmp.c @@ -0,0 +1,111 @@ +/* Test of normalization insensitive comparison of UTF-16 strings. + Copyright (C) 2009 Free Software Foundation, Inc. + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . */ + +/* Written by Bruno Haible , 2009. */ + +#include + +#include "uninorm.h" + +#include +#include + +#define SIZEOF(array) (sizeof (array) / sizeof (array[0])) +#define ASSERT(expr) \ + do \ + { \ + if (!(expr)) \ + { \ + fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \ + fflush (stderr); \ + abort (); \ + } \ + } \ + while (0) + +int +main () +{ + /* Empty string. */ + { + int cmp; + + ASSERT (u16_normcmp (NULL, 0, NULL, 0, UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 0); + } + { + static const uint16_t input[] = { 'x', 'y' }; + int cmp; + + ASSERT (u16_normcmp (input, SIZEOF (input), NULL, 0, UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 1); + + ASSERT (u16_normcmp (NULL, 0, input, SIZEOF (input), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == -1); + + ASSERT (u16_normcmp (input, SIZEOF (input), input, SIZEOF (input), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 0); + } + + /* Shorter and longer strings. */ + { + static const uint16_t input1[] = { 'R', 'e', 'a', 'g', 'a', 'n' }; + static const uint16_t input2[] = { 'R', 'e', 'a', 'g', 'a', 'n', 'o', 'm', 'i', 'c', 's' }; + int cmp; + + ASSERT (u16_normcmp (input1, SIZEOF (input1), input2, SIZEOF (input2), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == -1); + + ASSERT (u16_normcmp (input2, SIZEOF (input2), input1, SIZEOF (input1), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 1); + } + + /* Normalization effects. */ + { + static const uint16_t input1[] = { 'H', 0x00F6, 'h', 'l', 'e' }; + static const uint16_t input2[] = { 'H', 'o', 0x0308, 'h', 'l', 'e' }; + static const uint16_t input3[] = { 'H', 0x00F6, 'h', 'l', 'e', 'n' }; + static const uint16_t input4[] = { 'H', 'o', 0x0308, 'h', 'l', 'e', 'n' }; + static const uint16_t input5[] = { 'H', 'u', 'r', 'z' }; + int cmp; + + ASSERT (u16_normcmp (input1, SIZEOF (input1), input2, SIZEOF (input2), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 0); + + ASSERT (u16_normcmp (input2, SIZEOF (input2), input1, SIZEOF (input1), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 0); + + ASSERT (u16_normcmp (input3, SIZEOF (input3), input4, SIZEOF (input4), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 0); + + ASSERT (u16_normcmp (input4, SIZEOF (input4), input3, SIZEOF (input3), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == 0); + + ASSERT (u16_normcmp (input2, SIZEOF (input2), input3, SIZEOF (input3), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == -1); + + ASSERT (u16_normcmp (input1, SIZEOF (input1), input4, SIZEOF (input4), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == -1); + + ASSERT (u16_normcmp (input1, SIZEOF (input1), input5, SIZEOF (input5), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == -1); + + ASSERT (u16_normcmp (input2, SIZEOF (input2), input5, SIZEOF (input5), UNINORM_NFD, &cmp) == 0); + ASSERT (cmp == -1); + } + + return 0; +} -- 2.11.0