No point in running this twice since accessors are always inlined
[gitmo/Moose.git] / t / 030_roles / 020_role_composite.t
index 38e8307..506968e 100644 (file)
@@ -3,14 +3,11 @@
 use strict;
 use warnings;
 
-use Test::More no_plan => 1;
+use Test::More tests => 14;
 use Test::Exception;
 
-BEGIN {
-    use_ok('Moose');
-    use_ok('Moose::Meta::Role::Application::RoleSummation');
-    use_ok('Moose::Meta::Role::Composite');
-}
+use Moose::Meta::Role::Application::RoleSummation;
+use Moose::Meta::Role::Composite;
 
 {
     package Role::Foo;
@@ -20,7 +17,10 @@ BEGIN {
     use Moose::Role;
 
     package Role::Baz;
-    use Moose::Role;         
+    use Moose::Role;      
+    
+    package Role::Gorch;
+    use Moose::Role;       
 }
 
 {
@@ -41,7 +41,40 @@ BEGIN {
         Role::Baz->meta,        
     ], '... got the right roles');
     
+    ok($c->does_role($_), '... our composite does the role ' . $_)
+        for qw(
+            Role::Foo
+            Role::Bar
+            Role::Baz            
+        );
+    
     lives_ok {
         Moose::Meta::Role::Application::RoleSummation->new->apply($c);
-    } '... this composed okay';    
+    } '... this composed okay';   
+    
+    ##... now nest 'em
+    { 
+        my $c2 = Moose::Meta::Role::Composite->new(
+            roles => [
+                $c,
+                Role::Gorch->meta,
+            ]
+        );
+        isa_ok($c2, 'Moose::Meta::Role::Composite');
+
+        is($c2->name, 'Role::Foo|Role::Bar|Role::Baz|Role::Gorch', '... got the composite role name');
+
+        is_deeply($c2->get_roles, [
+            $c,
+            Role::Gorch->meta,  
+        ], '... got the right roles');
+
+        ok($c2->does_role($_), '... our composite does the role ' . $_)
+            for qw(
+                Role::Foo
+                Role::Bar
+                Role::Baz     
+                Role::Gorch                        
+            );     
+    }
 }