1
0
mirror of https://https.git.savannah.gnu.org/git/gnulib.git synced 2026-04-28 06:33:36 +00:00
Files
gnulib/tests/test-szprintf-posix.h
Bruno Haible b2a583ead5 tests: Use memeq, part 1.
Done through
  sed -e 's/memcmp \([(][^()]*[)]\) == 0/memeq \1/g' \
      -e 's/memcmp \([(][^()]*[(][^()]*[)][^()]*[)]\) == 0/memeq \1/g'

* tests/**/*.[hc]: Use memeq instead of memcmp ... == 0.
* modules/*-tests (Dependencies): Add memeq.
2026-03-01 12:36:28 +01:00

183 lines
6.3 KiB
C

/* Test of POSIX compatible vszprintf() and szprintf() functions.
Copyright (C) 2007-2026 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 <https://www.gnu.org/licenses/>. */
/* Written by Bruno Haible <bruno@clisp.org>, 2024. */
/* This test exercises only a few POSIX compliance problems that are still
visible on platforms relevant in 2024. For a much more complete test suite,
see test-sprintf-posix.h. */
#include "infinity.h"
#include "nan.h"
/* Test whether string[start_index..end_index-1] is a valid textual
representation of NaN. */
static int
strisnan (const char *string, size_t start_index, size_t end_index, int uppercase)
{
if (start_index < end_index)
{
if (string[start_index] == '-')
start_index++;
if (start_index + 3 <= end_index
&& memeq (string + start_index, uppercase ? "NAN" : "nan", 3))
{
start_index += 3;
if (start_index == end_index
|| (string[start_index] == '(' && string[end_index - 1] == ')'))
return 1;
}
}
return 0;
}
static void
test_function (ptrdiff_t (*my_szprintf) (char *, const char *, ...))
{
char result[5000];
/* Test the support of the 'a' and 'A' conversion specifier for hexadecimal
output of floating-point numbers. */
{ /* This test would fail on Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%a %d", 3.1416015625, 33, 44, 55);
ASSERT (streq (result, "0x1.922p+1 33")
|| streq (result, "0x3.244p+0 33")
|| streq (result, "0x6.488p-1 33")
|| streq (result, "0xc.91p-2 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%A %d", -3.1416015625, 33, 44, 55);
ASSERT (streq (result, "-0X1.922P+1 33")
|| streq (result, "-0X3.244P+0 33")
|| streq (result, "-0X6.488P-1 33")
|| streq (result, "-0XC.91P-2 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on FreeBSD 6.1, NetBSD 10.0. */
ptrdiff_t retval =
my_szprintf (result, "%.2a %d", 1.51, 33, 44, 55);
ASSERT (streq (result, "0x1.83p+0 33")
|| streq (result, "0x3.05p-1 33")
|| streq (result, "0x6.0ap-2 33")
|| streq (result, "0xc.14p-3 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on macOS 14, FreeBSD 14.0, OpenBSD 7.5, AIX 7.3,
Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%.0a %d", 1.51, 33, 44, 55);
ASSERT (streq (result, "0x2p+0 33")
|| streq (result, "0x3p-1 33")
|| streq (result, "0x6p-2 33")
|| streq (result, "0xcp-3 33"));
ASSERT (retval == strlen (result));
}
/* Test the support of the %f format directive. */
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%f %d", Infinityd (), 33, 44, 55);
ASSERT (streq (result, "inf 33")
|| streq (result, "infinity 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%f %d", NaNd (), 33, 44, 55);
ASSERT (strlen (result) >= 3 + 3
&& strisnan (result, 0, strlen (result) - 3, 0)
&& streq (result + strlen (result) - 3, " 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%010f %d", Infinityd (), 33, 44, 55);
ASSERT (streq (result, " inf 33")
|| streq (result, " infinity 33"));
ASSERT (retval == strlen (result));
}
/* Test the support of the %e format directive. */
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%e %d", Infinityd (), 33, 44, 55);
ASSERT (streq (result, "inf 33")
|| streq (result, "infinity 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%e %d", NaNd (), 33, 44, 55);
ASSERT (strlen (result) >= 3 + 3
&& strisnan (result, 0, strlen (result) - 3, 0)
&& streq (result + strlen (result) - 3, " 33"));
ASSERT (retval == strlen (result));
}
/* Test the support of the %g format directive. */
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%g %d", Infinityd (), 33, 44, 55);
ASSERT (streq (result, "inf 33")
|| streq (result, "infinity 33"));
ASSERT (retval == strlen (result));
}
{ /* This test would fail on AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%g %d", NaNd (), 33, 44, 55);
ASSERT (strlen (result) >= 3 + 3
&& strisnan (result, 0, strlen (result) - 3, 0)
&& streq (result + strlen (result) - 3, " 33"));
ASSERT (retval == strlen (result));
}
/* Test the support of large precision. */
{ /* This test would fail on AIX 7.1. */
ptrdiff_t retval =
my_szprintf (result, "%.4000d %d", 1234567, 99);
for (size_t i = 0; i < 4000 - 7; i++)
ASSERT (result[i] == '0');
ASSERT (streq (result + 4000 - 7, "1234567 99"));
ASSERT (retval == strlen (result));
}
/* Test the support of the 'b' conversion specifier for binary output of
integers. */
{ /* This test would fail on glibc 2.34, musl libc, macOS 14,
FreeBSD 13.2, NetBSD 10.0, OpenBSD 7.5, AIX 7.3, Solaris 11.4. */
ptrdiff_t retval =
my_szprintf (result, "%b %d", 12345, 33, 44, 55);
ASSERT (streq (result, "11000000111001 33"));
ASSERT (retval == strlen (result));
}
}