2016-12-09 07:18:27 +00:00
|
|
|
/* Interfaces for the test driver.
|
2023-01-06 21:08:04 +00:00
|
|
|
Copyright (C) 2016-2023 Free Software Foundation, Inc.
|
2016-12-09 07:18:27 +00:00
|
|
|
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
|
Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
$(find $(git ls-files) -prune -type f \
! -name '*.po' \
! -name 'ChangeLog*' \
! -path COPYING ! -path COPYING.LIB \
! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
! -path manual/texinfo.tex ! -path scripts/config.guess \
! -path scripts/config.sub ! -path scripts/install-sh \
! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
! -path INSTALL ! -path locale/programs/charmap-kw.h \
! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
! '(' -name configure \
-execdir test -f configure.ac -o -f configure.in ';' ')' \
! '(' -name preconfigure \
-execdir test -f preconfigure.ac ';' ')' \
-print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
chmod a+x sysdeps/unix/sysv/linux/riscv/configure
# Omit irrelevant whitespace and comment-only changes,
# perhaps from a slightly-different Autoconf version.
git checkout -f \
sysdeps/csky/configure \
sysdeps/hppa/configure \
sysdeps/riscv/configure \
sysdeps/unix/sysv/linux/csky/configure
# Omit changes that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
git checkout -f \
sysdeps/powerpc/powerpc64/ppc-mcount.S \
sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
# Omit change that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
2019-09-07 05:40:42 +00:00
|
|
|
<https://www.gnu.org/licenses/>. */
|
2016-12-09 07:18:27 +00:00
|
|
|
|
|
|
|
#ifndef SUPPORT_TEST_DRIVER_H
|
|
|
|
#define SUPPORT_TEST_DRIVER_H
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
|
|
|
|
__BEGIN_DECLS
|
|
|
|
|
|
|
|
struct test_config
|
|
|
|
{
|
|
|
|
void (*prepare_function) (int argc, char **argv);
|
|
|
|
int (*test_function) (void);
|
|
|
|
int (*test_function_argv) (int argc, char **argv);
|
|
|
|
void (*cleanup_function) (void);
|
|
|
|
void (*cmdline_function) (int);
|
|
|
|
const void *options; /* Custom options if not NULL. */
|
|
|
|
int timeout; /* Test timeout in seconds. */
|
|
|
|
int expected_status; /* Expected exit status. */
|
|
|
|
int expected_signal; /* If non-zero, expect termination by signal. */
|
|
|
|
char no_mallopt; /* Boolean flag to disable mallopt. */
|
2018-06-26 10:05:21 +00:00
|
|
|
char no_setvbuf; /* Boolean flag to disable setvbuf. */
|
elf: Testing infrastructure for ld.so DSO sorting (BZ #17645)
This is the first of a 2-part patch set that fixes slow DSO sorting behavior in
the dynamic loader, as reported in BZ #17645. In order to facilitate such a
large modification to the dynamic loader, this first patch implements a testing
framework for validating shared object sorting behavior, to enable comparison
between old/new sorting algorithms, and any later enhancements.
This testing infrastructure consists of a Python script
scripts/dso-ordering-test.py' which takes in a description language, consisting
of strings that describe a set of link dependency relations between DSOs, and
generates testcase programs and Makefile fragments to automatically test the
described situation, for example:
a->b->c->d # four objects linked one after another
a->[bc]->d;b->c # a depends on b and c, which both depend on d,
# b depends on c (b,c linked to object a in fixed order)
a->b->c;{+a;%a;-a} # a, b, c serially dependent, main program uses
# dlopen/dlsym/dlclose on object a
a->b->c;{}!->[abc] # a, b, c serially dependent; multiple tests generated
# to test all permutations of a, b, c ordering linked
# to main program
(Above is just a short description of what the script can do, more
documentation is in the script comments.)
Two files containing several new tests, elf/dso-sort-tests-[12].def are added,
including test scenarios for BZ #15311 and Redhat issue #1162810 [1].
Due to the nature of dynamic loader tests, where the sorting behavior and test
output occurs before/after main(), generating testcases to use
support/test-driver.c does not suffice to control meaningful timeout for ld.so.
Therefore a new utility program 'support/test-run-command', based on
test-driver.c/support_test_main.c has been added. This does the same testcase
control, but for a program specified through a command-line rather than at the
source code level. This utility is used to run the dynamic loader testcases
generated by dso-ordering-test.py.
[1] https://bugzilla.redhat.com/show_bug.cgi?id=1162810
Signed-off-by: Chung-Lin Tang <cltang@codesourcery.com>
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
2021-10-21 13:41:21 +00:00
|
|
|
char run_command_mode; /* Boolean flag to indicate run-command-mode. */
|
2017-05-24 12:17:34 +00:00
|
|
|
const char *optstring; /* Short command line options. */
|
2016-12-09 07:18:27 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
/* Test exit status which indicates that the feature is
|
|
|
|
unsupported. */
|
|
|
|
EXIT_UNSUPPORTED = 77,
|
|
|
|
|
|
|
|
/* Default timeout is twenty seconds. Tests should normally
|
|
|
|
complete faster than this, but if they don't, that's abnormal
|
|
|
|
(a bug) anyways. */
|
|
|
|
DEFAULT_TIMEOUT = 20,
|
|
|
|
|
|
|
|
/* Used for command line argument parsing. */
|
|
|
|
OPT_DIRECT = 1000,
|
|
|
|
OPT_TESTDIR,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Options provided by the test driver. */
|
|
|
|
#define TEST_DEFAULT_OPTIONS \
|
2016-12-31 10:01:40 +00:00
|
|
|
{ "verbose", no_argument, NULL, 'v' }, \
|
2016-12-09 07:18:27 +00:00
|
|
|
{ "direct", no_argument, NULL, OPT_DIRECT }, \
|
|
|
|
{ "test-dir", required_argument, NULL, OPT_TESTDIR }, \
|
|
|
|
|
|
|
|
/* The directory the test should use for temporary files. */
|
|
|
|
extern const char *test_dir;
|
|
|
|
|
2016-12-31 10:01:40 +00:00
|
|
|
/* The number of --verbose arguments specified during program
|
|
|
|
invocation. This variable can be used to control the verbosity of
|
|
|
|
tests. */
|
|
|
|
extern unsigned int test_verbose;
|
|
|
|
|
2019-06-19 21:06:14 +00:00
|
|
|
/* Output that is only emitted if at least one --verbose argument was
|
|
|
|
specified. */
|
|
|
|
#define verbose_printf(...) \
|
|
|
|
do { \
|
|
|
|
if (test_verbose > 0) \
|
|
|
|
printf (__VA_ARGS__); \
|
|
|
|
} while (0);
|
|
|
|
|
2016-12-09 07:18:27 +00:00
|
|
|
int support_test_main (int argc, char **argv, const struct test_config *);
|
|
|
|
|
|
|
|
__END_DECLS
|
|
|
|
|
|
|
|
#endif /* SUPPORT_TEST_DRIVER_H */
|