X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fmethod-generate-accessor.t;h=87d25089a9d85c0b1556b11a15ba3272b0f501fd;hb=2f425b5770149d4ed2e59da001c3be052cbd6bc1;hp=7043a4b29f9e8f146356d8e98807d71010d9b99f;hpb=b02331f2ee6c4c11ff568d1ecad59b896e537d37;p=gitmo%2FMoo.git diff --git a/t/method-generate-accessor.t b/t/method-generate-accessor.t index 7043a4b..87d2508 100644 --- a/t/method-generate-accessor.t +++ b/t/method-generate-accessor.t @@ -3,6 +3,7 @@ use Test::More; use Test::Fatal; use Method::Generate::Accessor; +use Sub::Quote 'quote_sub'; my $gen = Method::Generate::Accessor->new; @@ -11,6 +12,12 @@ my $gen = Method::Generate::Accessor->new; use Moo; } +{ + package WithOverload; + use overload '&{}' => sub { sub { 5 } }, fallback => 1; + sub new { bless {} } +} + $gen->generate_method('Foo' => 'one' => { is => 'ro' }); $gen->generate_method('Foo' => 'two' => { is => 'rw' }); @@ -26,39 +33,76 @@ like( ); like( - exception { $gen->generate_method('Foo' => 'four' => { is => 'ro', default => 5 }) }, - qr/Invalid default/, 'default - scalar rejected' + exception { $gen->generate_method('Foo' => 'four' => { is => 'ro', coerce => 5 }) }, + qr/Invalid coerce/, "coerce - scalar rejected" ); -like( - exception { $gen->generate_method('Foo' => 'five' => { is => 'ro', default => [] }) }, - qr/Invalid default/, 'default - arrayref rejected' +is( + exception { $gen->generate_method('Foo' => 'four' => { is => 'ro', default => 5 }) }, + undef, "default - non-ref scalar accepted" ); +foreach my $setting (qw( default coerce )) { + + like( + exception { $gen->generate_method('Foo' => 'five' => { allow_overwrite => 1, is => 'ro', $setting => [] }) }, + qr/Invalid $setting/, "$setting - arrayref rejected" + ); + + like( + exception { $gen->generate_method('Foo' => 'five' => { allow_overwrite => 1, is => 'ro', $setting => Foo->new }) }, + qr/Invalid $setting/, "$setting - non-code-convertible object rejected" + ); + + is( + exception { $gen->generate_method('Foo' => 'six' => { allow_overwrite => 1, is => 'ro', $setting => sub { 5 } }) }, + undef, "$setting - coderef accepted" + ); + + is( + exception { $gen->generate_method('Foo' => 'seven' => { allow_overwrite => 1, is => 'ro', $setting => bless sub { 5 } => 'Blah' }) }, + undef, "$setting - blessed sub accepted" + ); + + is( + exception { $gen->generate_method('Foo' => 'eight' => { allow_overwrite => 1, is => 'ro', $setting => WithOverload->new }) }, + undef, "$setting - object with overloaded ->() accepted" + ); + + like( + exception { $gen->generate_method('Foo' => 'nine' => { allow_overwrite => 1, is => 'ro', $setting => bless {} => 'Blah' }) }, + qr/Invalid $setting/, "$setting - object rejected" + ); +} + is( - exception { $gen->generate_method('Foo' => 'six' => { is => 'ro', default => sub { 5 } }) }, - undef, 'default - coderef accepted' + exception { $gen->generate_method('Foo' => 'ten' => { is => 'ro', builder => '_build_ten' }) }, + undef, 'builder - string accepted', ); is( - exception { $gen->generate_method('Foo' => 'seven' => { is => 'ro', default => bless sub { 5 } => 'Blah' }) }, - undef, 'default - blessed sub accepted' + exception { $gen->generate_method('Foo' => 'eleven' => { is => 'ro', builder => sub {} }) }, + undef, 'builder - coderef accepted' ); -{ - package WithOverload; - use overload '&{}' => sub { sub { 5 } }; - sub new { bless {} } -} +like( + exception { $gen->generate_method('Foo' => 'twelve' => { is => 'ro', builder => 'build:twelve' }) }, + qr/Invalid builder/, 'builder - invalid name rejected', +); is( - exception { $gen->generate_method('Foo' => 'eight' => { is => 'ro', default => WithOverload->new }) }, - undef, 'default - object with overloaded ->() accepted' + exception { $gen->generate_method('Foo' => 'thirteen' => { is => 'ro', builder => 'build::thirteen' }) }, + undef, 'builder - fully-qualified name accepted', ); -like( - exception { $gen->generate_method('Foo' => 'nine' => { is => 'ro', default => bless {} => 'Blah' }) }, - qr/Invalid default/, 'default - object rejected' +is( + exception { $gen->generate_method('Foo' => 'fifteen' => { is => 'lazy', builder => sub {15} }) }, + undef, 'builder - coderef accepted' +); + +is( + exception { $gen->generate_method('Foo' => 'sixteen' => { is => 'lazy', builder => quote_sub q{ 16 } }) }, + undef, 'builder - quote_sub accepted' ); my $foo = Foo->new(one => 1); @@ -71,4 +115,9 @@ is($foo->two, undef, 'rw reads'); $foo->two(-3); is($foo->two, -3, 'rw writes'); +is($foo->fifteen, 15, 'builder installs code sub'); +is($foo->_build_fifteen, 15, 'builder installs code sub under the correct name'); + +is($foo->sixteen, 16, 'builder installs quote_sub'); + done_testing;