elf: add test for dl-printf

Message ID 20230515202942.8307-1-royeldar0@gmail.com
State New
Headers
Series elf: add test for dl-printf |

Checks

Context Check Description
dj/TryBot-apply_patch success Patch applied to master at the time it was sent
dj/TryBot-32bit success Build for i686
redhat-pt-bot/TryBot-still_applies warning Patch no longer applies to master

Commit Message

Roy Eldar May 15, 2023, 8:29 p.m. UTC
  This patch checks _dl_debug_vdprintf, by passing various inputs to
_dl_dprintf and comparing the output with invocations of snprintf.

Signed-off-by: Roy Eldar <royeldar0@gmail.com>
---
 elf/Makefile               |  1 +
 elf/tst-dl-printf-static.c | 75 ++++++++++++++++++++++++++++++++++++++
 2 files changed, 76 insertions(+)
 create mode 100644 elf/tst-dl-printf-static.c
  

Comments

Florian Weimer May 25, 2023, 7:44 a.m. UTC | #1
* Roy Eldar:

> This patch checks _dl_debug_vdprintf, by passing various inputs to
> _dl_dprintf and comparing the output with invocations of snprintf.
>
> Signed-off-by: Roy Eldar <royeldar0@gmail.com>

Do you have a copyright assignment on file?  If not, Signed-off-by: is
sufficient but we should say …

> diff --git a/elf/tst-dl-printf-static.c b/elf/tst-dl-printf-static.c
> new file mode 100644
> index 0000000000..a31759a006
> --- /dev/null
> +++ b/elf/tst-dl-printf-static.c
> @@ -0,0 +1,75 @@
> +/* Check _dl_debug_vdprintf.
> +   Copyright (C) 2016-2023 Free Software Foundation, Inc.

… “Copyright The GNU Toolchain Authors.” here.

> +   This file is part of the GNU C Library.
> +
> +   The GNU C Library is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU Lesser General Public
> +   License as published by the Free Software Foundation; either
> +   version 2.1 of the License, or (at your option) any later version.
> +
> +   The GNU C Library 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
> +   Lesser General Public License for more details.
> +
> +   You should have received a copy of the GNU Lesser General Public
> +   License along with the GNU C Library; if not, see
> +   <https://www.gnu.org/licenses/>.  */
> +
> +#include <ldsodefs.h>
> +#include <limits.h>
> +#include <stdarg.h>
> +#include <stdio.h>
> +#include <support/check.h>
> +#include <support/xunistd.h>
> +
> +#define BUFSZ 64
> +
> +#define TEST(fmt, ...) do {                                                   \

GNU style puts { and } on their own lines.

> +    char str1[BUFSZ], str2[BUFSZ];                                            \
> +    int len1 = snprintf (str1, BUFSZ, fmt, __VA_ARGS__);                      \
> +    TEST_VERIFY_EXIT (len1 >= 0);                                             \
> +    TEST_VERIFY_EXIT (len1 < BUFSZ);                                          \
> +    _dl_dprintf (fds[1], fmt, __VA_ARGS__);                                   \
> +    ssize_t len2 = read (fds[0], str2, BUFSZ);                                \
> +    TEST_VERIFY_EXIT (len2 >= 0);                                             \
> +    TEST_VERIFY_EXIT (len2 < BUFSZ);                                          \
> +    str2[len2] = '\0';                                                        \
> +    TEST_COMPARE_STRING(str1, str2);                                          \

Missing space after TEST_COMPARE_STRING.

Rest looks good.

Thanks,
Florian
  

Patch

diff --git a/elf/Makefile b/elf/Makefile
index 396ec51424..90ccd65db1 100644
--- a/elf/Makefile
+++ b/elf/Makefile
@@ -275,6 +275,7 @@  tests-static-normal := \
 
 tests-static-internal := \
   tst-dl_find_object-static \
+  tst-dl-printf-static \
   tst-ptrguard1-static \
   tst-stackguard1-static \
   tst-tls1-static \
diff --git a/elf/tst-dl-printf-static.c b/elf/tst-dl-printf-static.c
new file mode 100644
index 0000000000..a31759a006
--- /dev/null
+++ b/elf/tst-dl-printf-static.c
@@ -0,0 +1,75 @@ 
+/* Check _dl_debug_vdprintf.
+   Copyright (C) 2016-2023 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library 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
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <https://www.gnu.org/licenses/>.  */
+
+#include <ldsodefs.h>
+#include <limits.h>
+#include <stdarg.h>
+#include <stdio.h>
+#include <support/check.h>
+#include <support/xunistd.h>
+
+#define BUFSZ 64
+
+#define TEST(fmt, ...) do {                                                   \
+    char str1[BUFSZ], str2[BUFSZ];                                            \
+    int len1 = snprintf (str1, BUFSZ, fmt, __VA_ARGS__);                      \
+    TEST_VERIFY_EXIT (len1 >= 0);                                             \
+    TEST_VERIFY_EXIT (len1 < BUFSZ);                                          \
+    _dl_dprintf (fds[1], fmt, __VA_ARGS__);                                   \
+    ssize_t len2 = read (fds[0], str2, BUFSZ);                                \
+    TEST_VERIFY_EXIT (len2 >= 0);                                             \
+    TEST_VERIFY_EXIT (len2 < BUFSZ);                                          \
+    str2[len2] = '\0';                                                        \
+    TEST_COMPARE_STRING(str1, str2);                                          \
+  } while (0)
+
+static int
+do_test (void)
+{
+  int fds[2];
+  xpipe (fds);
+  TEST ("%d", 0);
+  TEST ("%d", 1);
+  TEST ("%d", INT_MAX);
+  TEST ("%d", -1);
+  TEST ("%d", INT_MIN + 1);
+  TEST ("%d", INT_MIN);
+  TEST ("%u", 0U);
+  TEST ("%u", 1U);
+  TEST ("%u", UINT_MAX);
+  TEST ("%x", 0);
+  TEST ("%x", 1);
+  TEST ("%x", UINT_MAX);
+  TEST ("%ld", 0L);
+  TEST ("%ld", 1L);
+  TEST ("%ld", LONG_MAX);
+  TEST ("%ld", -1L);
+  TEST ("%ld", LONG_MIN + 1);
+  TEST ("%ld", LONG_MIN);
+  TEST ("%lu", 0UL);
+  TEST ("%lu", 1UL);
+  TEST ("%lu", ULONG_MAX);
+  TEST ("%lx", 0UL);
+  TEST ("%lx", 1UL);
+  TEST ("%lx", ULONG_MAX);
+  xclose (fds[0]);
+  xclose (fds[1]);
+  return 0;
+}
+
+#include <support/test-driver.c>