X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=25e3be59c6ea73bd17253043f9088df7c856c298;hb=a5df48e596d4b685f53bf59ef581d6999ab14eb6;hp=dea9173a877b0f190700fbee6ca452bfdcd7a189;hpb=32cf1353e897e482f55d49b4c6c3be01ab4544a8;p=gitmo%2FMouse.git diff --git a/Makefile.PL b/Makefile.PL index dea9173..25e3be5 100755 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,3 +1,4 @@ +BEGIN{ $INC{'Module/Install/ExtraTests.pm'} = __FILE__ } # to disable the use of ExtrTests use strict; use warnings; use inc::Module::Install; @@ -14,11 +15,14 @@ tests 't/*.t t/*/*.t'; # > Fixed looks_like_number(undef) to return false for perl >= 5.009002 requires 'Scalar::Util' => 1.14; +configure_requires 'ExtUtils::CBuilder'; + test_requires 'Test::More' => 0.88; test_requires 'Test::Exception' => 0.27; # test_requires 'Test::Output' => 0.16; # too many dependencies! -include 'Test::Exception'; # work around 0.27_0x (its use of diehook might be wrong) + +include_deps 'Test::Exception'; # work around 0.27_0x (its use of diehook might be wrong) recommends 'MRO::Compat' if $] < 5.010; @@ -29,10 +33,15 @@ for (@ARGV) { /^--xs$/ and $use_xs = 1; } +if($] < 5.008_001){ + $use_xs = 0; +} + if(!defined $use_xs){ - configure_requires 'ExtUtils::CBuilder'; - require ExtUtils::CBuilder; - $use_xs = ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); + $use_xs = eval { + require ExtUtils::CBuilder; + ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); + }; } if($use_xs){ @@ -47,7 +56,7 @@ else{ print "Mouse configured in Pure Perl (--pp)\n"; } -if ($Module::Install::AUTHOR) { +if (author_context()) { local @INC = ('lib', @INC); require 'lib/Mouse/Spec.pm'; my $require_version = Mouse::Spec->MooseVersion; @@ -62,9 +71,20 @@ if ($Module::Install::AUTHOR) { } else { print "you don't have Moose $require_version. skipping moose compatibility test\n"; } + + if($use_xs){ + # repeat testing + # see also ExtUtils::MM_Any::test_via_harness() + my $test_via_harness = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} + .q{ "do 'author/force-pp.pl'; test_harness($(TEST_VERBOSE), '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ $(TEST_FILES)} . "\n"; + + postamble qq{test_dynamic :: test_pp\n\n} + . qq{test_pp :: pure_all\n} + . qq{\t} . $test_via_harness; + } } clean_files 'lib/Mouse/Tiny.pm'; WriteAll check_nmake => 0; -