fix deep recursion when calling isa check within isa check
[gitmo/Moo.git] / t / method-generate-accessor.t
index 6da7e99..118ff47 100644 (file)
@@ -32,6 +32,12 @@ like(
   qr/Unknown is purple/, 'is purple rejected'
 );
 
+is(exception {
+  $gen->generate_method('Foo' => 'three' => { is => 'bare', predicate => 1 });
+}, undef, 'generating bare accessor works');
+
+ok(Foo->can('has_three'), 'bare accessor will still generate predicate');
+
 like(
   exception { $gen->generate_method('Foo' => 'four' => { is => 'ro', coerce => 5 }) },
   qr/Invalid coerce/, "coerce - scalar rejected"
@@ -42,35 +48,35 @@ is(
   undef, "default - non-ref scalar accepted"
 );
 
+foreach my $setting (qw( default coerce )) {
 
-for my $setting (qw( default coerce )) {
   like(
-    exception { $gen->generate_method('Foo' => 'five' => { is => 'ro', $setting => [] }) },
+    exception { $gen->generate_method('Foo' => 'five' => { allow_overwrite => 1, is => 'ro', $setting => [] }) },
     qr/Invalid $setting/, "$setting - arrayref rejected"
   );
 
   like(
-    exception { $gen->generate_method('Foo' => 'five' => { is => 'ro', $setting => Foo->new }) },
+    exception { $gen->generate_method('Foo' => 'five' => { allow_overwrite => 1, is => 'ro', $setting => Foo->new }) },
     qr/Invalid $setting/, "$setting - non-code-convertible object rejected"
   );
 
   is(
-    exception { $gen->generate_method('Foo' => 'six' => { is => 'ro', $setting => sub { 5 } }) },
+    exception { $gen->generate_method('Foo' => 'six' => { allow_overwrite => 1, is => 'ro', $setting => sub { 5 } }) },
     undef, "$setting - coderef accepted"
   );
 
   is(
-    exception { $gen->generate_method('Foo' => 'seven' => { is => 'ro', $setting => bless sub { 5 } => 'Blah' }) },
+    exception { $gen->generate_method('Foo' => 'seven' => { allow_overwrite => 1, is => 'ro', $setting => bless sub { 5 } => 'Blah' }) },
     undef, "$setting - blessed sub accepted"
   );
 
   is(
-    exception { $gen->generate_method('Foo' => 'eight' => { is => 'ro', $setting => WithOverload->new }) },
+    exception { $gen->generate_method('Foo' => 'eight' => { allow_overwrite => 1, is => 'ro', $setting => WithOverload->new }) },
     undef, "$setting - object with overloaded ->() accepted"
   );
 
   like(
-    exception { $gen->generate_method('Foo' => 'nine' => { is => 'ro', $setting => bless {} => 'Blah' }) },
+    exception { $gen->generate_method('Foo' => 'nine' => { allow_overwrite => 1, is => 'ro', $setting => bless {} => 'Blah' }) },
     qr/Invalid $setting/, "$setting - object rejected"
   );
 }