X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F020_attributes%2F019_attribute_lazy_initializer.t;h=3ac82d8553037e58b05a234bb5c5f69e87f07059;hb=ad3882b59692e4e4eab99f9b183c941e6f63d3bd;hp=6735822b29baef51c78650235de3794b9eadaf10;hpb=e606ae5f848070d889472329819c95f5ba763ca3;p=gitmo%2FMoose.git diff --git a/t/020_attributes/019_attribute_lazy_initializer.t b/t/020_attributes/019_attribute_lazy_initializer.t index 6735822..3ac82d8 100644 --- a/t/020_attributes/019_attribute_lazy_initializer.t +++ b/t/020_attributes/019_attribute_lazy_initializer.t @@ -3,24 +3,23 @@ use strict; use warnings; -use Test::More tests => 23; +use Test::More; use Test::Exception; - { package Foo; use Moose; - + has 'foo' => ( reader => 'get_foo', writer => 'set_foo', initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); ::is($attr->name, 'foo', '... got the right name'); - + $callback->($value * 2); }, ); @@ -31,14 +30,14 @@ use Test::Exception; default => 10, initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); - ::is($attr->name, 'lazy_foo', '... got the right name'); - + ::is($attr->name, 'lazy_foo', '... got the right name'); + $callback->($value * 2); }, ); - + has 'lazy_foo_w_type' => ( reader => 'get_lazy_foo_w_type', isa => 'Int', @@ -46,43 +45,43 @@ use Test::Exception; default => 20, initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); - ::is($attr->name, 'lazy_foo_w_type', '... got the right name'); - + ::is($attr->name, 'lazy_foo_w_type', '... got the right name'); + $callback->($value * 2); }, - ); - + ); + has 'lazy_foo_builder' => ( reader => 'get_lazy_foo_builder', builder => 'get_foo_builder', initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); - ::is($attr->name, 'lazy_foo_builder', '... got the right name'); - + ::is($attr->name, 'lazy_foo_builder', '... got the right name'); + $callback->($value * 2); }, ); - + has 'lazy_foo_builder_w_type' => ( reader => 'get_lazy_foo_builder_w_type', - isa => 'Int', + isa => 'Int', builder => 'get_foo_builder_w_type', initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); - ::is($attr->name, 'lazy_foo_builder_w_type', '... got the right name'); - + ::is($attr->name, 'lazy_foo_builder_w_type', '... got the right name'); + $callback->($value * 2); }, ); - - sub get_foo_builder { 100 } - sub get_foo_builder_w_type { 1000 } + + sub get_foo_builder { 100 } + sub get_foo_builder_w_type { 1000 } } { @@ -93,26 +92,26 @@ use Test::Exception; is($foo->get_lazy_foo, 20, 'initial lazy value set to 2x given value'); is($foo->get_lazy_foo_w_type, 40, 'initial lazy value with type set to 2x given value'); is($foo->get_lazy_foo_builder, 200, 'initial lazy value with builder set to 2x given value'); - is($foo->get_lazy_foo_builder_w_type, 2000, 'initial lazy value with builder and type set to 2x given value'); + is($foo->get_lazy_foo_builder_w_type, 2000, 'initial lazy value with builder and type set to 2x given value'); } { package Bar; use Moose; - + has 'foo' => ( reader => 'get_foo', writer => 'set_foo', initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); ::is($attr->name, 'foo', '... got the right name'); - + $callback->($value * 2); }, - ); - + ); + __PACKAGE__->meta->make_immutable; } @@ -120,27 +119,27 @@ use Test::Exception; my $bar = Bar->new(foo => 10); isa_ok($bar, 'Bar'); - is($bar->get_foo, 20, 'initial value set to 2x given value'); + is($bar->get_foo, 20, 'initial value set to 2x given value'); } { package Fail::Bar; use Moose; - + has 'foo' => ( reader => 'get_foo', writer => 'set_foo', isa => 'Int', initializer => sub { my ($self, $value, $callback, $attr) = @_; - + ::isa_ok($attr, 'Moose::Meta::Attribute'); ::is($attr->name, 'foo', '... got the right name'); - + $callback->("Hello $value World"); }, - ); - + ); + __PACKAGE__->meta->make_immutable; } @@ -148,3 +147,4 @@ dies_ok { Fail::Bar->new(foo => 10) } '... this fails, because initializer returns a bad type'; +done_testing;