X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F020_attribute.t;h=33cafdde9d7959e3dd24042e56000d012f26aff8;hb=8d2d4c6705a3781606464d003a3641d835a35815;hp=d23820d9bd3e86cd87cc76087316e2efcc479c1e;hpb=1a7ebbb3e44301a39a8b5c57542ca8ae76a3e2d0;p=gitmo%2FClass-MOP.git diff --git a/t/020_attribute.t b/t/020_attribute.t index d23820d..33cafdd 100644 --- a/t/020_attribute.t +++ b/t/020_attribute.t @@ -3,7 +3,7 @@ use strict; use warnings; -use Test::More tests => 64; +use Test::More tests => 73; use Test::Exception; BEGIN { @@ -16,12 +16,33 @@ BEGIN { isa_ok($attr, 'Class::MOP::Attribute'); is($attr->name, '$foo', '... $attr->name == $foo'); - + ok($attr->has_init_arg, '... $attr does have an init_arg'); + is($attr->init_arg, '$foo', '... $attr init_arg is the name'); + ok(!$attr->has_accessor, '... $attr does not have an accessor'); ok(!$attr->has_reader, '... $attr does not have an reader'); ok(!$attr->has_writer, '... $attr does not have an writer'); - ok(!$attr->has_init_arg, '... $attr does not have an init_arg'); - ok(!$attr->has_default, '... $attr does not have an default'); + ok(!$attr->has_default, '... $attr does not have an default'); + ok(!$attr->has_builder, '... $attr does not have a builder'); + + my $class = Class::MOP::Class->initialize('Foo'); + isa_ok($class, 'Class::MOP::Class'); + + lives_ok { + $attr->attach_to_class($class); + } '... attached a class successfully'; + + is($attr->associated_class, $class, '... the class was associated correctly'); + + my $attr_clone = $attr->clone(); + isa_ok($attr_clone, 'Class::MOP::Attribute'); + isnt($attr, $attr_clone, '... but they are different instances'); + + is($attr->associated_class, $attr_clone->associated_class, '... the associated classes are the same though'); + is($attr->associated_class, $class, '... the associated classes are the same though'); + is($attr_clone->associated_class, $class, '... the associated classes are the same though'); + + is_deeply($attr, $attr_clone, '... but they are the same inside'); } { @@ -32,15 +53,26 @@ BEGIN { isa_ok($attr, 'Class::MOP::Attribute'); is($attr->name, '$foo', '... $attr->name == $foo'); - + ok($attr->has_init_arg, '... $attr does have an init_arg'); is($attr->init_arg, '-foo', '... $attr->init_arg == -foo'); - ok($attr->has_default, '... $attr does have an default'); + ok($attr->has_default, '... $attr does have an default'); is($attr->default, 'BAR', '... $attr->default == BAR'); - + ok(!$attr->has_builder, '... $attr does not have a builder'); + ok(!$attr->has_accessor, '... $attr does not have an accessor'); ok(!$attr->has_reader, '... $attr does not have an reader'); - ok(!$attr->has_writer, '... $attr does not have an writer'); + ok(!$attr->has_writer, '... $attr does not have an writer'); + + my $attr_clone = $attr->clone(); + isa_ok($attr_clone, 'Class::MOP::Attribute'); + isnt($attr, $attr_clone, '... but they are different instances'); + + is($attr->associated_class, $attr_clone->associated_class, '... the associated classes are the same though'); + is($attr->associated_class, undef, '... the associated class is actually undef'); + is($attr_clone->associated_class, undef, '... the associated class is actually undef'); + + is_deeply($attr, $attr_clone, '... but they are the same inside'); } { @@ -52,111 +84,75 @@ BEGIN { isa_ok($attr, 'Class::MOP::Attribute'); is($attr->name, '$foo', '... $attr->name == $foo'); - + ok($attr->has_init_arg, '... $attr does have an init_arg'); is($attr->init_arg, '-foo', '... $attr->init_arg == -foo'); - ok($attr->has_default, '... $attr does have an default'); + ok($attr->has_default, '... $attr does have an default'); is($attr->default, 'BAR', '... $attr->default == BAR'); - ok($attr->has_accessor, '... $attr does have an accessor'); + ok($attr->has_accessor, '... $attr does have an accessor'); is($attr->accessor, 'foo', '... $attr->accessor == foo'); - + ok(!$attr->has_reader, '... $attr does not have an reader'); - ok(!$attr->has_writer, '... $attr does not have an writer'); + ok(!$attr->has_writer, '... $attr does not have an writer'); + + my $attr_clone = $attr->clone(); + isa_ok($attr_clone, 'Class::MOP::Attribute'); + isnt($attr, $attr_clone, '... but they are different instances'); + + is_deeply($attr, $attr_clone, '... but they are the same inside'); } { my $attr = Class::MOP::Attribute->new('$foo', ( reader => 'get_foo', - writer => 'set_foo', + writer => 'set_foo', init_arg => '-foo', default => 'BAR' )); isa_ok($attr, 'Class::MOP::Attribute'); is($attr->name, '$foo', '... $attr->name == $foo'); - + ok($attr->has_init_arg, '... $attr does have an init_arg'); is($attr->init_arg, '-foo', '... $attr->init_arg == -foo'); - ok($attr->has_default, '... $attr does have an default'); + ok($attr->has_default, '... $attr does have an default'); is($attr->default, 'BAR', '... $attr->default == BAR'); ok($attr->has_reader, '... $attr does have an reader'); - is($attr->reader, 'get_foo', '... $attr->reader == get_foo'); + is($attr->reader, 'get_foo', '... $attr->reader == get_foo'); ok($attr->has_writer, '... $attr does have an writer'); - is($attr->writer, 'set_foo', '... $attr->writer == set_foo'); - - ok(!$attr->has_accessor, '... $attr does not have an accessor'); -} - -dies_ok { - Class::MOP::Attribute->new('$foo', ( - accessor => 'foo', - reader => 'get_foo', - )); -} '... cannot create accessors with reader/writers'; + is($attr->writer, 'set_foo', '... $attr->writer == set_foo'); -dies_ok { - Class::MOP::Attribute->new('$foo', ( - accessor => 'foo', - writer => 'set_foo', - )); -} '... cannot create accessors with reader/writers'; - -dies_ok { - Class::MOP::Attribute->new('$foo', ( - accessor => 'foo', - reader => 'get_foo', - writer => 'set_foo', - )); -} '... cannot create accessors with reader/writers'; + ok(!$attr->has_accessor, '... $attr does not have an accessor'); -dies_ok { - Class::MOP::Attribute->new(); -} '... no name argument'; + my $attr_clone = $attr->clone(); + isa_ok($attr_clone, 'Class::MOP::Attribute'); + isnt($attr, $attr_clone, '... but they are different instances'); -dies_ok { - Class::MOP::Attribute->new(''); -} '... bad name argument'; + is_deeply($attr, $attr_clone, '... but they are the same inside'); +} -dies_ok { - Class::MOP::Attribute->new(0); -} '... bad name argument'; +{ + my $attr = Class::MOP::Attribute->new('$foo'); + isa_ok($attr, 'Class::MOP::Attribute'); -dies_ok { - Class::MOP::Attribute->install_accessors(); -} '... bad install_accessors argument'; + my $attr_clone = $attr->clone('name' => '$bar'); + isa_ok($attr_clone, 'Class::MOP::Attribute'); + isnt($attr, $attr_clone, '... but they are different instances'); -dies_ok { - Class::MOP::Attribute->install_accessors(bless {} => 'Fail'); -} '... bad install_accessors argument'; + isnt($attr->name, $attr_clone->name, '... we changes the name parameter'); -dies_ok { - Class::MOP::Attribute->remove_accessors(); -} '... bad remove_accessors argument'; + is($attr->name, '$foo', '... $attr->name == $foo'); + is($attr_clone->name, '$bar', '... $attr_clone->name == $bar'); +} -dies_ok { - Class::MOP::Attribute->remove_accessors(bless {} => 'Fail'); -} '... bad remove_accessors argument'; +{ + my $attr = Class::MOP::Attribute->new('$foo', (builder => 'foo_builder')); + isa_ok($attr, 'Class::MOP::Attribute'); + ok(!$attr->has_default, '... $attr does not have a default'); + ok($attr->has_builder, '... $attr does have a builder'); + is($attr->builder, 'foo_builder', '... $attr->builder == foo_builder'); -{ - my $meta = Class::MOP::Attribute->meta(); - isa_ok($meta, 'Class::MOP::Class'); - - foreach my $method_name (qw( - meta - new - has_accessor accessor - has_writer writer - has_reader reader - has_init_arg init_arg - has_default default - install_accessors - remove_accessors - )) { - ok($meta->has_method($method_name), '... Class::MOP::Attribute->has_method(' . $method_name . ')'); - } - - }