X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F010_self_introspection.t;h=5d891d5410c69484c0a963a89861ae3ca1f5ee0f;hb=9aeda601ba12d0b78a51115d5f01c9021e029414;hp=dcac510adea17d60fde9f22259af3df25fda7d28;hpb=3cf189f335625b5ceb9ba49895ee9c78af07dbaa;p=gitmo%2FClass-MOP.git diff --git a/t/010_self_introspection.t b/t/010_self_introspection.t index dcac510..5d891d5 100644 --- a/t/010_self_introspection.t +++ b/t/010_self_introspection.t @@ -1,7 +1,7 @@ use strict; use warnings; -use Test::More tests => 298; +use Test::More tests => 304; use Test::Exception; use Class::MOP; @@ -34,7 +34,16 @@ my @class_mop_package_methods = qw( add_package_symbol get_package_symbol has_package_symbol remove_package_symbol list_all_package_symbols get_all_package_symbols remove_package_glob + method_metaclass wrapped_method_metaclass + + _method_map + _code_is_mine + has_method get_method add_method remove_method wrap_method_body + get_method_list _full_method_map + _deconstruct_variable_name + + get_method_map ); my @class_mop_module_methods = qw( @@ -70,14 +79,12 @@ my @class_mop_class_methods = qw( add_dependent_meta_instance remove_dependent_meta_instance invalidate_meta_instances invalidate_meta_instance - attribute_metaclass method_metaclass wrapped_method_metaclass + attribute_metaclass superclasses subclasses direct_subclasses class_precedence_list linearized_isa _superclasses_updated - _method_map - has_method get_method add_method remove_method alias_method wrap_method_body - get_method_list get_method_map get_all_method_names get_all_methods compute_all_applicable_methods + alias_method get_all_method_names get_all_methods compute_all_applicable_methods find_method_by_name find_all_methods_by_name find_next_method_by_name add_before_method_modifier add_after_method_modifier add_around_method_modifier @@ -92,7 +99,8 @@ my @class_mop_class_methods = qw( _rebless_as_mutable _remove_inlined_code _immutable_metaclass - immutable_trait constructor_name constructor_class destructor_class + immutable_trait immutable_options + constructor_name constructor_class destructor_class DESTROY ); @@ -156,6 +164,9 @@ foreach my $non_method_name (qw( my @class_mop_package_attributes = ( 'package', 'namespace', + 'method_metaclass', + 'wrapped_method_metaclass', + '_methods', ); my @class_mop_module_attributes = ( @@ -165,11 +176,8 @@ my @class_mop_module_attributes = ( my @class_mop_class_attributes = ( 'superclasses', - 'methods', 'attributes', 'attribute_metaclass', - 'method_metaclass', - 'wrapped_method_metaclass', 'instance_metaclass', 'immutable_trait', 'constructor_name', @@ -239,6 +247,37 @@ is(ref($class_mop_package_meta->get_attribute('package')->reader), 'HASH', '... ok($class_mop_package_meta->get_attribute('package')->has_init_arg, '... Class::MOP::Class package has a init_arg'); is($class_mop_package_meta->get_attribute('package')->init_arg, 'package', '... Class::MOP::Class package\'s a init_arg is package'); +ok($class_mop_package_meta->get_attribute('method_metaclass')->has_reader, '... Class::MOP::Package method_metaclass has a reader'); +is_deeply($class_mop_package_meta->get_attribute('method_metaclass')->reader, + { 'method_metaclass' => \&Class::MOP::Package::method_metaclass }, + '... Class::MOP::Package method_metaclass\'s a reader is &method_metaclass'); + +ok($class_mop_package_meta->get_attribute('method_metaclass')->has_init_arg, '... Class::MOP::Package method_metaclass has a init_arg'); +is($class_mop_package_meta->get_attribute('method_metaclass')->init_arg, + 'method_metaclass', + '... Class::MOP::Package method_metaclass\'s init_arg is method_metaclass'); + +ok($class_mop_package_meta->get_attribute('method_metaclass')->has_default, '... Class::MOP::Package method_metaclass has a default'); +is($class_mop_package_meta->get_attribute('method_metaclass')->default, + 'Class::MOP::Method', + '... Class::MOP::Package method_metaclass\'s a default is Class::MOP:::Method'); + +ok($class_mop_package_meta->get_attribute('wrapped_method_metaclass')->has_reader, '... Class::MOP::Package wrapped_method_metaclass has a reader'); +is_deeply($class_mop_package_meta->get_attribute('wrapped_method_metaclass')->reader, + { 'wrapped_method_metaclass' => \&Class::MOP::Package::wrapped_method_metaclass }, + '... Class::MOP::Package wrapped_method_metaclass\'s a reader is &wrapped_method_metaclass'); + +ok($class_mop_package_meta->get_attribute('wrapped_method_metaclass')->has_init_arg, '... Class::MOP::Package wrapped_method_metaclass has a init_arg'); +is($class_mop_package_meta->get_attribute('wrapped_method_metaclass')->init_arg, + 'wrapped_method_metaclass', + '... Class::MOP::Package wrapped_method_metaclass\'s init_arg is wrapped_method_metaclass'); + +ok($class_mop_package_meta->get_attribute('method_metaclass')->has_default, '... Class::MOP::Package method_metaclass has a default'); +is($class_mop_package_meta->get_attribute('method_metaclass')->default, + 'Class::MOP::Method', + '... Class::MOP::Package method_metaclass\'s a default is Class::MOP:::Method'); + + # ... class ok($class_mop_class_meta->get_attribute('attributes')->has_reader, '... Class::MOP::Class attributes has a reader'); @@ -271,36 +310,6 @@ is($class_mop_class_meta->get_attribute('attribute_metaclass')->default, 'Class::MOP::Attribute', '... Class::MOP::Class attribute_metaclass\'s a default is Class::MOP:::Attribute'); -ok($class_mop_class_meta->get_attribute('method_metaclass')->has_reader, '... Class::MOP::Class method_metaclass has a reader'); -is_deeply($class_mop_class_meta->get_attribute('method_metaclass')->reader, - { 'method_metaclass' => \&Class::MOP::Class::method_metaclass }, - '... Class::MOP::Class method_metaclass\'s a reader is &method_metaclass'); - -ok($class_mop_class_meta->get_attribute('method_metaclass')->has_init_arg, '... Class::MOP::Class method_metaclass has a init_arg'); -is($class_mop_class_meta->get_attribute('method_metaclass')->init_arg, - 'method_metaclass', - '... Class::MOP::Class method_metaclass\'s init_arg is method_metaclass'); - -ok($class_mop_class_meta->get_attribute('method_metaclass')->has_default, '... Class::MOP::Class method_metaclass has a default'); -is($class_mop_class_meta->get_attribute('method_metaclass')->default, - 'Class::MOP::Method', - '... Class::MOP::Class method_metaclass\'s a default is Class::MOP:::Method'); - -ok($class_mop_class_meta->get_attribute('wrapped_method_metaclass')->has_reader, '... Class::MOP::Class wrapped_method_metaclass has a reader'); -is_deeply($class_mop_class_meta->get_attribute('wrapped_method_metaclass')->reader, - { 'wrapped_method_metaclass' => \&Class::MOP::Class::wrapped_method_metaclass }, - '... Class::MOP::Class wrapped_method_metaclass\'s a reader is &wrapped_method_metaclass'); - -ok($class_mop_class_meta->get_attribute('wrapped_method_metaclass')->has_init_arg, '... Class::MOP::Class wrapped_method_metaclass has a init_arg'); -is($class_mop_class_meta->get_attribute('wrapped_method_metaclass')->init_arg, - 'wrapped_method_metaclass', - '... Class::MOP::Class wrapped_method_metaclass\'s init_arg is wrapped_method_metaclass'); - -ok($class_mop_class_meta->get_attribute('method_metaclass')->has_default, '... Class::MOP::Class method_metaclass has a default'); -is($class_mop_class_meta->get_attribute('method_metaclass')->default, - 'Class::MOP::Method', - '... Class::MOP::Class method_metaclass\'s a default is Class::MOP:::Method'); - # check the values of some of the methods is($class_mop_class_meta->name, 'Class::MOP::Class', '... Class::MOP::Class->name');