X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=t%2Fbuildsystems%2Fbuildsystem_tests;h=1a9e21ca3508b4b81bf160c64dce310d8b1b936d;hb=bd97b09925d8e72b19804f831bc6237509bfbff1;hp=a2b451a96699f77a7079c1100da94bc0df053235;hpb=e71d6861d8a40562512b934a70ebde0bb1b2518b;p=debhelper.git diff --git a/t/buildsystems/buildsystem_tests b/t/buildsystems/buildsystem_tests index a2b451a..1a9e21c 100755 --- a/t/buildsystems/buildsystem_tests +++ b/t/buildsystems/buildsystem_tests @@ -1,6 +1,6 @@ #!/usr/bin/perl -use Test::More tests => 224; +use Test::More tests => 291; use strict; use warnings; @@ -19,7 +19,6 @@ use_ok( 'Debian::Debhelper::Dh_Buildsystems' ); my $TOPDIR = "../.."; my @STEPS = qw(configure build test install clean); -my @BUILDSYSTEMS = qw(autoconf perl_makemaker makefile python_distutils perl_build cmake); my $BS_CLASS = 'Debian::Debhelper::Buildsystem'; my ($bs, @bs, %bs); @@ -50,25 +49,54 @@ sub process_stdout { my ($cmdline, $stdin) = @_; my ($reader, $writer); - open2($reader, $writer, $cmdline) or die "Unable to exec $cmdline"; + my $pid = open2($reader, $writer, $cmdline) or die "Unable to exec $cmdline"; print $writer $stdin if $stdin; close $writer; + waitpid($pid, 0); + $? = $? >> 8; # exit status return readlines($reader); } +sub write_debian_rules { + my $contents=shift; + my $backup; + + if (-f "debian/rules") { + (undef, $backup) = tempfile(DIR => ".", OPEN => 0); + rename "debian/rules", $backup; + } + # Write debian/rules if requested + if ($contents) { + open(my $f, ">", "debian/rules"); + print $f $contents;; + close($f); + chmod 0755, "debian/rules"; + } + return $backup; +} + ### Test Buildsystem class API methods -is( $BS_CLASS->_canonpath("path/to/the/./nowhere/../../somewhere"), - "path/to/somewhere", "_canonpath no1" ); -is( $BS_CLASS->_canonpath("path/to/../forward/../../somewhere"), - "somewhere","_canonpath no2" ); -is( $BS_CLASS->_canonpath("path/to/../../../somewhere"), - "../somewhere","_canonpath no3" ); -is( $BS_CLASS->_rel2rel("path/my/file", "path/my"), +is( $BS_CLASS->canonpath("path/to/the/./nowhere/../../somewhere"), + "path/to/somewhere", "canonpath no1" ); +is( $BS_CLASS->canonpath("path/to/../forward/../../somewhere"), + "somewhere","canonpath no2" ); +is( $BS_CLASS->canonpath("path/to/../../../somewhere"), + "../somewhere","canonpath no3" ); +is( $BS_CLASS->canonpath("./"), ".", "canonpath no4" ); +is( $BS_CLASS->canonpath("/absolute/path/./somewhere/../to/nowhere"), + "/absolute/path/to/nowhere", "canonpath no5" ); +is( $BS_CLASS->_rel2rel("path/my/file", "path/my", "/tmp"), "file", "_rel2rel no1" ); -is( $BS_CLASS->_rel2rel("path/dir/file", "path/my"), +is( $BS_CLASS->_rel2rel("path/dir/file", "path/my", "/tmp"), "../dir/file", "_rel2rel no2" ); is( $BS_CLASS->_rel2rel("file", "/root/path/my", "/root"), - "../../file", "_rel2rel no3" ); + "/root/file", "_rel2rel abs no3" ); +is( $BS_CLASS->_rel2rel(".", ".", "/tmp"), ".", "_rel2rel no4" ); +is( $BS_CLASS->_rel2rel("path", "path/", "/tmp"), ".", "_rel2rel no5" ); +is( $BS_CLASS->_rel2rel("/absolute/path", "anybase", "/tmp"), + "/absolute/path", "_rel2rel abs no6"); +is( $BS_CLASS->_rel2rel("relative/path", "/absolute/base", "/tmp"), + "/tmp/relative/path", "_rel2rel abs no7"); ### Test Buildsystem class path API methods under different configurations sub test_buildsystem_paths_api { @@ -126,24 +154,18 @@ $bs = $BS_CLASS->new(builddir => undef, sourcedir => "autoconf"); %tmp = ( "get_sourcedir()" => "autoconf", "get_sourcepath(a/b)" => "autoconf/a/b", - "get_builddir()" => "autoconf/$default_builddir", - "get_buildpath()" => "autoconf/$default_builddir", - "get_buildpath(a/b)" => "autoconf/$default_builddir/a/b", - "get_source_rel2builddir()" => "..", - "get_source_rel2builddir(a/b)" => "../a/b", - "get_build_rel2sourcedir()" => "$default_builddir", - "get_build_rel2sourcedir(a/b)" => "$default_builddir/a/b", + "get_builddir()" => "$default_builddir", + "get_buildpath()" => "$default_builddir", + "get_buildpath(a/b)" => "$default_builddir/a/b", + "get_source_rel2builddir()" => "../autoconf", + "get_source_rel2builddir(a/b)" => "../autoconf/a/b", + "get_build_rel2sourcedir()" => "../$default_builddir", + "get_build_rel2sourcedir(a/b)" => "../$default_builddir/a/b", ); test_buildsystem_paths_api($bs, "default builddir, sourcedir=autoconf", \%tmp); -# Enforced out of source tree building -# sourcedir=builddir=autoconf hence default builddir is implied -$bs = $BS_CLASS->new(builddir => "./autoconf", sourcedir => "autoconf/"); -$bs->enforce_out_of_source_building(); -test_buildsystem_paths_api($bs, "out of source enforced, sourcedir=autoconf/", \%tmp); - # sourcedir=autoconf (builddir should be dropped) -$bs = $BS_CLASS->new(builddir => ".", sourcedir => "autoconf"); +$bs = $BS_CLASS->new(builddir => "autoconf", sourcedir => "autoconf"); %tmp = ( "get_sourcedir()" => "autoconf", "get_sourcepath(a/b)" => "autoconf/a/b", @@ -157,13 +179,18 @@ $bs = $BS_CLASS->new(builddir => ".", sourcedir => "autoconf"); ); test_buildsystem_paths_api($bs, "no builddir, sourcedir=autoconf", \%tmp); +# Prefer out of source tree building when +# sourcedir=builddir=autoconf hence builddir should be dropped. +$bs->prefer_out_of_source_building(builddir => "autoconf"); +test_buildsystem_paths_api($bs, "out of source prefered, sourcedir=builddir", \%tmp); + # builddir=bld/dir, sourcedir=autoconf. Should be the same as sourcedir=autoconf. $bs = $BS_CLASS->new(builddir => "bld/dir", sourcedir => "autoconf"); $bs->enforce_in_source_building(); test_buildsystem_paths_api($bs, "in source enforced, sourcedir=autoconf", \%tmp); -# builddir=../bld/dir (relative to the sourcedir) -$bs = $BS_CLASS->new(builddir => "../bld/dir/", sourcedir => "autoconf"); +# builddir=../bld/dir (relative to the curdir) +$bs = $BS_CLASS->new(builddir => "bld/dir/", sourcedir => "autoconf"); %tmp = ( "get_sourcedir()" => "autoconf", "get_sourcepath(a/b)" => "autoconf/a/b", @@ -177,15 +204,6 @@ $bs = $BS_CLASS->new(builddir => "../bld/dir/", sourcedir => "autoconf"); ); test_buildsystem_paths_api($bs, "builddir=../bld/dir, sourcedir=autoconf", \%tmp); -# Builddir relative to the pwd (same path as above). -$bs = $BS_CLASS->new(builddir => "./bld/dir", sourcedir => "autoconf"); -test_buildsystem_paths_api($bs, "builddir=./bld/dir, sourcedir=autoconf", \%tmp); - -### Test if all buildsystems can be loaded -@bs = load_all_buildsystems([ $INC[0] ]); -@tmp = map { $_->NAME() } @bs; -is_deeply( \@tmp, \@BUILDSYSTEMS, "load_all_buildsystems() loads all built-in buildsystems" ); - ### Test check_auto_buildable() of each buildsystem sub test_check_auto_buildable { my $bs=shift; @@ -205,14 +223,8 @@ sub test_check_auto_buildable { } elsif (exists $expected->{default}) { $e = $expected->{default}; } - if ($e) { - ok( $bs->check_auto_buildable($step), - $bs->NAME() . "($config): check_auto_buildable($step)" ); - } - else { - ok( ! $bs->check_auto_buildable($step), - $bs->NAME() . "($config): ! check_auto_buildable($step)" ); - } + is( $bs->check_auto_buildable($step), $e, + $bs->NAME() . "($config): check_auto_buildable($step) == $e" ); } } @@ -220,19 +232,25 @@ $tmpdir = tempdir("tmp.XXXXXX"); $builddir = "$tmpdir/builddir"; mkdir $builddir; %tmp = ( - builddir => 'builddir', + builddir => "$tmpdir/builddir", sourcedir => $tmpdir ); -$bs{autoconf} = load_buildsystem("autoconf", undef, %tmp); -$bs{cmake} = load_buildsystem("cmake", undef, %tmp); -$bs{perl_mm} = load_buildsystem("perl_makemaker", undef, %tmp); -$bs = load_buildsystem("makefile", undef, %tmp); +# Test if all buildsystems can be loaded +@bs = load_all_buildsystems([ $INC[0] ], %tmp); +@tmp = map { $_->NAME() } @bs; +ok(@Debian::Debhelper::Dh_Buildsystems::BUILDSYSTEMS >= 1, "some build systems are built in" ); +is_deeply( \@tmp, \@Debian::Debhelper::Dh_Buildsystems::BUILDSYSTEMS, "load_all_buildsystems() loads all built-in buildsystems" ); -test_check_auto_buildable($bs{autoconf}, "no configure", 0); -test_check_auto_buildable($bs{cmake}, "no CMakeLists.txt", 0); -test_check_auto_buildable($bs{perl_mm}, "no Makefile.PL", 0); -test_check_auto_buildable($bs, "no Makefile", 0); +# check_auto_buildable() fails with numeric 0 +for $bs (@bs) { + test_check_auto_buildable($bs, "fails with numeric 0", 0); +} + +%bs = (); +for $bs (@bs) { + $bs{$bs->NAME()} = $bs; +} touch "$tmpdir/configure", 0755; test_check_auto_buildable($bs{autoconf}, "configure", { configure => 1 }); @@ -241,54 +259,59 @@ touch "$tmpdir/CMakeLists.txt"; test_check_auto_buildable($bs{cmake}, "CMakeLists.txt", { configure => 1 }); touch "$tmpdir/Makefile.PL"; -test_check_auto_buildable($bs{perl_mm}, "Makefile.PL", - { configure => 1, install => 1 }); +test_check_auto_buildable($bs{perl_makemaker}, "Makefile.PL", { configure => 1 }); # With Makefile touch "$builddir/Makefile"; -test_check_auto_buildable($bs, "Makefile", { configure => 0, default => 1 }); +test_check_auto_buildable($bs{makefile}, "Makefile", 1); test_check_auto_buildable($bs{autoconf}, "configure+Makefile", { configure => 1 }); test_check_auto_buildable($bs{cmake}, "CMakeLists.txt+Makefile", 1); +touch "$builddir/CMakeCache.txt"; # strong evidence that cmake was run +test_check_auto_buildable($bs{cmake}, "CMakeCache.txt+Makefile", 2); # Makefile.PL forces in-source #(see note in check_auto_buildable() why always 1 here) unlink "$builddir/Makefile"; touch "$tmpdir/Makefile"; -test_check_auto_buildable($bs{perl_mm}, "Makefile.PL+Makefile", 1); +test_check_auto_buildable($bs{perl_makemaker}, "Makefile.PL+Makefile", 1); # Perl Build.PL - handles always -$bs = load_buildsystem("perl_build", undef, %tmp); -test_check_auto_buildable($bs, "no Build.PL", 0); +test_check_auto_buildable($bs{perl_build}, "no Build.PL", 0); touch "$tmpdir/Build.PL"; -test_check_auto_buildable($bs, "Build.PL", { configure => 1 }); +test_check_auto_buildable($bs{perl_build}, "Build.PL", { configure => 1 }); touch "$tmpdir/Build"; # forced in source -test_check_auto_buildable($bs, "Build.PL+Build", 1); +test_check_auto_buildable($bs{perl_build}, "Build.PL+Build", 1); # Python Distutils -$bs = load_buildsystem("python_distutils", undef, %tmp); -test_check_auto_buildable($bs, "no setup.py", 0); +test_check_auto_buildable($bs{python_distutils}, "no setup.py", 0); touch "$tmpdir/setup.py"; -test_check_auto_buildable($bs, "setup.py", 1); +test_check_auto_buildable($bs{python_distutils}, "setup.py", 1); cleandir($tmpdir); ### Now test if it can autoselect a proper buildsystem for a typical package sub test_autoselection { - my $system=shift; + my $testname=shift; my $expected=shift; + my %args=@_; for my $step (@STEPS) { my $bs = load_buildsystem(undef, $step, @_); my $e = $expected; $e = $expected->{$step} if ref $expected; if (defined $bs) { - is( $bs->NAME(), $e, "autoselection($system): $step=".((defined $e)?$e:'undef') ); + is( $bs->NAME(), $e, "autoselection($testname): $step=".((defined $e)?$e:'undef') ); } else { - is ( undef, $e, "autoselection($system): $step=".((defined $e)?$e:'undef') ); + is ( undef, $e, "autoselection($testname): $step=".((defined $e)?$e:'undef') ); } + &{$args{"code_$step"}}() if exists $args{"code_$step"}; } } +# Auto-select nothing when no supported build system can be found +# (see #557006). +test_autoselection("auto-selects nothing", undef, %tmp); + # Autoconf touch "$tmpdir/configure", 0755; touch "$builddir/Makefile"; @@ -305,8 +328,7 @@ cleandir $tmpdir; # Makefile touch "$builddir/Makefile"; -test_autoselection("makefile", { build => "makefile", test => "makefile", - install => "makefile", clean => "makefile" }, %tmp); +test_autoselection("makefile", "makefile", %tmp); cleandir $tmpdir; # Python Distutils @@ -321,11 +343,58 @@ test_autoselection("perl_build", "perl_build", %tmp); cleandir $tmpdir; # CMake +touch "$tmpdir/CMakeLists.txt"; +$tmp = sub { + touch "$builddir/Makefile"; +}; +test_autoselection("cmake without CMakeCache.txt", + { configure => "cmake", build => "makefile", + test => "makefile", install => "makefile", clean => "makefile" }, %tmp, + code_configure => $tmp); +cleandir $tmpdir; + +touch "$tmpdir/CMakeLists.txt"; +$tmp = sub { + touch "$builddir/Makefile"; + touch "$builddir/CMakeCache.txt"; +}; +test_autoselection("cmake with CMakeCache.txt", + "cmake", %tmp, code_configure => $tmp); +cleandir $tmpdir; + touch "$tmpdir/CMakeLists.txt"; touch "$builddir/Makefile"; -test_autoselection("cmake", - { configure => "cmake", build => "makefile", - test => "makefile", install => "makefile", clean => "makefile" }, %tmp); +test_autoselection("cmake and existing Makefile", "makefile", %tmp); +cleandir $tmpdir; + +### Test Buildsystem::rmdir_builddir() +sub do_rmdir_builddir { + my $builddir=shift; + my $system; + $system = $BS_CLASS->new(builddir => $builddir, sourcedir => $tmpdir); + $system->mkdir_builddir(); + $system->rmdir_builddir(); +} + +$builddir = "$tmpdir/builddir"; +do_rmdir_builddir($builddir); +ok ( ! -e $builddir, "testing rmdir_builddir() 1: builddir parent '$builddir' deleted" ); +ok ( -d $tmpdir, "testing rmdir_builddir() 1: sourcedir '$tmpdir' remains" ); + +$builddir = "$tmpdir/bld"; +do_rmdir_builddir("$builddir/dir"); +ok ( ! -e $builddir, "testing rmdir_builddir() 2: builddir parent '$builddir' deleted" ); +ok ( -d $tmpdir, "testing rmdir_builddir() 2: sourcedir '$tmpdir' remains" ); + +$builddir = "$tmpdir/bld"; +mkdir "$builddir"; +touch "$builddir/afile"; +mkdir "$builddir/dir"; +touch "$builddir/dir/afile2"; +do_rmdir_builddir("$builddir/dir"); +ok ( ! -e "$builddir/dir", "testing rmdir_builddir() 3: builddir '$builddir/dir' not empty, but deleted" ); +ok ( -d $builddir, "testing rmdir_builddir() 3: builddir parent '$builddir' not empty, remains" ); + cleandir $tmpdir; ### Test buildsystems_init() and commandline/env argument handling @@ -349,17 +418,20 @@ if (defined \$bs) { EOF } -is_deeply( process_stdout("DH_AUTO_OPTIONS='--builddirectory=bld\\ dir --sourcedirectory autoconf' $^X -- -", +$tmp = Cwd::getcwd(); +# NOTE: disabling parallel building explicitly (it might get automatically +# enabled if run under dpkg-buildpackage -jX) to make output deterministic. +is_deeply( process_stdout("$^X -- - --builddirectory='autoconf/bld dir' --sourcedirectory autoconf --max-parallel=1", get_load_bs_source(undef, "configure")), - [ 'NAME=autoconf', 'builddir=autoconf/bld dir', 'makecmd=make', 'sourcedir=autoconf' ], - "dh_auto_options w/space, autoconf autoselection and sourcedir/builddir" ); + [ 'NAME=autoconf', 'builddir=autoconf/bld dir', "cwd=$tmp", 'makecmd=make', 'parallel=1', 'sourcedir=autoconf' ], + "autoconf autoselection and sourcedir/builddir" ); -is_deeply( process_stdout("$^X -- - -cautoconf -d autoconf", get_load_bs_source("autoconf", "build")), - [ 'NAME=autoconf', 'builddir=undef', 'makecmd=make', 'sourcedir=autoconf' ], +is_deeply( process_stdout("$^X -- - -Sautoconf -D autoconf --max-parallel=1", get_load_bs_source("autoconf", "build")), + [ 'NAME=autoconf', 'builddir=undef', "cwd=$tmp", 'makecmd=make', 'parallel=1', 'sourcedir=autoconf' ], "forced autoconf and sourcedir" ); -is_deeply( process_stdout("$^X -- - -b -cautoconf", get_load_bs_source("autoconf", "build")), - [ 'NAME=autoconf', "builddir=$default_builddir", 'makecmd=make', 'sourcedir=.' ], +is_deeply( process_stdout("$^X -- - -B -Sautoconf --max-parallel=1", get_load_bs_source("autoconf", "build")), + [ 'NAME=autoconf', "builddir=$default_builddir", "cwd=$tmp", 'makecmd=make', 'parallel=1', 'sourcedir=.' ], "forced autoconf and default build directory" ); # Build the autoconf test package @@ -370,12 +442,12 @@ sub dh_auto_do_autoconf { my (@lines, @extra_args); my $buildpath = $sourcedir; - my @dh_auto_args = ("-d", $sourcedir); - my $dh_auto_str = "-d $sourcedir"; + my @dh_auto_args = ("-D", $sourcedir); + my $dh_auto_str = "-D $sourcedir"; if ($builddir) { - push @dh_auto_args, "-b", $builddir; - $dh_auto_str .= " -b $builddir"; - $buildpath .= "/$builddir"; + push @dh_auto_args, "-B", $builddir; + $dh_auto_str .= " -B $builddir"; + $buildpath = $builddir; } my $do_dh_auto = sub { @@ -422,7 +494,148 @@ sub dh_auto_do_autoconf { dh_auto_do_autoconf('autoconf'); dh_auto_do_autoconf('autoconf', 'bld/dir', configure_args => [ "--extra-autoconf-configure-arg" ]); -ok ( ! -e 'autoconf/bld', "autoconf/bld got deleted too" ); +ok ( ! -e 'bld', "bld got deleted too" ); + +#### Test parallel building and related options / routines +@tmp = ( $ENV{MAKEFLAGS}, $ENV{DEB_BUILD_OPTIONS} ); + +# Test is_make_jobserver_unavailable and clean_jobserver_makeflags. + +$ENV{MAKEFLAGS} = "--jobserver-fds=103,104 -j"; +ok(is_make_jobserver_unavailable(), "unavailable jobserver" ); +clean_jobserver_makeflags(); +ok(! exists $ENV{MAKEFLAGS}, "unset makeflags"); + +$ENV{MAKEFLAGS} = "-a --jobserver-fds=103,104 -j -b"; +ok(is_make_jobserver_unavailable(), "unavailable jobserver" ); +clean_jobserver_makeflags(); +is($ENV{MAKEFLAGS}, "-a -b", "clean makeflags"); + +$ENV{MAKEFLAGS} = " --jobserver-fds=1,2 -j "; +ok(! is_make_jobserver_unavailable(), "available jobserver" ); +clean_jobserver_makeflags(); +ok(! exists $ENV{MAKEFLAGS}, "unset makeflags"); + +$ENV{MAKEFLAGS} = "-a -j -b"; +ok(! is_make_jobserver_unavailable(), "no specified jobserver"); +clean_jobserver_makeflags(); +is($ENV{MAKEFLAGS}, "-a -j -b", "clean makeflags does not remove -j"); + +$ENV{MAKEFLAGS} = "-a --jobs -b"; +ok(! is_make_jobserver_unavailable(), "no specified jobserver"); +clean_jobserver_makeflags(); +is($ENV{MAKEFLAGS}, "-a --jobs -b", "clean makeflags does not remove --jobs"); + +$ENV{MAKEFLAGS} = "-j6"; +ok(! is_make_jobserver_unavailable(), "no specified jobserver"); +clean_jobserver_makeflags(); +is($ENV{MAKEFLAGS}, "-j6", "clean makeflags does not remove -j6"); + +$ENV{MAKEFLAGS} = "-a -j6 --jobs=7"; +ok(! is_make_jobserver_unavailable(), "no specified jobserver"); +clean_jobserver_makeflags(); +is($ENV{MAKEFLAGS}, "-a -j6 --jobs=7", "clean makeflags does not remove -j or --jobs"); + +$ENV{MAKEFLAGS} = "-j6 --jobserver-fds=5,6 --jobs=8"; +ok(is_make_jobserver_unavailable(), "unavailable jobserver"); +clean_jobserver_makeflags(); +is($ENV{MAKEFLAGS}, "-j6 --jobs=8", "jobserver options removed"); + +# Test parallel building with makefile build system. +$ENV{MAKEFLAGS} = ""; +$ENV{DEB_BUILD_OPTIONS} = ""; + +sub do_parallel_mk { + my $dh_opts=shift || ""; + my $make_opts=shift || ""; + return process_stdout( + "LANG=C LC_ALL=C LC_MESSAGES=C $TOPDIR/dh_auto_build -Smakefile $dh_opts " . + "-- -s -f parallel.mk $make_opts 2>&1 >/dev/null", ""); +} + +sub test_isnt_parallel { + my ($got, $desc) = @_; + my @makemsgs = grep /^make[\d\[\]]*:/, @$got; + if (@makemsgs) { + like( $makemsgs[0], qr/Error 10/, $desc ); + } + else { + ok( scalar(@makemsgs) > 0, $desc ); + } +} + +sub test_is_parallel { + my ($got, $desc) = @_; + is_deeply( $got, [] , $desc ); + is( $?, 0, "(exit status=0) $desc"); +} + +test_isnt_parallel( do_parallel_mk(), + "No parallel by default" ); + +$ENV{DEB_BUILD_OPTIONS}="parallel=5"; +test_isnt_parallel( do_parallel_mk(), + "DEB_BUILD_OPTIONS=parallel=5 without --max-parallel" ); +test_is_parallel( do_parallel_mk("--max-parallel=2"), + "DEB_BUILD_OPTIONS=parallel=5 with --max-parallel=2" ); +test_isnt_parallel( do_parallel_mk("--max-parallel=1"), + "DEB_BUILD_OPTIONS=parallel=5 with --max-parallel=1 (off)" ); + +$ENV{MAKEFLAGS} = "--jobserver-fds=105,106 -j"; +$ENV{DEB_BUILD_OPTIONS}=""; +test_isnt_parallel( do_parallel_mk("--max-parallel=5"), + "makefile.pm (no parallel): no make warnings about unavailable jobserver" ); +$ENV{DEB_BUILD_OPTIONS}="parallel=5"; +test_is_parallel( do_parallel_mk("--max-paralle=5"), + "DEB_BUILD_OPTIONS=parallel=5: no make warnings about unavail parent jobserver" ); + +$ENV{MAKEFLAGS} = "-j2"; +$ENV{DEB_BUILD_OPTIONS}=""; +test_isnt_parallel( do_parallel_mk(), + "MAKEFLAGS=-j2: dh_auto_build ignores MAKEFLAGS" ); +test_isnt_parallel( do_parallel_mk("--max-parallel=1"), + "MAKEFLAGS=-j2 with --max-parallel=1: dh_auto_build enforces -j1" ); + +# Test dh dpkg-buildpackage -jX detection +sub do_rules_for_parallel { + my $cmdline=shift || ""; + my $stdin=shift || ""; + return process_stdout("LANG=C LC_ALL=C LC_MESSAGES=C PATH=$TOPDIR:\$PATH " . + "make -f - $cmdline 2>&1 >/dev/null", $stdin); +} + +doit("ln", "-sf", "parallel.mk", "Makefile"); + +# Test if dh+override+$(MAKE) legacy punctuation hack work as before +$ENV{MAKEFLAGS} = "-j5"; +$ENV{DEB_BUILD_OPTIONS} = "parallel=5"; + +$tmp = write_debian_rules(<<'EOF'); +#!/usr/bin/make -f +override_dh_auto_build: + $(MAKE) +%: + @dh_clean > /dev/null 2>&1 + @+dh --buildsystem=makefile --after=dh_auto_configure --until=dh_auto_build $@ + @dh_clean > /dev/null 2>&1 +EOF +test_is_parallel( do_rules_for_parallel("build", "include debian/rules"), + "legacy punctuation hacks: +dh, override with \$(MAKE)" ); +unlink "debian/rules"; + +if (defined $tmp) { + rename($tmp, "debian/rules"); +} +else { + unlink("debian/rules"); +} + +# Clean up after parallel testing +END { + system("rm", "-f", "Makefile"); +} +$ENV{MAKEFLAGS} = $tmp[0] if defined $tmp[0]; +$ENV{DEB_BUILD_OPTIONS} = $tmp[1] if defined $tmp[1]; END { system("rm", "-rf", $tmpdir);