use strict;
use warnings;
-use Test::More 'no_plan';
+use Test::More;
use Test::Exception;
-# All the BEGIN blocks are necessary to emulate the behavior of
-# loading modules via use and the similar compile-time effect of "no
-# ..."
+BEGIN {
+ unless ( eval 'use Test::Warn 0.11; 1' ) {
+ plan skip_all => 'These tests require Test::Warn 0.11';
+ }
+ else {
+ plan tests => 45;
+ }
+}
+
+
+{
+ package HasOwnImmutable;
+
+ use Moose;
+
+ no Moose;
+
+ ::warning_is( sub { eval q[sub make_immutable { return 'foo' }] },
+ '',
+ 'no warning when defining our own make_immutable sub' );
+}
+
+{
+ is( HasOwnImmutable->make_immutable(), 'foo',
+ 'HasOwnImmutable->make_immutable does not get overwritten' );
+}
+
{
package MooseX::Empty;
use Moose ();
- BEGIN { Moose::Exporter->build_import_methods( also => 'Moose' ); }
+ Moose::Exporter->setup_import_methods( also => 'Moose' );
}
{
package WantsMoose;
- BEGIN { MooseX::Empty->import(); }
+ MooseX::Empty->import();
sub foo { 1 }
- BEGIN {
- ::can_ok( 'WantsMoose', 'has' );
- ::can_ok( 'WantsMoose', 'with' );
- ::can_ok( 'WantsMoose', 'foo' );
- }
+ ::can_ok( 'WantsMoose', 'has' );
+ ::can_ok( 'WantsMoose', 'with' );
+ ::can_ok( 'WantsMoose', 'foo' );
- BEGIN{ MooseX::Empty->unimport();}
+ MooseX::Empty->unimport();
}
{
+ # Note: it's important that these methods be out of scope _now_,
+ # after unimport was called. We tried a
+ # namespace::clean(0.08)-based solution, but had to abandon it
+ # because it cleans the namespace _later_ (when the file scope
+ # ends).
ok( ! WantsMoose->can('has'), 'WantsMoose::has() has been cleaned' );
ok( ! WantsMoose->can('with'), 'WantsMoose::with() has been cleaned' );
can_ok( 'WantsMoose', 'foo' );
return $caller . ' called wrapped1';
}
- BEGIN {
- Moose::Exporter->build_import_methods(
- with_caller => ['wrapped1'],
- also => 'Moose',
- );
- }
+ Moose::Exporter->setup_import_methods(
+ with_caller => ['wrapped1'],
+ also => 'Moose',
+ );
}
{
package WantsSugar;
- BEGIN { MooseX::Sugar->import() }
+ MooseX::Sugar->import();
sub foo { 1 }
- BEGIN {
- ::can_ok( 'WantsSugar', 'has' );
- ::can_ok( 'WantsSugar', 'with' );
- ::can_ok( 'WantsSugar', 'wrapped1' );
- ::can_ok( 'WantsSugar', 'foo' );
- ::is( wrapped1(), 'WantsSugar called wrapped1',
- 'wrapped1 identifies the caller correctly' );
- }
+ ::can_ok( 'WantsSugar', 'has' );
+ ::can_ok( 'WantsSugar', 'with' );
+ ::can_ok( 'WantsSugar', 'wrapped1' );
+ ::can_ok( 'WantsSugar', 'foo' );
+ ::is( wrapped1(), 'WantsSugar called wrapped1',
+ 'wrapped1 identifies the caller correctly' );
- BEGIN{ MooseX::Sugar->unimport();}
+ MooseX::Sugar->unimport();
}
{
return 'as_is1';
}
- BEGIN {
- Moose::Exporter->build_import_methods(
- with_caller => ['wrapped2'],
- as_is => ['as_is1'],
- also => 'MooseX::Sugar',
- );
- }
+ Moose::Exporter->setup_import_methods(
+ with_caller => ['wrapped2'],
+ as_is => ['as_is1'],
+ also => 'MooseX::Sugar',
+ );
}
{
package WantsMoreSugar;
- BEGIN { MooseX::MoreSugar->import() }
+ MooseX::MoreSugar->import();
sub foo { 1 }
- BEGIN {
- ::can_ok( 'WantsMoreSugar', 'has' );
- ::can_ok( 'WantsMoreSugar', 'with' );
- ::can_ok( 'WantsMoreSugar', 'wrapped1' );
- ::can_ok( 'WantsMoreSugar', 'wrapped2' );
- ::can_ok( 'WantsMoreSugar', 'as_is1' );
- ::can_ok( 'WantsMoreSugar', 'foo' );
- ::is( wrapped1(), 'WantsMoreSugar called wrapped1',
- 'wrapped1 identifies the caller correctly' );
- ::is( wrapped2(), 'WantsMoreSugar called wrapped2',
- 'wrapped2 identifies the caller correctly' );
- ::is( as_is1(), 'as_is1',
- 'as_is1 works as expected' );
- }
-
- BEGIN{ MooseX::MoreSugar->unimport();}
+ ::can_ok( 'WantsMoreSugar', 'has' );
+ ::can_ok( 'WantsMoreSugar', 'with' );
+ ::can_ok( 'WantsMoreSugar', 'wrapped1' );
+ ::can_ok( 'WantsMoreSugar', 'wrapped2' );
+ ::can_ok( 'WantsMoreSugar', 'as_is1' );
+ ::can_ok( 'WantsMoreSugar', 'foo' );
+ ::is( wrapped1(), 'WantsMoreSugar called wrapped1',
+ 'wrapped1 identifies the caller correctly' );
+ ::is( wrapped2(), 'WantsMoreSugar called wrapped2',
+ 'wrapped2 identifies the caller correctly' );
+ ::is( as_is1(), 'as_is1',
+ 'as_is1 works as expected' );
+
+ MooseX::MoreSugar->unimport();
}
{
);
}
- BEGIN { Moose::Exporter->build_import_methods( also => 'Moose' ); }
+ Moose::Exporter->setup_import_methods( also => 'Moose' );
}
{
package NewMeta;
- BEGIN { HasInitMeta->import() }
+ HasInitMeta->import();
}
{
::dies_ok(
sub {
- Moose::Exporter->build_import_methods(
+ Moose::Exporter->setup_import_methods(
also => [ 'Moose', 'MooseX::CircularAlso' ],
);
},
::like(
$@,
- qr/\QCircular reference in also parameter to MooseX::Exporter between MooseX::CircularAlso and MooseX::CircularAlso/,
+ qr/\QCircular reference in also parameter to Moose::Exporter between MooseX::CircularAlso and MooseX::CircularAlso/,
'got the expected error from circular reference in also'
);
}
::dies_ok(
sub {
- Moose::Exporter->build_import_methods(
+ Moose::Exporter->setup_import_methods(
also => [ 'NoSuchThing' ],
);
},
::like(
$@,
- qr/\QPackage in also (NoSuchThing) does not seem to use MooseX::Exporter/,
+ qr/\QPackage in also (NoSuchThing) does not seem to use Moose::Exporter/,
'got the expected error from a reference in also to a package which does not use Moose::Exporter'
);
}
+
+{
+ package MooseX::OverridingSugar;
+
+ use Moose ();
+
+ sub has {
+ my $caller = shift;
+ return $caller . ' called has';
+ }
+
+ Moose::Exporter->setup_import_methods(
+ with_caller => ['has'],
+ also => 'Moose',
+ );
+}
+
+{
+ package WantsOverridingSugar;
+
+ MooseX::OverridingSugar->import();
+
+ ::can_ok( 'WantsOverridingSugar', 'has' );
+ ::can_ok( 'WantsOverridingSugar', 'with' );
+ ::is( has('foo'), 'WantsOverridingSugar called has',
+ 'has from MooseX::OverridingSugar is called, not has from Moose' );
+
+ MooseX::OverridingSugar->unimport();
+}
+
+{
+ ok( ! WantsSugar->can('has'), 'WantsSugar::has() has been cleaned' );
+ ok( ! WantsSugar->can('with'), 'WantsSugar::with() has been cleaned' );
+}
+