3 # Generic build infrastructure for test programs.
5 # This is the only public file that should be included by Makefiles when
6 # tests are to be built. All other *.test.mk files are internal and not
7 # to be included directly.
13 # Tests install directory
14 TESTSDIR?= ${TESTSBASE}/${RELDIR:H}
16 # List of subdirectories containing tests into which to recurse. This has the
17 # same semantics as SUBDIR at build-time. However, the directories listed here
18 # get registered into the run-time test suite definitions so that the test
19 # engines know to recurse into these directories.
21 # In other words: list here any directories that contain test programs but use
22 # SUBDIR for directories that may contain helper binaries and/or data files.
25 # If defined, indicates that the tests built by the Makefile are not part of
26 # the FreeBSD Test Suite. The implication of this is that the tests won't be
27 # installed under /usr/tests/ and that Kyua won't be able to run them.
30 # List of variables to pass to the tests at run-time via the environment.
33 # Force all tests in a separate distribution file.
35 # We want this to be the case even when the distribution name is already
36 # overriden. For example: we want the tests for programs in the 'games'
37 # distribution to end up in the 'tests' distribution; the test programs
38 # themselves have all the necessary logic to detect that the games are not
39 # installed and thus won't cause false negatives.
42 # Ordered list of directories to construct the PATH for the tests.
43 TESTS_PATH+= ${DESTDIR}/bin ${DESTDIR}/sbin \
44 ${DESTDIR}/usr/bin ${DESTDIR}/usr/sbin
45 TESTS_ENV+= PATH=${TESTS_PATH:tW:C/ +/:/g}
47 # Ordered list of directories to construct the LD_LIBRARY_PATH for the tests.
48 TESTS_LD_LIBRARY_PATH+= ${DESTDIR}/lib ${DESTDIR}/usr/lib
49 TESTS_ENV+= LD_LIBRARY_PATH=${TESTS_LD_LIBRARY_PATH:tW:C/ +/:/g}
51 # List of all tests being built. The various *.test.mk modules extend this
55 # Pull in the definitions of all supported test interfaces.
56 .include <atf.test.mk>
57 .include <plain.test.mk>
58 .include <tap.test.mk>
60 .for ts in ${TESTS_SUBDIRS}
61 .if empty(SUBDIR:M${ts})
66 # it is rare for test cases to have man pages
71 # tell progs.mk we might want to install things
73 PROGS_TARGETS+= install
75 .if !defined(NOT_FOR_TEST_SUITE)
76 .include <suite.test.mk>
81 @echo "$@ not defined; skipping"
85 .ORDER: beforetest realtest
86 test: beforetest realtest
89 .ORDER: realtest aftertest
94 # we came here via bsd.progs.mk below
95 # parent will do staging.
99 .if !empty(PROGS) || !empty(PROGS_CXX) || !empty(SCRIPTS)
100 .include <bsd.progs.mk>
102 .include <bsd.files.mk>
104 .if !defined(PROG) && ${MK_STAGING} != "no"
105 .if !defined(_SKIP_BUILD)
106 # this will handle staging if needed
108 # but we don't want it to build anything
112 stage_files.prog: ${PROGS}
114 .include <bsd.prog.mk>
118 .include <bsd.obj.mk>