use strict;
use warnings;
-use Test::More tests => 18;
+use Test::More tests => 28;
use Test::Exception;
BEGIN {
use_ok('Class::MOP::Method');
}
-my $method = Class::MOP::Method->new(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__');
+
+dies_ok { Class::MOP::Method->wrap } '... cant call this method without some code';
+dies_ok { Class::MOP::Method->wrap([]) } '... cant call this method without some code';
+dies_ok { Class::MOP::Method->wrap(bless {} => 'Fail') } '... cant call this method without some code';
+
+dies_ok { Class::MOP::Method->name } '... cant call this method with a class';
+dies_ok { Class::MOP::Method->package_name } '... cant call this method with a class';
+dies_ok { Class::MOP::Method->fully_qualified_name } '... cant call this method with a class';
my $meta = Class::MOP::Method->meta;
isa_ok($meta, 'Class::MOP::Class');
foreach my $method_name (qw(
- new
+ wrap
package_name
name
)) {
}
dies_ok {
- Class::MOP::Method->new()
+ Class::MOP::Method->wrap()
+} '... bad args for &wrap';
+
+dies_ok {
+ Class::MOP::Method->wrap('Fail')
} '... bad args for &wrap';
dies_ok {
- Class::MOP::Method->new('Fail')
+ Class::MOP::Method->wrap([])
} '... bad args for &wrap';
dies_ok {
- Class::MOP::Method->new([])
-} '... bad args for &wrap';
\ No newline at end of file
+ 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';
+
+
+
+
+