predicate fixes
[gitmo/Class-MOP.git] / t / 030_method.t
index de48851..f803363 100644 (file)
@@ -3,7 +3,7 @@
 use strict;
 use warnings;
 
-use Test::More tests => 8;
+use Test::More tests => 25;
 use Test::Exception;
 
 BEGIN {
@@ -11,19 +11,33 @@ BEGIN {
     use_ok('Class::MOP::Method');
 }
 
+my $method = Class::MOP::Method->wrap(sub { 1 });
+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');
 
-
-{
-    my $meta = Class::MOP::Method->meta();
-    isa_ok($meta, 'Class::MOP::Class');
-    
-    foreach my $method_name (qw(
-        wrap
-        )) {
-        ok($meta->has_method($method_name), '... Class::MOP::Method->has_method(' . $method_name . ')');
-    }
+foreach my $method_name (qw(
+    wrap
+       package_name
+       name
+    )) {
+    ok($meta->has_method($method_name), '... Class::MOP::Method->has_method(' . $method_name . ')');
+       my $method = $meta->get_method($method_name);
+       is($method->package_name, 'Class::MOP::Method', '... our package is Class::MOP::Method');
+       is($method->name, $method_name, '... our sub name is "' . $method_name . '"');  
 }
 
 dies_ok {