summaryrefslogtreecommitdiff
path: root/cpan/Object-Accessor/t
diff options
context:
space:
mode:
authorChris 'BinGOs' Williams <chris@bingosnet.co.uk>2011-01-08 23:09:04 +0000
committerChris 'BinGOs' Williams <chris@bingosnet.co.uk>2011-01-08 23:09:04 +0000
commit0019012ad86d597fb507f71577d70ecd4c416bba (patch)
tree04fc542107733593ff7160bb07de38880c7917a7 /cpan/Object-Accessor/t
parent4fc94532da4b3d2462eb7388c63cc5a714c95725 (diff)
downloadperl-0019012ad86d597fb507f71577d70ecd4c416bba.tar.gz
Update Object-Accessor to CPAN version 0.38
[DELTA] Changes for 0.38 Fri Jan 7 21:47:51 GMT 2011 ================================================= * Apply blead patch from Peter Acklam
Diffstat (limited to 'cpan/Object-Accessor/t')
-rw-r--r--cpan/Object-Accessor/t/06_Object-Accessor-alias.t63
1 files changed, 43 insertions, 20 deletions
diff --git a/cpan/Object-Accessor/t/06_Object-Accessor-alias.t b/cpan/Object-Accessor/t/06_Object-Accessor-alias.t
index 2a8aa81f0d..f302a09523 100644
--- a/cpan/Object-Accessor/t/06_Object-Accessor-alias.t
+++ b/cpan/Object-Accessor/t/06_Object-Accessor-alias.t
@@ -9,25 +9,48 @@ my $Class = 'Object::Accessor';
use_ok($Class);
-my $Object = $Class->new;
-my $Acc = 'foo';
-my $Alias = 'bar';
-
-### basic sanity test
-{ ok( $Object, "Object created" );
-
- ok( $Object->mk_accessors( $Acc ),
- " Accessor ->$Acc created" );
- ok( $Object->$Acc( $$ ), " ->$Acc set to $$" );
+my $Object = $Class->new;
+my $Acc = 'foo';
+my $Alias = 'bar';
+
+ok( $Object, "Object created" );
+isa_ok( $Object, $Class, " Object" );
+
+### add an accessor
+{ my $rv = $Object->mk_accessors( $Acc );
+ ok( $rv, "Created accessor '$Acc'" );
+ ok( $Object->$Acc( $$ )," Set value" );
+ is( $Object->$Acc, $$, " Retrieved value" );
+}
+
+### add an alias
+{ my $rv = $Object->mk_aliases( $Alias => $Acc );
+ ok( $rv, "Created alias '$Alias'" );
+ ok( $Object->can( $Alias ),
+ " Alias '$Alias' exists" );
+ is( $Object->$Alias, $Object->$Acc,
+ " Alias & original return the same value" );
+
+ ok( $Object->$Alias( $$.$$ ),
+ " Changed value using alias" );
+ is( $Object->$Alias, $Object->$Acc,
+ " Alias & original return the same value" );
+}
+
+### test if cloning works
+{ my $clone = $Object->mk_clone;
+ ok( $clone, "Cloned object" );
+
+ is_deeply( [sort $clone->ls_accessors], [sort $Object->ls_accessors],
+ " All accessors cloned" );
+
+ ok( $clone->$Acc( $$ ), " Set value" );
+ is( $clone->$Alias, $clone->$Acc,
+ " Alias & original return the same value" );
+
+ ok( $clone->$Alias( $$.$$ ),
+ " Changed value using alias" );
+ is( $clone->$Alias, $clone->$Acc,
+ " Alias & original return the same value" );
}
-### alias tests
-{ ok( $Object->mk_aliases( $Alias => $Acc ),
- "Alias ->$Alias => ->$Acc" );
- ok( $Object->$Alias, " ->$Alias returns value" );
- is( $Object->$Acc, $Object->$Alias,
- " ->$Alias eq ->$Acc" );
- ok( $Object->$Alias( $0 ), " Set value via alias ->$Alias" );
- is( $Object->$Acc, $Object->$Alias,
- " ->$Alias eq ->$Acc" );
-}