X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=8e9ed086cba2763e0559f03aa397631c35d1b303;hb=000bf66b6556949556a3499b970fd33ac83b3d4d;hp=c694d47b87386b40daaf7076a83c51a893991555;hpb=314fe3048f1aa8eb5d77b32040b4355b19a0c676;p=gitmo%2FMouse.git diff --git a/Makefile.PL b/Makefile.PL index c694d47..8e9ed08 100755 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,5 +1,11 @@ +BEGIN{ $INC{'Module/Install/ExtraTests.pm'} = __FILE__ } # to disable the use of ExtrTests +use strict; +use warnings; use inc::Module::Install; +system($^X, 'author/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 + or warn "Cannot generate Mouse::Tiny: $!"; + name 'Mouse'; all_from 'lib/Mouse.pm'; @@ -9,66 +15,68 @@ tests 't/*.t t/*/*.t'; # > Fixed looks_like_number(undef) to return false for perl >= 5.009002 requires 'Scalar::Util' => 1.14; -build_requires 'Test::Exception'; -build_requires 'Test::More'; +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) + +recommends 'MRO::Compat' if $] < 5.010; + +my $use_xs; + +for (@ARGV) { + /^--pp$/ and $use_xs = 0; + /^--xs$/ and $use_xs = 1; +} + +if(!defined $use_xs){ + configure_requires 'ExtUtils::CBuilder'; + require ExtUtils::CBuilder; + $use_xs = ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); +} + +if($use_xs){ + require Module::Install::XSUtil; + use_ppport(3.19); + cc_warnings(); + cc_src_paths('xs-src'); -if ($Module::Install::AUTHOR) { - if (eval "package foo; use Moose; 1;") { + print "Mouse configured in XS (--xs)\n"; +} +else{ + print "Mouse configured in Pure Perl (--pp)\n"; +} + +if (author_context()) { + local @INC = ('lib', @INC); + require 'lib/Mouse/Spec.pm'; + my $require_version = Mouse::Spec->MooseVersion; + + if (eval{ require Moose; Moose->VERSION($require_version) }) { if (eval 'use Module::Install::AuthorTests; 1') { - create_moose_compatibility_test(); + do 'author/create-moose-compatibility-tests.pl'; recursive_author_tests('xt'); } else { print "you don't have a M::I::AuthorTests.\n"; } } else { - print "you don't have a moose. skipping moose compatibility test\n"; + print "you don't have Moose $require_version. skipping moose compatibility test\n"; } -} -auto_include; -WriteAll; - -sub create_moose_compatibility_test { - require Path::Class; - Path::Class->import('file', 'dir'); - - # some test does not pass... currently skip it. - my %SKIP_TEST = ( - '016-trigger.t' => "trigger's argument is incompatble :(", - '020-load-class.t' => "&Moose::is_class_loaded doesn't exists", - '019-handles.t' => 'incompatible', - '025-more-isa.t' => 'Class::MOP::is_class_loaded is not compatible with Mouse::is_class_loaded', - '029-new.t' => 'Class->new(undef) incompatible', - '010-isa-or.t' => 'Mouse has a [BUG]', - '044-attribute-metaclass.t' => 'Moose::Meta::Attribute does not have a "create"', - '047-attribute-metaclass-role.t' => 'Moose::Meta::Attribute does not have a "create"', - '201-squirrel.t' => 'skip Squirrel', - '202-squirrel-role.t' => 'Squirrel is ...', - '400-define-role.t' => 'incompatibility', - '600-tiny-tiny.t' => "Moose doesn't support ::Tiny", - '601-tiny-mouse.t' => "Moose doesn't support ::Tiny", - '602-mouse-tiny.t' => "Moose doesn't support ::Tiny", - '031_roles_applied_in_create.t' => 'wtf?', - ); - - dir('t')->recurse( - callback => sub { - my $f = shift; - return if $f->is_dir; - return if $f =~ /\.sw[po]$/; - return if $SKIP_TEST{$f->basename}; - - my $dstfile = dir('xt', 'compatibility')->file($f); - $dstfile->dir->mkpath(); - - my $fh = $dstfile->openw(); - $fh->print(do { - local $_ = $f->slurp; - s/Mouse/Moose/g; - $_; - }); - $fh->close(); - }, - ); + 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;