use strict;
use warnings;
-use Test::More tests => 9;
+use Test::More tests => 10;
use Test::Exception;
BEGIN {
{
package Role::Foo;
use Moose::Role;
-
+
before foo => sub { 'Role::Foo::foo' };
around foo => sub { 'Role::Foo::foo' };
after foo => sub { 'Role::Foo::foo' };
-
+ around baz => sub { [ 'Role::Foo', @{shift->(@_)} ] };
+
package Role::Bar;
use Moose::Role;
before bar => sub { 'Role::Bar::bar' };
around bar => sub { 'Role::Bar::bar' };
after bar => sub { 'Role::Bar::bar' };
+
+ package Role::Baz;
+ use Moose::Role;
+
+ with 'Role::Foo';
+ around baz => sub { [ 'Role::Baz', @{shift->(@_)} ] };
+
+}
+
+{
+ package Class::FooBar;
+ use Moose;
+
+ with 'Role::Baz';
+ sub foo { 'placeholder' }
+ sub baz { ['Class::FooBar'] }
+}
+
+#test modifier call order
+{
+ is_deeply(
+ Class::FooBar->baz,
+ ['Role::Baz','Role::Foo','Class::FooBar']
+ );
}
# test simple overrides
isa_ok($c, 'Moose::Meta::Role::Composite');
is($c->name, 'Role::Foo|Role::Bar', '... got the composite role name');
-
+
lives_ok {
Moose::Meta::Role::Application::RoleSummation->new->apply($c);
} '... this succeeds as expected';
-
+
is_deeply(
[ sort $c->get_method_modifier_list('before') ],
[ 'bar', 'foo' ],
'... got the right list of methods'
);
-
+
is_deeply(
[ sort $c->get_method_modifier_list('after') ],
[ 'bar', 'foo' ],
'... got the right list of methods'
);
-
+
is_deeply(
[ sort $c->get_method_modifier_list('around') ],
- [ 'bar', 'foo' ],
+ [ 'bar', 'baz', 'foo' ],
'... got the right list of methods'
);
-}
\ No newline at end of file
+}