* tests/scripts/features/implicit_search: Add -r for safety.

This commit is contained in:
Paul Smith 2022-01-23 11:41:46 -05:00
parent f3e345c869
commit 7154e316b7

View File

@ -27,7 +27,7 @@ run_make_test("
all: hello$s all: hello$s
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", '', "hello.f\n#MAKE#: Nothing to be done for 'all'."); ", '-r', "hello.f\n#MAKE#: Nothing to be done for 'all'.");
# Test that make finds the intended implicit rule based on the explicit # Test that make finds the intended implicit rule based on the explicit
# prerequisite of the top goal and despite the existence of a # prerequisite of the top goal and despite the existence of a
@ -40,8 +40,7 @@ run_make_test("
hello$s: hello.c hello$s: hello.c
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", ", '-r',
'',
"#MAKE#: *** No rule to make target 'hello.c', needed by 'hello$s'. Stop.\n", "#MAKE#: *** No rule to make target 'hello.c', needed by 'hello$s'. Stop.\n",
512); 512);
@ -57,7 +56,7 @@ all: hello$s
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
hello.c:; false hello.c:; false
", '', "false\n#MAKE#: *** [#MAKEFILE#:5: hello.c] Error 1\n", 512); ", '-r', "false\n#MAKE#: *** [#MAKEFILE#:5: hello.c] Error 1\n", 512);
# Test that make finds the intended implicit rule based on existence of a # Test that make finds the intended implicit rule based on existence of a
# prerequisite in the filesystem, even when the prerequisite of another # prerequisite in the filesystem, even when the prerequisite of another
@ -71,7 +70,7 @@ all: hello$s
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
unrelated: hello.c unrelated: hello.c
", '', "hello.f\n#MAKE#: Nothing to be done for 'all'."); ", '-r', "hello.f\n#MAKE#: Nothing to be done for 'all'.");
# Test that make finds the intended implicit rule based on existence of a # Test that make finds the intended implicit rule based on existence of a
# prerequisite in the filesystem. # prerequisite in the filesystem.
@ -83,7 +82,7 @@ run_make_test("
all: hello$s all: hello$s
%$s:$r %.c hello.c; \$(info hello.c) %$s:$r %.c hello.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", '', "hello.f\n#MAKE#: Nothing to be done for 'all'."); ", '-r', "hello.f\n#MAKE#: Nothing to be done for 'all'.");
# '%.o: %.c' rule is skipped and '%.o: %.f' rule is chosen. # '%.o: %.c' rule is skipped and '%.o: %.f' rule is chosen.
# '%.o: %.f hello.f' rule has explicit prerequisite hello.f. # '%.o: %.f hello.f' rule has explicit prerequisite hello.f.
@ -92,7 +91,7 @@ run_make_test("
all: hello$s all: hello$s
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f hello.f; \$(info hello.f) %$s:$r %.f hello.f; \$(info hello.f)
", '', "hello.f\n#MAKE#: Nothing to be done for 'all'."); ", '-r', "hello.f\n#MAKE#: Nothing to be done for 'all'.");
# Rule '%: %.f' is chosen, because '%: %.f' requires no intermediates. # Rule '%: %.f' is chosen, because '%: %.f' requires no intermediates.
# '%: %.c', on the other hand, requires intemediate hello.c to be built by the # '%: %.c', on the other hand, requires intemediate hello.c to be built by the
@ -103,7 +102,7 @@ all: hello$s
%$s:$r %.f; \$(info \$<) %$s:$r %.f; \$(info \$<)
.DEFAULT:; \$(info \$\@) true .DEFAULT:; \$(info \$\@) true
unrelated: hello.c unrelated: hello.c
", '', "hello.f\n#MAKE#: Nothing to be done for 'all'."); ", '-r', "hello.f\n#MAKE#: Nothing to be done for 'all'.");
# hello.f is missing. # hello.f is missing.
@ -118,7 +117,7 @@ all: hello$s
%$s:$r %.f; \$(info \$<) %$s:$r %.f; \$(info \$<)
.DEFAULT:; \$(info \$\@) false .DEFAULT:; \$(info \$\@) false
unrelated: hello.c unrelated: hello.c
", '', "hello.c\nfalse\n#MAKE#: *** [#MAKEFILE#:5: hello.c] Error 1\n", 512); ", '-r', "hello.c\nfalse\n#MAKE#: *** [#MAKEFILE#:5: hello.c] Error 1\n", 512);
# hello.f is missing. # hello.f is missing.
# No rule is found, because hello.c is not mentioned explicitly. # No rule is found, because hello.c is not mentioned explicitly.
@ -127,10 +126,7 @@ all: hello$s
%$s:$r %.c; \$(info \$<) %$s:$r %.c; \$(info \$<)
%$s:$r %.f; \$(info \$<) %$s:$r %.f; \$(info \$<)
.DEFAULT:; \@\$(info \$\@) false .DEFAULT:; \@\$(info \$\@) false
", ", '-r', "hello$s\n#MAKE#: *** [#MAKEFILE#:5: hello$s] Error 1\n", 512);
'',
"hello$s\n#MAKE#: *** [#MAKEFILE#:5: hello$s] Error 1\n",
512);
} }
} }
@ -153,21 +149,21 @@ all: hello.tsk
%.tsk: %$s; \$(info hello.tsk) %.tsk: %$s; \$(info hello.tsk)
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", '', "$result", $rcode); ", '-r', "$result", $rcode);
run_make_test(" run_make_test("
all: hello.tsk all: hello.tsk
%.tsk: %$s hello$s; \$(info hello.tsk) %.tsk: %$s hello$s; \$(info hello.tsk)
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", '', $result, $rcode); ", '-r', $result, $rcode);
run_make_test(" run_make_test("
all: hello.tsk all: hello.tsk
%.tsk: %$s; \$(info hello.tsk) %.tsk: %$s; \$(info hello.tsk)
%$s:$r %.c hello$s; \$(info hello.c) %$s:$r %.c hello$s; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", '', $result, $rcode); ", '-r', $result, $rcode);
} }
} }
@ -180,8 +176,7 @@ all: hello.tsk
%.tsk: %.o; \$(info hello.tsk) %.tsk: %.o; \$(info hello.tsk)
%.o:$r %.c; \$(info hello.c) %.o:$r %.c; \$(info hello.c)
%.o:$r %.f %.tsk; \$(info hello.f) %.o:$r %.f %.tsk; \$(info hello.f)
", ", '-r',
'-R',
"#MAKE#: Circular hello.o <- hello.tsk dependency dropped.\nhello.f\nhello.tsk\n#MAKE#: Nothing to be done for 'all'."); "#MAKE#: Circular hello.o <- hello.tsk dependency dropped.\nhello.f\nhello.tsk\n#MAKE#: Nothing to be done for 'all'.");
} }
@ -196,8 +191,7 @@ hello$s: hello.c
%.tsk: %$s; \$(info hello.tsk) %.tsk: %$s; \$(info hello.tsk)
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
", ", '-r',
'',
"#MAKE#: *** No rule to make target 'hello.c', needed by 'hello$s'. Stop.\n", "#MAKE#: *** No rule to make target 'hello.c', needed by 'hello$s'. Stop.\n",
512); 512);
} }
@ -217,7 +211,7 @@ all: hello.tsk
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
hello.c:; false hello.c:; false
", '', $result, 512); ", '-r', $result, 512);
} }
} }
@ -231,7 +225,7 @@ all: hello.tsk
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
unrelated: hello$s unrelated: hello$s
", '', "hello.f\nhello.tsk\n#MAKE#: Nothing to be done for 'all'."); ", '-r', "hello.f\nhello.tsk\n#MAKE#: Nothing to be done for 'all'.");
} }
} }
@ -250,7 +244,7 @@ all: hello.tsk
%.tsk: %$s; \$(info hello.tsk) %.tsk: %$s; \$(info hello.tsk)
%$s:$r %.c; \$(info hello.c) %$s:$r %.c; \$(info hello.c)
%$s:$r %.f hello.f; \$(info hello.f) %$s:$r %.f hello.f; \$(info hello.f)
", '', $result, $rcode); ", '-r', $result, $rcode);
} }
} }
@ -271,8 +265,7 @@ all: hello.tsk
%$s:$r %.f; \$(info hello.f) %$s:$r %.f; \$(info hello.f)
unrelated: hello$s unrelated: hello$s
%.x:$r %.z; \$(info hello.z) %.x:$r %.z; \$(info hello.z)
", ", '-r',
'',
"#MAKE#: *** No rule to make target 'hello$s', needed by 'hello.tsk'. Stop.\n", "#MAKE#: *** No rule to make target 'hello$s', needed by 'hello.tsk'. Stop.\n",
512); 512);
} }
@ -287,7 +280,7 @@ all: hello.tsk
%.tsk: %.x; touch hello.tsk %.tsk: %.x; touch hello.tsk
%.x: ; %.x: ;
unrelated: hello.x unrelated: hello.x
", '', "touch hello.tsk\n"); ", '-r', "touch hello.tsk\n");
unlink('hello.tsk'); unlink('hello.tsk');
touch ('hello.f'); touch ('hello.f');
@ -312,8 +305,7 @@ all: hello.o
# hello.c prerequisite causes '%: %.c' rule to be chosen. # hello.c prerequisite causes '%: %.c' rule to be chosen.
run_make_test(q! run_make_test(q!
hello: hello.c hello: hello.c
!, !, 'FC="@echo f77" OUTPUT_OPTION=',
'FC="@echo f77" OUTPUT_OPTION=',
"#MAKE#: *** No rule to make target 'hello.c', needed by 'hello'. Stop.\n", "#MAKE#: *** No rule to make target 'hello.c', needed by 'hello'. Stop.\n",
512); 512);
@ -323,8 +315,7 @@ hello: hello.c
# hello.c prerequisite causes '%.o: %.c' rule to be chosen. # hello.c prerequisite causes '%.o: %.c' rule to be chosen.
run_make_test(q! run_make_test(q!
hello.o: hello.c hello.o: hello.c
!, !, 'FC="@echo f77" OUTPUT_OPTION=',
'FC="@echo f77" OUTPUT_OPTION=',
"#MAKE#: *** No rule to make target 'hello.c', needed by 'hello.o'. Stop.\n", "#MAKE#: *** No rule to make target 'hello.c', needed by 'hello.o'. Stop.\n",
512); 512);
@ -352,8 +343,7 @@ run_make_test(q!
all: hello.o all: hello.o
unrelated: hello.c unrelated: hello.c
%.o: %.f %.o: %.f
!, !, '',
'',
"#MAKE#: *** No rule to make target 'hello.c', needed by 'hello.o'. Stop.\n", "#MAKE#: *** No rule to make target 'hello.c', needed by 'hello.o'. Stop.\n",
512); 512);
@ -366,8 +356,7 @@ run_make_test(q!
all: hello.tsk all: hello.tsk
%.tsk: %; $(info $@ from $<) %.tsk: %; $(info $@ from $<)
unrelated: hello unrelated: hello
!, !, 'FC="@echo f77" OUTPUT_OPTION=',
'FC="@echo f77" OUTPUT_OPTION=',
"f77 hello.f -o hello\nhello.tsk from hello\n"); "f77 hello.f -o hello\nhello.tsk from hello\n");
# In this test the builtin match-anything rule %: %.f cannot be used to build # In this test the builtin match-anything rule %: %.f cannot be used to build
@ -376,8 +365,7 @@ unrelated: hello
run_make_test(q! run_make_test(q!
all: hello.tsk all: hello.tsk
%.tsk: %; $(info $@ from $<) %.tsk: %; $(info $@ from $<)
!, !, 'FC="@echo f77" OUTPUT_OPTION=',
'FC="@echo f77" OUTPUT_OPTION=',
"#MAKE#: *** No rule to make target 'hello.tsk', needed by 'all'. Stop.\n", "#MAKE#: *** No rule to make target 'hello.tsk', needed by 'all'. Stop.\n",
512); 512);
@ -395,8 +383,7 @@ all: hello.tsk
%.tsk: % %.x; $(info $@ from $^) %.tsk: % %.x; $(info $@ from $^)
unrelated: hello unrelated: hello
%.x: %.xx; $(info $@ from $<) %.x: %.xx; $(info $@ from $<)
!, !, 'FC="@echo f77" OUTPUT_OPTION=',
'FC="@echo f77" OUTPUT_OPTION=',
"f77 hello.f -o hello\nhello.x from hello.xx\nhello.tsk from hello hello.x\n"); "f77 hello.f -o hello\nhello.x from hello.xx\nhello.tsk from hello hello.x\n");
unlink('bye.o', 'bye.tsk', 'bye.x'); unlink('bye.o', 'bye.tsk', 'bye.x');
@ -407,7 +394,7 @@ all: bye.tsk
%.tsk: %.o; $(info $@ from $<) %.tsk: %.o; $(info $@ from $<)
.DEFAULT:; $(info bye.o) .DEFAULT:; $(info bye.o)
unrelated: bye.o unrelated: bye.o
!, '', "bye.o\nbye.tsk from bye.o\n#MAKE#: Nothing to be done for 'all'."); !, '-r', "bye.o\nbye.tsk from bye.o\n#MAKE#: Nothing to be done for 'all'.");
touch('bye.xx'); touch('bye.xx');
# This is just like the one above, but compatibility rule '%.tsk: %.o %.x' has 2 # This is just like the one above, but compatibility rule '%.tsk: %.o %.x' has 2
@ -423,7 +410,7 @@ all: bye.tsk
.DEFAULT:; $(info bye.o) .DEFAULT:; $(info bye.o)
unrelated: bye.o unrelated: bye.o
%.x: %.xx; $(info $@ from $<) %.x: %.xx; $(info $@ from $<)
!, '', !, '-r',
"bye.o\nbye.x from bye.xx\nbye.tsk from bye.o bye.x\n#MAKE#: Nothing to be done for 'all'."); "bye.o\nbye.x from bye.xx\nbye.tsk from bye.o bye.x\n#MAKE#: Nothing to be done for 'all'.");
unlink('hello.f', 'hello.z', 'hello.xx', 'bye.xx'); unlink('hello.f', 'hello.z', 'hello.xx', 'bye.xx');
@ -443,7 +430,7 @@ all: hello.tsk
%.tsk: hello.x; $(info $@) %.tsk: hello.x; $(info $@)
%.x:; $(flags) %.x:; $(flags)
hello.x: flags:=true hello.x: flags:=true
!, '', "true\nhello.tsk\n"); !, '-r', "true\nhello.tsk\n");
# Similar to the one above, but this time 'hello.x' is derived from the stem. # Similar to the one above, but this time 'hello.x' is derived from the stem.
run_make_test(q! run_make_test(q!
@ -451,7 +438,7 @@ all: hello.tsk
%.tsk: %.x; $(info $@) %.tsk: %.x; $(info $@)
%.x:; $(flags) %.x:; $(flags)
hello.x: flags:=true hello.x: flags:=true
!, '', "true\nhello.tsk\n"); !, '-r', "true\nhello.tsk\n");
# Similar to the one above, this time 'hello.x' is also mentioned explicitly on # Similar to the one above, this time 'hello.x' is also mentioned explicitly on
# an unrelated rule. # an unrelated rule.
@ -461,7 +448,7 @@ all: hello.tsk
%.x:; $(flags) %.x:; $(flags)
hello.x: flags:=true hello.x: flags:=true
unrelated: hello.x unrelated: hello.x
!, '', "true\nhello.tsk\n"); !, '-r', "true\nhello.tsk\n");
# 'hello.x' has a pattern specific variable. # 'hello.x' has a pattern specific variable.
run_make_test(q! run_make_test(q!
@ -469,7 +456,7 @@ all: hello.tsk
%.tsk: %.x; $(info $@) %.tsk: %.x; $(info $@)
%.x:; $(flags) %.x:; $(flags)
%.x: flags:=true %.x: flags:=true
!, '', "true\nhello.tsk\n"); !, '-r', "true\nhello.tsk\n");
# 'hello.x' has a target specific variable and a pattern specific variable. # 'hello.x' has a target specific variable and a pattern specific variable.
run_make_test(q! run_make_test(q!
@ -478,7 +465,7 @@ all: hello.tsk
%.x:; $(flags) %.x:; $(flags)
hello.x: flags+=good hello.x: flags+=good
%.x: flags:=true %.x: flags:=true
!, '', "true good\nhello.tsk\n"); !, '-r', "true good\nhello.tsk\n");
# Intermediate prerequisite 'hello.x' has a target specific variable, a pattern # Intermediate prerequisite 'hello.x' has a target specific variable, a pattern
# specfic variable, matches on both rules '%.tsk: %.x' and 'big_%.tsk: %.x'. # specfic variable, matches on both rules '%.tsk: %.x' and 'big_%.tsk: %.x'.
@ -489,7 +476,7 @@ big_%.tsk: %.x; $(info $@)
%.x:; $(flags) %.x:; $(flags)
hello.x: flags+=good hello.x: flags+=good
%.x: flags:=true %.x: flags:=true
!, '', "true good\nhello.tsk\nbig_hello.tsk\n"); !, '-r', "true good\nhello.tsk\nbig_hello.tsk\n");
# This tells the test driver that the perl test script executed properly. # This tells the test driver that the perl test script executed properly.