Fix pod coverage.
[gitmo/MooseX-AttributeHelpers.git] / t / 001_basic_counter.t
CommitLineData
22d869ff 1#!/usr/bin/perl
2
3use strict;
4use warnings;
5
eef0ea50 6use Test::More tests => 18;
22d869ff 7
8BEGIN {
9 use_ok('MooseX::AttributeHelpers');
10}
11
12{
13 package MyHomePage;
14 use Moose;
15
16 has 'counter' => (
17 metaclass => 'Counter',
18 is => 'ro',
19 isa => 'Int',
20 default => sub { 0 },
21 provides => {
457dc4fb 22 inc => 'inc_counter',
23 dec => 'dec_counter',
24 reset => 'reset_counter',
eef0ea50 25 set => 'set_counter'
22d869ff 26 }
27 );
28}
29
30my $page = MyHomePage->new();
31isa_ok($page, 'MyHomePage');
32
69dde336 33can_ok($page, $_) for qw[
34 dec_counter
35 inc_counter
457dc4fb 36 reset_counter
eef0ea50 37 set_counter
69dde336 38];
8c651099 39
22d869ff 40is($page->counter, 0, '... got the default value');
41
42$page->inc_counter;
43is($page->counter, 1, '... got the incremented value');
44
45$page->inc_counter;
46is($page->counter, 2, '... got the incremented value (again)');
47
48$page->dec_counter;
49is($page->counter, 1, '... got the decremented value');
50
457dc4fb 51$page->reset_counter;
52is($page->counter, 0, '... got the original value');
53
eef0ea50 54$page->set_counter(5);
55is($page->counter, 5, '... set the value');
56
57$page->inc_counter(2);
58is($page->counter, 7, '... increment by arg');
59
60$page->dec_counter(5);
61is($page->counter, 2, '... decrement by arg');
62
8c651099 63# check the meta ..
64
65my $counter = $page->meta->get_attribute('counter');
66isa_ok($counter, 'MooseX::AttributeHelpers::Counter');
67
68is($counter->helper_type, 'Num', '... got the expected helper type');
69
70is($counter->type_constraint->name, 'Int', '... got the expected type constraint');
22d869ff 71
8c651099 72is_deeply($counter->provides, {
457dc4fb 73 inc => 'inc_counter',
74 dec => 'dec_counter',
eef0ea50 75 reset => 'reset_counter',
76 set => 'set_counter'
8c651099 77}, '... got the right provides methods');
22d869ff 78