Remove numbers from our tests
[gitmo/Moose.git] / t / roles / role_composition_override.t
diff --git a/t/roles/role_composition_override.t b/t/roles/role_composition_override.t
new file mode 100644 (file)
index 0000000..602ac00
--- /dev/null
@@ -0,0 +1,114 @@
+#!/usr/bin/perl
+
+use strict;
+use warnings;
+
+use Test::More;
+use Test::Fatal;
+
+use Moose::Meta::Role::Application::RoleSummation;
+use Moose::Meta::Role::Composite;
+
+{
+    package Role::Foo;
+    use Moose::Role;
+
+    override foo => sub { 'Role::Foo::foo' };
+
+    package Role::Bar;
+    use Moose::Role;
+
+    override bar => sub { 'Role::Bar::bar' };
+
+    package Role::FooConflict;
+    use Moose::Role;
+
+    override foo => sub { 'Role::FooConflict::foo' };
+
+    package Role::FooMethodConflict;
+    use Moose::Role;
+
+    sub foo { 'Role::FooConflict::foo' }
+
+    package Role::BarMethodConflict;
+    use Moose::Role;
+
+    sub bar { 'Role::BarConflict::bar' }
+}
+
+# test simple overrides
+{
+    my $c = Moose::Meta::Role::Composite->new(
+        roles => [
+            Role::Foo->meta,
+            Role::Bar->meta,
+        ]
+    );
+    isa_ok($c, 'Moose::Meta::Role::Composite');
+
+    is($c->name, 'Role::Foo|Role::Bar', '... got the composite role name');
+
+    is( exception {
+        Moose::Meta::Role::Application::RoleSummation->new->apply($c);
+    }, undef, '... this lives ok' );
+
+    is_deeply(
+        [ sort $c->get_method_modifier_list('override') ],
+        [ 'bar', 'foo' ],
+        '... got the right list of methods'
+    );
+}
+
+# test simple overrides w/ conflicts
+isnt( exception {
+    Moose::Meta::Role::Application::RoleSummation->new->apply(
+        Moose::Meta::Role::Composite->new(
+            roles => [
+                Role::Foo->meta,
+                Role::FooConflict->meta,
+            ]
+        )
+    );
+}, undef, '... this fails as expected' );
+
+# test simple overrides w/ conflicts
+isnt( exception {
+    Moose::Meta::Role::Application::RoleSummation->new->apply(
+        Moose::Meta::Role::Composite->new(
+            roles => [
+                Role::Foo->meta,
+                Role::FooMethodConflict->meta,
+            ]
+        )
+    );
+}, undef, '... this fails as expected' );
+
+
+# test simple overrides w/ conflicts
+isnt( exception {
+    Moose::Meta::Role::Application::RoleSummation->new->apply(
+        Moose::Meta::Role::Composite->new(
+            roles => [
+                Role::Foo->meta,
+                Role::Bar->meta,
+                Role::FooConflict->meta,
+            ]
+        )
+    );
+}, undef, '... this fails as expected' );
+
+
+# test simple overrides w/ conflicts
+isnt( exception {
+    Moose::Meta::Role::Application::RoleSummation->new->apply(
+        Moose::Meta::Role::Composite->new(
+            roles => [
+                Role::Foo->meta,
+                Role::Bar->meta,
+                Role::FooMethodConflict->meta,
+            ]
+        )
+    );
+}, undef, '... this fails as expected' );
+
+done_testing;