Hmm. I think I did something odd in here...
[gitmo/MooseX-AttributeHelpers.git] / t / 001_basic_counter.t
index 107314f..1f7d760 100644 (file)
@@ -3,7 +3,7 @@
 use strict;
 use warnings;
 
-use Test::More no_plan => 1;
+use Test::More tests => 14;
 
 BEGIN {
     use_ok('MooseX::AttributeHelpers');   
@@ -19,8 +19,9 @@ BEGIN {
         isa       => 'Int',
         default   => sub { 0 },
         provides  => {
-            inc => 'inc_counter',
-            dec => 'dec_counter',
+            inc   => 'inc_counter',
+            dec   => 'dec_counter',
+            reset => 'reset_counter',
         }
     );
 }
@@ -28,6 +29,12 @@ BEGIN {
 my $page = MyHomePage->new();
 isa_ok($page, 'MyHomePage');
 
+can_ok($page, $_) for qw[
+    dec_counter 
+    inc_counter
+    reset_counter
+];
+
 is($page->counter, 0, '... got the default value');
 
 $page->inc_counter; 
@@ -39,5 +46,21 @@ is($page->counter, 2, '... got the incremented value (again)');
 $page->dec_counter; 
 is($page->counter, 1, '... got the decremented value');
 
+$page->reset_counter;
+is($page->counter, 0, '... got the original value');
+
+# check the meta ..
+
+my $counter = $page->meta->get_attribute('counter');
+isa_ok($counter, 'MooseX::AttributeHelpers::Counter');
+
+is($counter->helper_type, 'Num', '... got the expected helper type');
+
+is($counter->type_constraint->name, 'Int', '... got the expected type constraint');
 
+is_deeply($counter->provides, { 
+    inc   => 'inc_counter',
+    dec   => 'dec_counter',
+    reset => 'reset_counter',        
+}, '... got the right provides methods');