1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
|
#!/usr/bin/perl -w
# This tests MakeMaker against recursive builds
BEGIN {
unshift @INC, 't/lib';
}
use strict;
use Config;
use Test::More
$ENV{PERL_CORE} && $Config{'usecrosscompile'}
? (skip_all => "no toolchain installed when cross-compiling")
: (tests => 26);
use File::Temp qw[tempdir];
use MakeMaker::Test::Utils;
use MakeMaker::Test::Setup::Recurs;
# 'make disttest' sets a bunch of environment variables which interfere
# with our testing.
delete @ENV{qw(PREFIX LIB MAKEFLAGS)};
my $perl = which_perl();
my $Is_VMS = $^O eq 'VMS';
my $tmpdir = tempdir( DIR => 't', CLEANUP => 1 );
chdir $tmpdir;
perl_lib;
my $Touch_Time = calibrate_mtime();
$| = 1;
ok( setup_recurs(), 'setup' );
END {
ok( chdir File::Spec->updir );
ok( teardown_recurs(), 'teardown' );
}
ok( chdir('Recurs'), q{chdir'd to Recurs} ) ||
diag("chdir failed: $!");
# Check recursive Makefile building.
my @mpl_out = run(qq{$perl Makefile.PL});
cmp_ok( $?, '==', 0, 'Makefile.PL exited with zero' ) ||
diag(@mpl_out);
my $makefile = makefile_name();
ok( -e $makefile, 'Makefile written' );
ok( -e File::Spec->catfile('prj2',$makefile), 'sub Makefile written' );
my $make = make_run();
my $make_out = run("$make");
is( $?, 0, 'recursive make exited normally' ) || diag $make_out;
ok( chdir File::Spec->updir );
ok( teardown_recurs(), 'cleaning out recurs' );
ok( setup_recurs(), ' setting up fresh copy' );
ok( chdir('Recurs'), q{chdir'd to Recurs} ) ||
diag("chdir failed: $!");
# Check NORECURS
@mpl_out = run(qq{$perl Makefile.PL "NORECURS=1"});
cmp_ok( $?, '==', 0, 'Makefile.PL NORECURS=1 exited with zero' ) ||
diag(@mpl_out);
$makefile = makefile_name();
ok( -e $makefile, 'Makefile written' );
ok( !-e File::Spec->catfile('prj2',$makefile), 'sub Makefile not written' );
$make = make_run();
run("$make");
is( $?, 0, 'recursive make exited normally' );
ok( chdir File::Spec->updir );
ok( teardown_recurs(), 'cleaning out recurs' );
ok( setup_recurs(), ' setting up fresh copy' );
ok( chdir('Recurs'), q{chdir'd to Recurs} ) ||
diag("chdir failed: $!");
# Check that arguments aren't stomped when they have .. prepended
# [rt.perl.org 4345]
@mpl_out = run(qq{$perl Makefile.PL "INST_SCRIPT=cgi"});
cmp_ok( $?, '==', 0, 'Makefile.PL exited with zero' ) ||
diag(@mpl_out);
$makefile = makefile_name();
my $submakefile = File::Spec->catfile('prj2',$makefile);
ok( -e $makefile, 'Makefile written' );
ok( -e $submakefile, 'sub Makefile written' );
my $inst_script = File::Spec->catdir(File::Spec->updir, 'cgi');
ok( open(MAKEFILE, $submakefile) ) || diag("Can't open $submakefile: $!");
{ local $/;
like( <MAKEFILE>, qr/^\s*INST_SCRIPT\s*=\s*\Q$inst_script\E/m,
'prepend .. not stomping WriteMakefile args' )
}
close MAKEFILE;
{
# Quiet "make test" failure noise
close *STDERR;
my $test_out = run("$make test");
isnt $?, 0, 'test failure in a subdir causes make to fail';
}
|