From: Yuval Kogman Date: Fri, 25 Apr 2008 07:33:17 +0000 (+0000) Subject: tests for attr initialization in runtime roles X-Git-Tag: 0_55~209 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=519e8a1f10c0bb2cd1c5eeaacbe03c53d81ef0f1;p=gitmo%2FMoose.git tests for attr initialization in runtime roles --- diff --git a/t/030_roles/015_runtime_roles_and_attrs.t b/t/030_roles/015_runtime_roles_and_attrs.t index ca4e51b..3cf2fb6 100644 --- a/t/030_roles/015_runtime_roles_and_attrs.t +++ b/t/030_roles/015_runtime_roles_and_attrs.t @@ -3,7 +3,7 @@ use strict; use warnings; -use Test::More tests => 9; +use Test::More tests => 12; use Test::Exception; use Scalar::Util 'blessed'; @@ -18,6 +18,12 @@ BEGIN { sub talk { 'woof' } + has fur => ( + isa => "Str", + is => "rw", + default => "dirty", + ); + package Foo; use Moose; @@ -31,6 +37,7 @@ my $obj = Foo->new; isa_ok($obj, 'Foo'); ok(!$obj->can( 'talk' ), "... the role is not composed yet"); +ok(!$obj->can( 'fur' ), 'ditto'); ok(!$obj->does('Dog'), '... we do not do any roles yet'); dies_ok { @@ -41,6 +48,7 @@ Dog->meta->apply($obj); ok($obj->does('Dog'), '... we now do the Bark role'); ok($obj->can('talk'), "... the role is now composed at the object level"); +ok($obj->can('fur'), "it has fur"); is($obj->talk, 'woof', '... got the right return value for the newly composed method'); @@ -48,3 +56,4 @@ lives_ok { $obj->dog($obj) } '... and setting the accessor is okay'; +is($obj->fur, "dirty", "role attr initialized");