X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F030_method.t;h=4813b82d8c2db9540ce8f37fb913347a1f982952;hb=2226a8b07473ebde21f32a77683a2f3192f41b99;hp=2f246a90bd88ead8c9ab5d099cb61b8c75f56b5e;hpb=a4258ffd7a0a2bb8db5f01936068185d4f879b1a;p=gitmo%2FClass-MOP.git diff --git a/t/030_method.t b/t/030_method.t index 2f246a9..4813b82 100644 --- a/t/030_method.t +++ b/t/030_method.t @@ -3,19 +3,36 @@ use strict; use warnings; -use Test::More tests => 18; +use Test::More tests => 39; use Test::Exception; -BEGIN { - use_ok('Class::MOP'); - use_ok('Class::MOP::Method'); -} +use Class::MOP; +use Class::MOP::Method; + -my $method = Class::MOP::Method->wrap(sub { 1 }); +my $method = Class::MOP::Method->wrap( + sub { 1 }, + package_name => 'main', + name => '__ANON__', +); is($method->meta, Class::MOP::Method->meta, '... instance and class both lead to the same meta'); is($method->package_name, 'main', '... our package is main::'); is($method->name, '__ANON__', '... our sub name is __ANON__'); +is($method->fully_qualified_name, 'main::__ANON__', '... our subs full name is main::__ANON__'); +is($method->original_method, undef, '... no original_method '); +is($method->original_package_name, 'main', '... the original_package_name is the same as package_name'); +is($method->original_name, '__ANON__', '... the original_name is the same as name'); +is($method->original_fully_qualified_name, 'main::__ANON__', '... the original_fully_qualified_name is the same as fully_qualified_name'); + +dies_ok { Class::MOP::Method->wrap } q{... can't call wrap() without some code}; +dies_ok { Class::MOP::Method->wrap([]) } q{... can't call wrap() without some code}; +dies_ok { Class::MOP::Method->wrap(bless {} => 'Fail') } q{... can't call wrap() without some code}; + +dies_ok { Class::MOP::Method->name } q{... can't call name() as a class method}; +dies_ok { Class::MOP::Method->body } q{... can't call body() as a class method}; +dies_ok { Class::MOP::Method->package_name } q{... can't call package_name() as a class method}; +dies_ok { Class::MOP::Method->fully_qualified_name } q{... can't call fully_qualified_name() as a class method}; my $meta = Class::MOP::Method->meta; isa_ok($meta, 'Class::MOP::Class'); @@ -41,4 +58,30 @@ dies_ok { dies_ok { Class::MOP::Method->wrap([]) -} '... bad args for &wrap'; \ No newline at end of file +} '... bad args for &wrap'; + +dies_ok { + Class::MOP::Method->wrap(sub { 'FAIL' }) +} '... bad args for &wrap'; + +dies_ok { + Class::MOP::Method->wrap(sub { 'FAIL' }, package_name => 'main') +} '... bad args for &wrap'; + +dies_ok { + Class::MOP::Method->wrap(sub { 'FAIL' }, name => '__ANON__') +} '... bad args for &wrap'; + +my $clone = $method->clone( + package_name => 'NewPackage', + name => 'new_name', +); + +isa_ok($clone, 'Class::MOP::Method'); +is($clone->package_name, 'NewPackage', '... cloned method has new pckage name'); +is($clone->name, 'new_name', '... cloned method has new sub name'); +is($clone->fully_qualified_name, 'NewPackage::new_name', '... cloned method has new fq name'); +is($clone->original_method, $method, '... cloned method has correct original_method'); +is($clone->original_package_name, 'main', '... cloned method has correct original_package_name'); +is($clone->original_name, '__ANON__', '... cloned method has correct original_name'); +is($clone->original_fully_qualified_name, 'main::__ANON__', '... cloned method has correct original_fully_qualified_name');