summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorDmitry Goncharov <dgoncharov@users.sf.net>2022-09-10 22:42:28 -0400
committerPaul Smith <psmith@gnu.org>2022-09-10 22:42:28 -0400
commit77734be2af9bf7f99d4014e26e6505c37f8012cf (patch)
treec174ac3fe6884628d1a9486f603cf125d30c318b /tests
parent820210ab8508955130a7618195ad8abb53c8171d (diff)
downloadmake-git-77734be2af9bf7f99d4014e26e6505c37f8012cf.tar.gz
[SV 63044] load: Update .LOADED if the setup function returns -1
* src/load.c (load_file): Update .LOADED if setup returns non-0. * tests/scripts/features/load: Change the return value based on an environment variable. Ensure that returning -1 still adds to .LOADED. Also add a test that verifies that make doesn't try to rebuild the loaded file if -1 is returned.
Diffstat (limited to 'tests')
-rw-r--r--tests/scripts/features/load39
1 files changed, 34 insertions, 5 deletions
diff --git a/tests/scripts/features/load b/tests/scripts/features/load
index 6d1978a5..b462ed9c 100644
--- a/tests/scripts/features/load
+++ b/tests/scripts/features/load
@@ -19,11 +19,10 @@ unlink(qw(testload.c testload.so));
open(my $F, '> testload.c') or die "open: testload.c: $!\n";
print $F <<'EOF' ;
-#include <string.h>
-#include <stdio.h>
-
#include "gnumake.h"
+char* getenv (const char*);
+
int plugin_is_GPL_compatible;
int testload_gmk_setup (gmk_floc *);
@@ -34,6 +33,8 @@ testload_gmk_setup (gmk_floc *pos)
{
(void)pos;
gmk_eval ("TESTLOAD = implicit", 0);
+ if (getenv("TESTAPI_KEEP"))
+ return -1;
return 1;
}
@@ -42,6 +43,8 @@ explicit_setup (gmk_floc *pos)
{
(void)pos;
gmk_eval ("TESTLOAD = explicit", 0);
+ if (getenv("TESTAPI_KEEP"))
+ return -1;
return 1;
}
EOF
@@ -79,7 +82,7 @@ all: ; @echo pre=$(PRE) post=$(POST) $(TESTLOAD)
!,
'', "pre= post=testload.so explicit\n");
-# TEST 4
+# TEST 3
# Check multiple loads
run_make_test(q!
PRE := $(.LOADED)
@@ -90,7 +93,7 @@ all: ; @echo pre=$(PRE) post=$(POST) $(TESTLOAD)
!,
'', "pre= post=testload.so implicit\n");
-# TEST 5
+# TEST 4
# Check auto-rebuild of loaded file that's out of date
utouch(-10, 'testload.so');
touch('testload.c');
@@ -115,6 +118,32 @@ all: ; @echo pre=$(PRE) post=$(POST) $(TESTLOAD)
%.so: %.c ; @echo "rebuilding $@"; !.$sobuild,
'', "rebuilding testload.so\npre= post=testload.so explicit\n");
+# sv 63044.
+# Test that the loaded shared object is present in .LOADED when the setup
+# routine returns -1.
+$ENV{TESTAPI_KEEP} = 1;
+run_make_test(q!
+PRE := $(.LOADED)
+load testload.so
+POST := $(.LOADED)
+all: ; @echo pre=$(PRE) post=$(POST) $(TESTLOAD)
+!,
+ '--warn-undefined-variables', "pre= post=testload.so implicit\n");
+
+# Check that we don't auto-rebuild of loaded file that's out of date
+# if we return -1 from the setup
+utouch(-10, 'testload.so');
+touch('testload.c');
+
+$ENV{TESTAPI_KEEP} = 1;
+run_make_test(q!
+PRE := $(.LOADED)
+load ./testload.so
+POST := $(.LOADED)
+all: ; @echo pre=$(PRE) post=$(POST) $(TESTLOAD)
+testload.so: testload.c ; @echo "rebuilding $@"; !.$sobuild,
+ '', "pre= post=testload.so implicit\n");
+
unlink(qw(testload.c testload.so)) unless $keep;
# This tells the test driver that the perl test script executed properly.