2005-12-13 22:44:17 +08:00
|
|
|
# -*-perl-*-
|
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
$description = "Test ignored failures in recipe command lines";
|
|
|
|
|
|
|
|
run_make_test(qq!
|
|
|
|
one:
|
|
|
|
\t-exit 1
|
|
|
|
\texit 0
|
|
|
|
two:
|
|
|
|
\texit 1
|
|
|
|
\texit 0
|
|
|
|
!,
|
2019-09-23 05:02:57 +08:00
|
|
|
"one", "exit 1\n#MAKE#: [#MAKEFILE#:3: one] Error 1 (ignored)\nexit 0\n");
|
1999-09-14 10:03:19 +08:00
|
|
|
|
|
|
|
# TEST #1
|
|
|
|
# -------
|
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
run_make_test(undef, " -i two",
|
2019-09-23 05:02:57 +08:00
|
|
|
"exit 1\n#MAKE#: [#MAKEFILE#:6: two] Error 1 (ignored)\nexit 0\n");
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
# TEST #2
|
|
|
|
# -------
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
# Test that error line offset works
|
2004-05-17 03:16:52 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
run_make_test(qq!
|
|
|
|
all:
|
|
|
|
\t\@echo hi
|
|
|
|
\t\@echo there
|
|
|
|
\t\@exit 1
|
|
|
|
!,
|
2019-09-23 05:02:57 +08:00
|
|
|
'', "hi\nthere\n#MAKE#: *** [#MAKEFILE#:5: all] Error 1", 512);
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2021-11-29 03:17:55 +08:00
|
|
|
# Windows error look completely different :-/
|
|
|
|
|
|
|
|
sub errors_getinfo
|
|
|
|
{
|
|
|
|
my ($cmd, $args) = @_;
|
|
|
|
if ($port_type eq 'W32') {
|
|
|
|
return (2, "process_begin: CreateProcess(NULL, $cmd $args, ...) failed.\nmake (e=2): The system cannot find the file specified.");
|
|
|
|
}
|
|
|
|
|
|
|
|
return (127, "#MAKE#: $cmd: $ERR_no_such_file");
|
|
|
|
}
|
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
# TEST #3
|
|
|
|
# -------
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
# Try failing due to unknown command
|
|
|
|
my $unk = './foobarbazbozblat';
|
|
|
|
unlink($unk);
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2022-04-19 04:57:06 +08:00
|
|
|
my ($ernum, $erstr) = errors_getinfo($unk, "xx yy");
|
2018-08-05 00:20:11 +08:00
|
|
|
run_make_test(qq!
|
|
|
|
one: ; -$unk xx yy
|
2021-11-29 03:17:55 +08:00
|
|
|
!, 'one',
|
|
|
|
"$unk xx yy\n$erstr\n#MAKE#: [#MAKEFILE#:2: one] Error $ernum (ignored)\n");
|
2018-08-05 00:20:11 +08:00
|
|
|
|
|
|
|
# TEST #4
|
1999-09-14 10:03:19 +08:00
|
|
|
# -------
|
|
|
|
|
2021-11-29 03:17:55 +08:00
|
|
|
($ernum, $erstr) = errors_getinfo($unk, "aa bb");
|
2019-09-22 03:11:21 +08:00
|
|
|
run_make_test(qq!
|
|
|
|
two: ; $unk aa bb
|
|
|
|
!, 'two -i',
|
2021-11-29 03:17:55 +08:00
|
|
|
"$unk aa bb\n$erstr\n#MAKE#: [#MAKEFILE#:2: two] Error $ernum (ignored)\n");
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
# TEST #5
|
|
|
|
# -------
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
run_make_test(undef, 'two',
|
2021-11-29 03:17:55 +08:00
|
|
|
"$unk aa bb\n$erstr\n#MAKE#: *** [#MAKEFILE#:2: two] Error $ernum\n", 512);
|
2019-09-22 03:11:21 +08:00
|
|
|
|
|
|
|
# SV #56918 : Test the unknown command as the second recipe line
|
|
|
|
|
2021-11-29 03:17:55 +08:00
|
|
|
($ernum, $erstr) = errors_getinfo($unk, "qq rr");
|
2019-09-22 03:11:21 +08:00
|
|
|
run_make_test(qq!
|
|
|
|
three:
|
|
|
|
\t\@echo one
|
|
|
|
\t$unk qq rr
|
|
|
|
!, 'three',
|
2021-11-29 03:17:55 +08:00
|
|
|
"one\n$unk qq rr\n$erstr\n#MAKE#: *** [#MAKEFILE#:4: three] Error $ernum\n", 512);
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
# Try failing due to non-executable file
|
1999-09-14 10:03:19 +08:00
|
|
|
|
2019-09-15 03:41:58 +08:00
|
|
|
if ($ERR_nonexe_file) {
|
|
|
|
my $noexe = './barfooblatboz';
|
|
|
|
touch($noexe);
|
|
|
|
|
|
|
|
run_make_test(qq!
|
|
|
|
one: ; -$noexe xx yy
|
|
|
|
two: ; $noexe aa bb
|
|
|
|
!,
|
2019-09-23 05:02:57 +08:00
|
|
|
'one', "$noexe xx yy\n#MAKE#: $noexe: $ERR_nonexe_file\n#MAKE#: [#MAKEFILE#:2: one] Error 127 (ignored)\n");
|
2019-09-15 03:41:58 +08:00
|
|
|
|
|
|
|
unlink($noexe);
|
|
|
|
}
|
2016-04-11 05:12:48 +08:00
|
|
|
|
2019-09-15 03:58:57 +08:00
|
|
|
# Try failing by "running" a directory
|
|
|
|
|
|
|
|
if ($ERR_exe_dir) {
|
|
|
|
mkdir('sd', 0775);
|
|
|
|
|
|
|
|
run_make_test(q!
|
|
|
|
PATH := .
|
|
|
|
all: ; sd
|
|
|
|
!,
|
2019-09-23 05:02:57 +08:00
|
|
|
'', "sd\n#MAKE#: sd: $ERR_exe_dir\n#MAKE#: *** [#MAKEFILE#:3: all] Error 127", 512);
|
2019-09-15 03:58:57 +08:00
|
|
|
|
|
|
|
run_make_test(q!
|
|
|
|
all: ; ./sd
|
|
|
|
!,
|
2019-09-23 05:02:57 +08:00
|
|
|
'', "./sd\n#MAKE#: ./sd: $ERR_exe_dir\n#MAKE#: *** [#MAKEFILE#:2: all] Error 127", 512);
|
2019-09-15 03:58:57 +08:00
|
|
|
|
|
|
|
rmdir('sd');
|
|
|
|
}
|
|
|
|
|
2018-08-05 00:20:11 +08:00
|
|
|
1;
|