X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Faccessors_wo.t;h=47463b6aec1bbbdb36983f0a203a675b4122e13b;hb=4ae5d124cca40cffd989a187f87b4c29199e0daa;hp=6700eb2da59420e2ac2b8ffa519f7d13a975bdf7;hpb=c26cc2b95d5d259245809d3ca521e720142c80eb;p=p5sagit%2FClass-Accessor-Grouped.git diff --git a/t/accessors_wo.t b/t/accessors_wo.t index 6700eb2..47463b6 100644 --- a/t/accessors_wo.t +++ b/t/accessors_wo.t @@ -1,10 +1,24 @@ use Test::More tests => 38; +use Test::Exception; use strict; use warnings; use lib 't/lib'; + +# we test the pure-perl versions only, but allow overrides +# from the accessor_xs test-umbrella +# Also make sure a rogue envvar will not interfere with +# things +my $use_xs; +BEGIN { + $Class::Accessor::Grouped::USE_XS = 0 + unless defined $Class::Accessor::Grouped::USE_XS; + $ENV{CAG_USE_XS} = 1; + $use_xs = $Class::Accessor::Grouped::USE_XS; +}; + use AccessorGroupsWO; -my $class = AccessorGroupsWO->new; +my $obj = AccessorGroupsWO->new; { my $warned = 0; @@ -15,65 +29,61 @@ my $class = AccessorGroupsWO->new; }; }; - $class->mk_group_wo_accessors('warnings', 'DESTROY'); + no warnings qw/once/; + local *AccessorGroupsWO::DESTROY = sub {}; + $obj->mk_group_wo_accessors('warnings', 'DESTROY'); ok($warned); - - # restore non-accessorized DESTROY - no warnings; - *AccessorGroupsWO::DESTROY = sub {}; }; -foreach (qw/singlefield multiple1 multiple2/) { - my $name = $_; - my $alias = "_${name}_accessor"; - - can_ok($class, $name, $alias); - - # set via name - is($class->$name('a'), 'a'); - is($class->{$name}, 'a'); - - # alias sets same as name - is($class->$alias('b'), 'b'); - is($class->{$name}, 'b'); - - # die on get via name/alias - eval { - $class->$name; - }; - ok($@ =~ /cannot access/); - - eval { - $class->$alias; - }; - ok($@ =~ /cannot access/); +my $test_accessors = { + singlefield => { + is_xs => $use_xs, + }, + multiple1 => { + }, + multiple2 => { + }, + lr1name => { + custom_field => 'lr1;field', + }, + lr2name => { + custom_field => "lr2'field", + }, }; -foreach (qw/lr1 lr2/) { - my $name = "$_".'name'; +for my $name (sort keys %$test_accessors) { + my $alias = "_${name}_accessor"; - my $field = "$_".'field'; + my $field = $test_accessors->{$name}{custom_field} || $name; - can_ok($class, $name, $alias); - ok(!$class->can($field)); + can_ok($obj, $name, $alias); + + ok(!$obj->can($field)) + if $field ne $name; # set via name - is($class->$name('c'), 'c'); - is($class->{$field}, 'c'); + is($obj->$name('a'), 'a'); + is($obj->{$field}, 'a'); # alias sets same as name - is($class->$alias('d'), 'd'); - is($class->{$field}, 'd'); + is($obj->$alias('b'), 'b'); + is($obj->{$field}, 'b'); + + my $wo_regex = $test_accessors->{$name}{is_xs} + ? qr/Usage\:.+$name.*\(self, newvalue\)/ + : qr/cannot access the value of '\Q$field\E'/ + ; # die on get via name/alias - eval { - $class->$name; - }; - ok($@ =~ /cannot access/); + throws_ok { + $obj->$name; + } $wo_regex; - eval { - $class->$alias; - }; - ok($@ =~ /cannot access/); + throws_ok { + $obj->$alias; + } $wo_regex; }; + +# important +1; \ No newline at end of file