X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F300_immutable%2F001_immutable_moose.t;h=b969268e7c6a3a36f47c6d6bf09005394c194063;hb=43b9a91cacfa5e209171acd1141e3ad8e8a2d31a;hp=f05797694e76daf83891d71d1959c79fad9e16e0;hpb=e59a5c292a333cac504b65ebd4bba20b5e98d796;p=gitmo%2FMoose.git diff --git a/t/300_immutable/001_immutable_moose.t b/t/300_immutable/001_immutable_moose.t index f057976..b969268 100644 --- a/t/300_immutable/001_immutable_moose.t +++ b/t/300_immutable/001_immutable_moose.t @@ -3,32 +3,56 @@ use strict; use warnings; -use Test::More tests => 8; +use Test::More; use Test::Exception; -BEGIN { - use_ok('Moose'); - use_ok('Moose::Meta::Role'); -} +use Moose::Meta::Role; + { - package FooRole; - our $VERSION = '0.01'; - sub foo { 'FooRole::foo' } + package FooRole; + our $VERSION = '0.01'; + sub foo {'FooRole::foo'} } { - package Foo; - use Moose; + package Foo; + use Moose; + + #two checks because the inlined methods are different when + #there is a TC present. + has 'foos' => ( is => 'ro', lazy_build => 1 ); + has 'bars' => ( isa => 'Str', is => 'ro', lazy_build => 1 ); + has 'bazes' => ( isa => 'Str', is => 'ro', builder => '_build_bazes' ); + sub _build_foos {"many foos"} + sub _build_bars {"many bars"} + sub _build_bazes {"many bazes"} } { - my $foo_role = Moose::Meta::Role->initialize('FooRole'); - my $meta = Foo->meta; - lives_ok{ $meta->make_immutable } "Foo is imutable"; - dies_ok{ $meta->add_role($foo_role) } "Add Role is locked"; - lives_ok{ $meta->make_mutable } "Foo is mutable"; - lives_ok{ $meta->add_role($foo_role) } "Add Role is unlocked"; + my $foo_role = Moose::Meta::Role->initialize('FooRole'); + my $meta = Foo->meta; + + lives_ok { Foo->new } "lazy_build works"; + is( Foo->new->foos, 'many foos', + "correct value for 'foos' before inlining constructor" ); + is( Foo->new->bars, 'many bars', + "correct value for 'bars' before inlining constructor" ); + is( Foo->new->bazes, 'many bazes', + "correct value for 'bazes' before inlining constructor" ); + lives_ok { $meta->make_immutable } "Foo is imutable"; + lives_ok { $meta->identifier } "->identifier on metaclass lives"; + dies_ok { $meta->add_role($foo_role) } "Add Role is locked"; + lives_ok { Foo->new } "Inlined constructor works with lazy_build"; + is( Foo->new->foos, 'many foos', + "correct value for 'foos' after inlining constructor" ); + is( Foo->new->bars, 'many bars', + "correct value for 'bars' after inlining constructor" ); + is( Foo->new->bazes, 'many bazes', + "correct value for 'bazes' after inlining constructor" ); + lives_ok { $meta->make_mutable } "Foo is mutable"; + lives_ok { $meta->add_role($foo_role) } "Add Role is unlocked"; + } { @@ -60,3 +84,5 @@ lives_ok { Baz->meta->make_immutable } Nothing here yet, but soon :) =cut + +done_testing;