diff options
author | Paul Smith <psmith@gnu.org> | 2013-10-19 15:39:15 -0400 |
---|---|---|
committer | Paul Smith <psmith@gnu.org> | 2013-10-19 15:39:15 -0400 |
commit | 107ab16bf6f0bb912aab2d72e019f20e11a03aba (patch) | |
tree | dbcf0e781246f3a52c323cd71d65ee2605c4a85f | |
parent | 07f2666b91c0083a36135c9893305b2a620e3b38 (diff) | |
download | gunmake-107ab16bf6f0bb912aab2d72e019f20e11a03aba.tar.gz |
[SV 40240] Use configure info to build load test shared libs
* tests/config-flags.pm.in: A new file containing variable assignments
for the test suite; these variables are set by configure to contain
the values detected there for compilers, flags, etc.
* tests/run_make_tests.pl: Require the config-flags.pm file
* tests/scripts/features/load, tests/scripts/features/loadapi: Use the
configure-provided values when building the shared test library.
* configure.ac: Replace tests/config-flags.pm.in
* Makefile.am: Make sure tests/config-flags.pm is up to date
-rw-r--r-- | Makefile.am | 2 | ||||
-rw-r--r-- | configure.ac | 2 | ||||
-rw-r--r-- | tests/.gitignore | 1 | ||||
-rw-r--r-- | tests/config-flags.pm.in | 18 | ||||
-rw-r--r-- | tests/run_make_tests.pl | 1 | ||||
-rw-r--r-- | tests/scripts/features/load | 12 | ||||
-rw-r--r-- | tests/scripts/features/loadapi | 10 |
7 files changed, 38 insertions, 8 deletions
diff --git a/Makefile.am b/Makefile.am index 6303d96..e2c0fe9 100644 --- a/Makefile.am +++ b/Makefile.am @@ -172,7 +172,7 @@ loadavg_LDADD = @GETLOADAVG_LIBS@ # MAKETESTFLAGS = -check-regression: +check-regression: tests/config-flags.pm @if test -f '$(srcdir)/tests/run_make_tests'; then \ if $(PERL) -v >/dev/null 2>&1; then \ case `cd '$(srcdir)'; pwd` in `pwd`) : ;; \ diff --git a/configure.ac b/configure.ac index 7bf9ccc..8e11328 100644 --- a/configure.ac +++ b/configure.ac @@ -499,7 +499,7 @@ AS_IF([test "x$make_cv_load" = xno && test "x$user_load" = xyes], # Specify what files are to be created. AC_CONFIG_FILES([Makefile glob/Makefile po/Makefile.in config/Makefile \ - doc/Makefile w32/Makefile]) + doc/Makefile w32/Makefile tests/config-flags.pm]) # OK, do it! diff --git a/tests/.gitignore b/tests/.gitignore index b8f99f5..a30a689 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -1 +1,2 @@ +config-flags.pm work diff --git a/tests/config-flags.pm.in b/tests/config-flags.pm.in new file mode 100644 index 0000000..a26b8dc --- /dev/null +++ b/tests/config-flags.pm.in @@ -0,0 +1,18 @@ +# This is a -*-perl-*- script +# +# Set variables that were defined by configure, in case we need them +# during the tests. + +%CONFIG_FLAGS = ( + AM_LDFLAGS => '@AM_LDFLAGS@', + CC => '@CC@', + CFLAGS => '@CFLAGS@', + CPP => '@CPP@', + CPPFLAGS => '@CPPFLAGS@', + GUILE_CFLAGS => '@GUILE_CFLAGS@', + GUILE_LIBS => '@GUILE_LIBS@', + LDFLAGS => '@LDFLAGS@', + LIBS => '@LIBS@' +); + +1; diff --git a/tests/run_make_tests.pl b/tests/run_make_tests.pl index 54c2892..555e409 100644 --- a/tests/run_make_tests.pl +++ b/tests/run_make_tests.pl @@ -43,6 +43,7 @@ $command_string = ''; $all_tests = 0; require "test_driver.pl"; +require "config-flags.pm"; # Some target systems might not have the POSIX module... $has_POSIX = eval { require "POSIX.pm" }; diff --git a/tests/scripts/features/load b/tests/scripts/features/load index 2e3f263..05e9ddb 100644 --- a/tests/scripts/features/load +++ b/tests/scripts/features/load @@ -6,8 +6,6 @@ $details = "Test dynamic loading of modules."; # Don't do anything if this system doesn't support "load" exists $FEATURES{load} or return -1; -my $sobuild = '$(CC) '.($srcdir? "-I$srcdir":'').' -g -shared -fPIC -o $@ $<'; - # First build a shared object # Provide both a default and non-default load symbol @@ -39,7 +37,15 @@ EOF close($F) or die "close: testload.c: $!\n"; # Make sure we can compile -run_make_test('testload.so: testload.c ; @'.$sobuild, '', ''); +# CONFIG_FLAGS are loaded from config-flags.pm and set by configure + +my $sobuild = "$CONFIG_FLAGS{CC} ".($srcdir? "-I$srcdir":'')." $CONFIG_FLAGS{CPPFLAGS} $CONFIG_FLAGS{CFLAGS} -shared -fPIC $CONFIG_FLAGS{LDFLAGS} -o testload.so testload.c"; + +my $clog = `$sobuild 2>&1`; +if ($? != 0) { + $verbose and print "Failed to build testload.so:\n$sobuild\n$_"; + return -1; +} # TEST 1 run_make_test(q! diff --git a/tests/scripts/features/loadapi b/tests/scripts/features/loadapi index 6d3b03f..bf66bae 100644 --- a/tests/scripts/features/loadapi +++ b/tests/scripts/features/loadapi @@ -6,8 +6,6 @@ $details = "Verify the different aspects of the shared object API."; # Don't do anything if this system doesn't support "load" exists $FEATURES{load} or return -1; -my $sobuild = '$(CC) '.($srcdir? "-I$srcdir":'').' -g -shared -fPIC -o $@ $<'; - # First build a shared object # Provide both a default and non-default load symbol @@ -74,7 +72,13 @@ testapi_gmk_setup () EOF close($F) or die "close: testapi.c: $!\n"; -run_make_test('testapi.so: testapi.c ; @'.$sobuild, '', ''); +my $sobuild = "$CONFIG_FLAGS{CC} ".($srcdir? "-I$srcdir":'')." $CONFIG_FLAGS{CPPFLAGS} $CONFIG_FLAGS{CFLAGS} -shared -fPIC $CONFIG_FLAGS{LDFLAGS} -o testapi.so testapi.c"; + +my $clog = `$sobuild 2>&1`; +if ($? != 0) { + $verbose and print "Failed to build testapi.so:\n$sobuild\n$_"; + return -1; +} # TEST 1 # Check the gmk_expand() function |