X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F030_method.t;h=4987909d4ea0ebbdd1cde764cbaff85d795d032b;hb=41fc2d0fd29483cb704e06198bfaabbcd3e09d08;hp=b481a5c9d908abcbfe43783d89b4c8af084e42fe;hpb=da88f307a9f54e4fef38bf1d7354cdb4d137c451;p=gitmo%2FClass-MOP.git diff --git a/t/030_method.t b/t/030_method.t index b481a5c..4987909 100644 --- a/t/030_method.t +++ b/t/030_method.t @@ -1,9 +1,7 @@ -#!/usr/bin/perl - use strict; use warnings; -use Test::More tests => 27; +use Test::More tests => 46; use Test::Exception; use Class::MOP; @@ -20,6 +18,10 @@ is($method->meta, Class::MOP::Method->meta, '... instance and class both lead to 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}; @@ -68,7 +70,29 @@ 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 package 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'); + +my $clone2 = $clone->clone( + package_name => 'NewerPackage', + name => 'newer_name', +); - - +is($clone2->package_name, 'NewerPackage', '... clone of clone has new package name'); +is($clone2->name, 'newer_name', '... clone of clone has new sub name'); +is($clone2->fully_qualified_name, 'NewerPackage::newer_name', '... clone of clone new fq name'); +is($clone2->original_method, $clone, '... cloned method has correct original_method'); +is($clone2->original_package_name, 'main', '... original_package_name follows clone chain'); +is($clone2->original_name, '__ANON__', '... original_name follows clone chain'); +is($clone2->original_fully_qualified_name, 'main::__ANON__', '... original_fully_qualified_name follows clone chain');