Waldemar Brodkorb f1dcb9beed dltest: fix a typo 9 years ago
..
argp 0f2a411b68 replace FSF addresses with URLs 9 years ago
args 6bfb450b58 test: add missing top_srcdir 12 years ago
assert 3f98fdc552 remove m68k binutils workarounds 9 years ago
build 6bfb450b58 test: add missing top_srcdir 12 years ago
crypt 337531c6d5 increase timeouts to successfully run on slower hardware/emulation, f.e. xtensa 9 years ago
ctype 3f98fdc552 remove m68k binutils workarounds 9 years ago
dlopen f1dcb9beed dltest: fix a typo 9 years ago
inet 3f98fdc552 remove m68k binutils workarounds 9 years ago
librt ff48662bba test: disable librt shmtest on non-MMU systems 11 years ago
locale 3f98fdc552 remove m68k binutils workarounds 9 years ago
locale-mbwc 3f98fdc552 remove m68k binutils workarounds 9 years ago
malloc 3f98fdc552 remove m68k binutils workarounds 9 years ago
math 0c57565920 mips: refresh ULPS file for math tests 9 years ago
misc 3f98fdc552 remove m68k binutils workarounds 9 years ago
mmap 6bfb450b58 test: add missing top_srcdir 12 years ago
nptl fad6c6021f disable always failing tst-signal7 9 years ago
plt e219bc7c1b test/plt: add a script to find PLT usage 16 years ago
pthread 0f2a411b68 replace FSF addresses with URLs 9 years ago
pwd_grp bff3a664e6 test: Some more tests under conditionals 11 years ago
regex 3f98fdc552 remove m68k binutils workarounds 9 years ago
rpc 6bfb450b58 test: add missing top_srcdir 12 years ago
setjmp 3f98fdc552 remove m68k binutils workarounds 9 years ago
signal 3f98fdc552 remove m68k binutils workarounds 9 years ago
silly 3f98fdc552 remove m68k binutils workarounds 9 years ago
stat 6bfb450b58 test: add missing top_srcdir 12 years ago
stdio 3f98fdc552 remove m68k binutils workarounds 9 years ago
stdlib 3f98fdc552 remove m68k binutils workarounds 9 years ago
string abbb302279 h8300: disable test using mprotect(), not available for h8300 10 years ago
termios 6bfb450b58 test: add missing top_srcdir 12 years ago
time 3f98fdc552 remove m68k binutils workarounds 9 years ago
tls 337531c6d5 increase timeouts to successfully run on slower hardware/emulation, f.e. xtensa 9 years ago
unistd 3f98fdc552 remove m68k binutils workarounds 9 years ago
.gitignore cc8d7d062e include: update atomic.h from glibc 10 years ago
Makefile 61cf47568f test: disable tests requiring math headers 9 years ago
README 560f416794 test: Add SIMULATOR_uclibc and SIMULATOR_glibc 10 years ago
Rules.mak 82b948ef8f remove deprecated architectures v850/i960 9 years ago
Test.mak 7c89984515 tests: Extend OMIT LDFLAGS logic to test binaries too 9 years ago
test-skeleton.c 6c3db949b0 test-skeleton: Fixes from glibc 9 years ago
testsuite.h bad7c039de test: silence warning in testsuite.h 12 years ago
uclibcng-testrunner.sh ef28300bbc implement experimental pure-sh testsuite runner and generation 10 years ago

README

-----------
For: User
-----------
Following make targets are avaialable

make compile

This will compile and link the tests.

make run

This will execute all the tests.

make check
make all

This will build and run tests.

The following make variables may help you in testing:

- UCLIBC_ONLY - only run tests against uClibc
- GLIBC_ONLY - only run tests against glibc
- V / VERBOSE - run tests with a lot of output
- TEST_INSTALLED_UCLIBC - Test installed libraries
under /lib and /usr/lib.
- TIMEOUTFACTOR=nn - increase test timeout nn times.
At least REGEX_OLD + regex/tst-regex2 needs it increased.

So, to just run the uClibc tests, try this:
make check UCLIBC_ONLY=1

You can pass the following 2 environment variables to "make run":
- make run SIMULATOR_uclibc=qemu-sh4 SIMULATOR_glibc=qemu-x86_64

If you need to test just a subset of all test, delete subdirectories
you do not need.

As of 2009-07, build machinery does not track dependencies on uclibc.
If you edit a header and re-run "make compile", it does not re-install it
into ../install_dir. If you delete ../install_dir, "make compile"
rebuilds uclibc as needed and re-installs ../install_dir,
but still does not rebuild testcases.
(You can work around it by "touch */*.c" for now).

----------------
For: Developer
----------------

The structure of this test system is:
test/ toplevel dir containing common test code
test/Rules.mak Common build code
test/Test.mak Runtime test make code
test/subdir/ code specific to a subsystem is stored in a subdir
test/subdir/Makefile.in describe the tests to run
test/subdir/Makefile test entry point, includes needed upper-level
makefiles plus Makefile.in
test/subdir/*.c the tests

Each subdir has a Makefile (same for any subdir) that must include in strict order:
- the upper-level Rules.mak file
- the Makefile.in
- the upper-level Test.mak file
Makefile.in may be used to define the TESTS and TESTS_DISABLED variables.
If you do not, TESTS is built automatically based upon all the .c files in the subdir.
TESTS := foo
TESTS_DISABLED := bar
Each test must use a similar .c name; so the "foo" test needs a "foo.c".

Additionally, the following options further control specific test behavior:
CFLAGS_foo := extra cflags to use to compile test
DODIFF_foo := compare the output of the glibc and uClibc tests (see below)
LDFLAGS_foo := extra ldflags to use to link test
OPTS_foo := extra options to pass to test
RET_foo := expected exit code of test; default is 0
WRAPPER_foo := execute stuff just before test

Or to control all tests in a subdir:
EXTRA_CLEAN := extra files to remove in the clean target
EXTRA_DIRS := extra directories to remove in the clean target
EXTRA_CFLAGS := -DFOO
EXTRA_LDFLAGS := -lpthread
OPTS :=
WRAPPER :=

If you want to compare the output of a test with known good output, then just
create a local file named "foo.out.good" and the output generated by the test
"foo" will be automatically stored in "foo.out" and compared to "foo.out.good".