use Test::Fatal;
use Method::Generate::Accessor;
+use Sub::Quote 'quote_sub';
my $gen = Method::Generate::Accessor->new;
qr/Unknown is purple/, 'is purple rejected'
);
-for my $setting (qw( default coerce )) {
- like(
- exception { $gen->generate_method('Foo' => 'four' => { is => 'ro', $setting => 5 }) },
- qr/Invalid $setting/, "$setting - scalar rejected"
- );
+like(
+ exception { $gen->generate_method('Foo' => 'four' => { is => 'ro', coerce => 5 }) },
+ qr/Invalid coerce/, "coerce - scalar 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' => { is => 'ro', $setting => [] }) },
+ 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' => { is => 'ro', $setting => Foo->new }) },
+ 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' => { is => 'ro', $setting => sub { 5 } }) },
+ 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' => { is => 'ro', $setting => bless sub { 5 } => 'Blah' }) },
+ 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' => { is => 'ro', $setting => WithOverload->new }) },
+ 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' => { is => 'ro', $setting => bless {} => 'Blah' }) },
+ exception { $gen->generate_method('Foo' => 'nine' => { allow_overwrite => 1, is => 'ro', $setting => bless {} => 'Blah' }) },
qr/Invalid $setting/, "$setting - object rejected"
);
}
undef, 'builder - string accepted',
);
-like(
+is(
exception { $gen->generate_method('Foo' => 'eleven' => { is => 'ro', builder => sub {} }) },
- qr/Invalid builder/, 'builder - coderef rejected'
+ undef, 'builder - coderef accepted'
);
like(
undef, 'builder - fully-qualified name accepted',
);
+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);
is($foo->one, 1, 'ro 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;