Add a test file for type constraints
[gitmo/Mouse.git] / t / 400-define-role.t
index b85ed40..1cb7397 100644 (file)
@@ -1,7 +1,15 @@
 #!/usr/bin/env perl
 use strict;
 use warnings;
-use Test::More tests => 11;
+use Test::More;
+BEGIN{
+    if(eval{ require Class::Method::Modifiers::Fast } || eval{ require Class::Method::Modifiers }){
+        plan tests => 11;
+    }
+    else{
+        plan skip_all => 'This test requires Class::Method::Modifiers(::Fast)?';
+    }
+}
 use Test::Exception;
 
 lives_ok {
@@ -18,7 +26,7 @@ throws_ok {
     extends 'Role::Parent';
 
     no Mouse::Role;
-} qr/Roles do not currently support 'extends'/;
+} qr/Roles do not support 'extends'/;
 
 lives_ok {
     package Role;
@@ -44,7 +52,7 @@ lives_ok {
     package Role;
     use Mouse::Role;
 
-    has 'foo';
+    has 'foo' => (is => 'bare');
 
     no Mouse::Role;
 };
@@ -64,14 +72,18 @@ lives_ok {
     no Mouse::Role;
 };
 
-throws_ok {
+TODO: {
     package Role;
     use Mouse::Role;
 
-    excludes 'excluded';
+    eval {
+        excludes 'excluded';
+    };
+    local our $TODO = "Mouse::Role does not currently support 'excludes'";
+    ::ok(!$@, "excludes");
 
     no Mouse::Role;
-} qr/Mouse::Role does not currently support 'excludes'/;
+};
 
 throws_ok {
     package Role;
@@ -89,11 +101,10 @@ lives_ok {
     ::is(blessed($obj), "Impromptu::Class");
 };
 
-our $TODO = 'skip';
-throws_ok {
+lives_ok{
     package Class;
     use Mouse;
 
     with 'Role', 'Other::Role';
-} qr/Mouse::Role only supports 'with' on individual roles at a time/;
+};