annotate tests/test-astrxfrm.c @ 16817:7747cb9b54b9

unistd_h: make it easier to avoid sys_types_h This is useful for Emacs, which has its own method of porting to Windows, and which therefore does not need the sys_types_h module. * m4/off_t.m4: New file, defining gl_TYPE_OFF_T, which contains code moved here from gl_SYS_TYPES_H. * m4/sys_types_h.m4 (gl_SYS_TYPES_H): Require it instead of using the code directly. * m4/unistd_h.m4 (gl_UNISTD_H): Require gl_TYPE_OFF_T, not gl_SYS_TYPES_H. * modules/sys_types (Files): * modules/unistd (Files): Add m4/off_t.m4.
author Paul Eggert <eggert@cs.ucla.edu>
date Fri, 04 May 2012 13:05:31 -0700
parents 8250f2777afc
children e542fd46ad6f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
13556
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
1 /* Test of astrxfrm() function.
16201
8250f2777afc maint: update all copyright year number ranges
Jim Meyering <meyering@redhat.com>
parents: 14079
diff changeset
2 Copyright (C) 2010-2012 Free Software Foundation, Inc.
13556
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
3
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
4 This program is free software: you can redistribute it and/or modify
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
6 the Free Software Foundation; either version 3 of the License, or
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
7 (at your option) any later version.
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
8
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
12 GNU General Public License for more details.
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
13
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
16
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
17 /* Written by Bruno Haible <bruno@clisp.org>, 2010. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
18
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
19 #include <config.h>
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
20
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
21 #include "astrxfrm.h"
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
22
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
23 #include <locale.h>
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
24 #include <string.h>
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
25
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
26 #include "macros.h"
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
27
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
28 int
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
29 main ()
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
30 {
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
31 const char input[] = "B\303\266se B\303\274bchen"; /* "Böse Bübchen" */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
32 char *expected_transform;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
33
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
34 setlocale (LC_ALL, "de_DE.UTF-8");
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
35
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
36 /* Test resultbuf = NULL. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
37 {
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
38 size_t length = 0;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
39 char *transform = astrxfrm (input, NULL, &length);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
40 ASSERT (transform != NULL);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
41 ASSERT (length == strlen (transform) + 1);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
42 expected_transform = transform;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
43 }
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
44
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
45 /* Test resultbuf = NULL. Initial value of length is ignored here. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
46 {
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
47 size_t length = 100;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
48 char *transform = astrxfrm (input, NULL, &length);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
49 ASSERT (transform != NULL);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
50 ASSERT (strcmp (transform, expected_transform) == 0);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
51 ASSERT (length == strlen (transform) + 1);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
52 }
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
53
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
54 /* Test resultbuf != NULL with an initial length = 0. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
55 {
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
56 char buf[1];
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
57 size_t length = 0;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
58 char *transform;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
59 buf[0] = '@';
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
60 transform = astrxfrm (input, buf, &length);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
61 ASSERT (transform != NULL);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
62 ASSERT (transform != buf);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
63 ASSERT (strcmp (transform, expected_transform) == 0);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
64 ASSERT (length == strlen (transform) + 1);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
65 ASSERT (buf[0] == '@');
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
66 }
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
67
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
68 /* Test resultbuf != NULL with an initial length that is too small. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
69 {
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
70 char buf[3];
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
71 size_t length = sizeof (buf) - 1;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
72 char *transform;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
73 buf[sizeof (buf) - 1] = '@';
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
74 transform = astrxfrm (input, buf, &length);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
75 ASSERT (transform != NULL);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
76 ASSERT (transform != buf);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
77 ASSERT (strcmp (transform, expected_transform) == 0);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
78 ASSERT (length == strlen (transform) + 1);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
79 ASSERT (buf[sizeof (buf) - 1] == '@');
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
80 }
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
81
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
82 /* Test resultbuf != NULL with an initial length that is large enough. */
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
83 {
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
84 char buf[200];
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
85 size_t length = sizeof (buf) - 1;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
86 char *transform;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
87 buf[sizeof (buf) - 1] = '@';
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
88 transform = astrxfrm (input, buf, &length);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
89 ASSERT (transform != NULL);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
90 ASSERT (transform == buf);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
91 ASSERT (strcmp (transform, expected_transform) == 0);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
92 ASSERT (length == strlen (transform) + 1);
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
93 ASSERT (buf[sizeof (buf) - 1] == '@');
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
94 }
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
95
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
96 return 0;
a82579362064 Tests for module 'astrxfrm'.
Bruno Haible <bruno@clisp.org>
parents:
diff changeset
97 }