X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=fcccedf6c656cab41f74e221da3cfde638c5c908;hb=3d27a7b791d542856ce729236794338634ae39be;hp=3a7e44f69cb0c2969b22f52e1404f21bc2be299a;hpb=c4f4f5e361bf079c051eebabf630de10b6c17ca4;p=gitmo%2FMouse.git diff --git a/Makefile.PL b/Makefile.PL old mode 100755 new mode 100644 index 3a7e44f..fcccedf --- a/Makefile.PL +++ b/Makefile.PL @@ -1,3 +1,4 @@ +# COMPAT_TEST=1 genrates Moose compatible tests # for developpers: BEGIN{ if(grep{ $_ eq '--author' } @ARGV){ @@ -8,15 +9,12 @@ BEGIN{ use strict; use warnings; -use inc::Module::Install 0.99; +use inc::Module::Install 1.00; # for co-developpers -use Module::Install::XSUtil 0.24; +use Module::Install::XSUtil 0.30; use Module::Install::AuthorTests; -system($^X, 'tool/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 - or warn "Cannot generate Mouse::Tiny: $!"; - name 'Mouse'; all_from 'lib/Mouse.pm'; @@ -24,18 +22,24 @@ all_from 'lib/Mouse.pm'; # > Fixed looks_like_number(undef) to return false for perl >= 5.009002 requires 'Scalar::Util' => 1.14; -test_requires 'Test::More' => 0.88; +test_requires 'Test::More' => 0.88; +test_requires 'Test::Requires' => 0.06; # works on 5.6.0 +test_requires 'Test::Exception::LessClever' => 0.005; + +# to keep zero-dependencies +include 'Test::Exception::LessClever'; +include 'Test::Requires'; my %suggests = ( 'Any::Moose' => 0.10, - 'Data::Util' => 0.55, + 'MouseX::AttributeHelpers' => 0.06, + 'MouseX::NativeTraits' => 1.00, ); - while(my($mod, $least) = each %suggests){ - my $status = system $^X, '-e', sprintf <<'CHECK', $mod, $least; -if(eval q{ use %1$s (); 1 }) { - if(eval q{ use %1$s %2$s (); 1 }) { + my $status = system $^X, '-e', <<"CHECK"; +if(eval q{ use $mod (); 1 }) { + if(eval q{ use $mod $least (); 1 }) { exit 0; # installd, and new enough } else { @@ -58,43 +62,45 @@ CHECK my $use_xs = ($] >= 5.008_001 && want_xs()); if($use_xs){ - print "Mouse configured with XS.\n", - "NOTE: You can try --pp option to configure Mouse with Pure Perl.\n"; + print "Mouse configured with XS.\n"; - cc_warnings(); use_ppport(3.19); + use_xshelper(); + cc_warnings(); cc_src_paths('xs-src'); } else{ print "Mouse configured with Pure Perl.\n"; } - tests 't/*.t t/*/*.t'; author_tests 'xt'; repository 'git://git.moose.perl.org/Mouse.git'; +system($^X, 'tool/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 + or warn "Cannot generate Mouse::Tiny: $!"; +makemaker_args PL_FILES => { + 'tool/generate-mouse-tiny.pl' => 'lib/Mouse/Tiny.pm', +}; + if ($Module::Install::AUTHOR) { require 'lib/Mouse/Spec.pm'; # for the version my $require_version = Mouse::Spec->MooseVersion; - if (eval { require Moose; Moose->VERSION($require_version) }) { + if ($ENV{COMPAT_TEST} + && eval { require Moose; Moose->VERSION($require_version) }) { print "You have Moose ", Moose->VERSION, ".\n"; - if (eval { require Module::Install::AuthorTests }) { - do 'tool/create-moose-compatibility-tests.pl'; - # repeat testing - # see also ExtUtils::MM_Any::test_via_harness() - my $t_moose = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} - .q{ "test_harness($(TEST_VERBOSE), '$(INST_LIB)', '$(INST_ARCHLIB)')"} - .q{ xt/compatibility/t/*/*.t } . "\n"; - - postamble qq{test_dynamic :: test_moose\n\n} - . qq{test_moose :: pure_all\n} - . qq{\t} . $t_moose; - } else { - print "You don't have a M::I::AuthorTests.\n"; - } + do 'tool/create-moose-compatibility-tests.pl'; + # repeat testing + # see also ExtUtils::MM_Any::test_via_harness() + my $t_moose = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} + .q{ "test_harness($(TEST_VERBOSE), 'inc', '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ xt/compat/t/*/*.t } . "\n"; + + postamble qq{test :: test_moose\n\n} + . qq{test_moose :: pure_all\n} + . qq{\t} . $t_moose; } else { print "You don't have Moose $require_version. skipping moose compatibility test\n"; } @@ -103,13 +109,28 @@ if ($Module::Install::AUTHOR) { # repeat testing # see also ExtUtils::MM_Any::test_via_harness() my $t_pp = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} - .q{ "do 'tool/force-pp.pl'; test_harness($(TEST_VERBOSE), '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ "do 'tool/force-pp.pl'; test_harness($(TEST_VERBOSE), 'inc', '$(INST_LIB)', '$(INST_ARCHLIB)')"} .q{ $(TEST_FILES)} . "\n"; - postamble qq{test_dynamic :: test_pp\n\n} + postamble qq{test :: test_pp\n\n} . qq{test_pp :: pure_all\n} . qq{\t} . $t_pp; } + + # Hack to disable Test::Exception, which might pull a perl internal bug. + # See also Test::Exception::LessClever. + open my $out, '>', 'inc/Test/Exception.pm' or die $!; + print $out <<'EOT'; +package Test::Exception; # wapper to T::E::LessClever +require Test::Exception::LessClever; +$INC{'Test/Exception.pm'} = __FILE__; +sub import { + shift; + Test::Exception::LessClever->export_to_level(1, @_); +} +1; +EOT + close $out or die $!; } clean_files q{