X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F010_self_introspection.t;h=f5108b1678ae6a5dc28c4b15964a769706394191;hb=b71bd1cded366fe62f4a44471908dd57a8686077;hp=19f17861a3abfe56f90cbaf0fe2d98879c87c6fb;hpb=11a8a2c1386357b58e7066a191856913407b2ddd;p=gitmo%2FClass-MOP.git diff --git a/t/010_self_introspection.t b/t/010_self_introspection.t index 19f1786..f5108b1 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 => 248; +use Test::More; use Test::Exception; use Class::MOP; @@ -35,11 +35,15 @@ my @class_mop_package_methods = qw( list_all_package_symbols get_all_package_symbols remove_package_glob _deconstruct_variable_name + + get_method_map ); my @class_mop_module_methods = qw( _new + _instantiate_module + version authority identifier create ); @@ -49,39 +53,45 @@ my @class_mop_class_methods = qw( is_pristine initialize create - + update_package_cache_flag reset_package_cache_flag create_anon_class is_anon_class - instance_metaclass get_meta_instance create_meta_instance + instance_metaclass get_meta_instance + create_meta_instance _create_meta_instance new_object clone_object - construct_instance + construct_instance _construct_instance construct_class_instance _construct_class_instance - clone_instance - rebless_instance + clone_instance _clone_instance + rebless_instance rebless_instance_away check_metaclass_compatibility _check_metaclass_compatibility add_meta_instance_dependencies remove_meta_instance_dependencies update_meta_instance_dependencies add_dependent_meta_instance remove_dependent_meta_instance invalidate_meta_instances invalidate_meta_instance - attribute_metaclass method_metaclass wrapped_method_metaclass - - superclasses subclasses class_precedence_list linearized_isa + superclasses subclasses direct_subclasses class_precedence_list + linearized_isa _superclasses_updated - 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 - has_attribute get_attribute add_attribute remove_attribute - get_attribute_list get_attribute_map get_all_attributes compute_all_applicable_attributes find_attribute_by_name + compute_all_applicable_attributes + get_attribute_map - is_mutable is_immutable make_mutable make_immutable create_immutable_transformer - get_immutable_options get_immutable_transformer + is_mutable is_immutable make_mutable make_immutable + _initialize_immutable _install_inlined_code _inlined_methods + _add_inlined_method _inline_accessors _inline_constructor + _inline_destructor _immutable_options _rebless_as_immutable + _rebless_as_mutable _remove_inlined_code + + _immutable_metaclass + immutable_trait immutable_options + constructor_name constructor_class destructor_class DESTROY ); @@ -154,12 +164,11 @@ my @class_mop_module_attributes = ( my @class_mop_class_attributes = ( 'superclasses', - 'methods', - 'attributes', - 'attribute_metaclass', - 'method_metaclass', - 'wrapped_method_metaclass', - 'instance_metaclass' + 'instance_metaclass', + 'immutable_trait', + 'constructor_name', + 'constructor_class', + 'destructor_class', ); # check class @@ -171,7 +180,7 @@ is_deeply( ); is_deeply( - [ sort keys %{$class_mop_class_meta->get_attribute_map} ], + [ sort keys %{$class_mop_class_meta->_attribute_map} ], [ sort @class_mop_class_attributes ], '... got the right list of attributes'); @@ -188,7 +197,7 @@ is_deeply( '... got the right list of attributes'); is_deeply( - [ sort keys %{$class_mop_package_meta->get_attribute_map} ], + [ sort keys %{$class_mop_package_meta->_attribute_map} ], [ sort @class_mop_package_attributes ], '... got the right list of attributes'); @@ -205,7 +214,7 @@ is_deeply( '... got the right list of attributes'); is_deeply( - [ sort keys %{$class_mop_module_meta->get_attribute_map} ], + [ sort keys %{$class_mop_module_meta->_attribute_map} ], [ sort @class_mop_module_attributes ], '... got the right list of attributes'); @@ -224,68 +233,70 @@ 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'); -# ... class +# ... package, but inherited from HasMethods +ok($class_mop_package_meta->find_attribute_by_name('method_metaclass')->has_reader, '... Class::MOP::Package method_metaclass has a reader'); +is_deeply($class_mop_package_meta->find_attribute_by_name('method_metaclass')->reader, + { 'method_metaclass' => \&Class::MOP::HasMethods::method_metaclass }, + '... Class::MOP::Package method_metaclass\'s a reader is &method_metaclass'); + +ok($class_mop_package_meta->find_attribute_by_name('method_metaclass')->has_init_arg, '... Class::MOP::Package method_metaclass has a init_arg'); +is($class_mop_package_meta->find_attribute_by_name('method_metaclass')->init_arg, + 'method_metaclass', + '... Class::MOP::Package method_metaclass\'s init_arg is method_metaclass'); + +ok($class_mop_package_meta->find_attribute_by_name('method_metaclass')->has_default, '... Class::MOP::Package method_metaclass has a default'); +is($class_mop_package_meta->find_attribute_by_name('method_metaclass')->default, + 'Class::MOP::Method', + '... Class::MOP::Package method_metaclass\'s a default is Class::MOP:::Method'); + +ok($class_mop_package_meta->find_attribute_by_name('wrapped_method_metaclass')->has_reader, '... Class::MOP::Package wrapped_method_metaclass has a reader'); +is_deeply($class_mop_package_meta->find_attribute_by_name('wrapped_method_metaclass')->reader, + { 'wrapped_method_metaclass' => \&Class::MOP::HasMethods::wrapped_method_metaclass }, + '... Class::MOP::Package wrapped_method_metaclass\'s a reader is &wrapped_method_metaclass'); + +ok($class_mop_package_meta->find_attribute_by_name('wrapped_method_metaclass')->has_init_arg, '... Class::MOP::Package wrapped_method_metaclass has a init_arg'); +is($class_mop_package_meta->find_attribute_by_name('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->find_attribute_by_name('method_metaclass')->has_default, '... Class::MOP::Package method_metaclass has a default'); +is($class_mop_package_meta->find_attribute_by_name('method_metaclass')->default, + 'Class::MOP::Method', + '... Class::MOP::Package method_metaclass\'s a default is Class::MOP:::Method'); -ok($class_mop_class_meta->get_attribute('attributes')->has_reader, '... Class::MOP::Class attributes has a reader'); -is_deeply($class_mop_class_meta->get_attribute('attributes')->reader, - { 'get_attribute_map' => \&Class::MOP::Class::get_attribute_map }, - '... Class::MOP::Class attributes\'s a reader is &get_attribute_map'); -ok($class_mop_class_meta->get_attribute('attributes')->has_init_arg, '... Class::MOP::Class attributes has a init_arg'); -is($class_mop_class_meta->get_attribute('attributes')->init_arg, +# ... class, but inherited from HasAttributes + +ok($class_mop_class_meta->find_attribute_by_name('attributes')->has_reader, '... Class::MOP::Class attributes has a reader'); +is_deeply($class_mop_class_meta->find_attribute_by_name('attributes')->reader, + { '_attribute_map' => \&Class::MOP::HasAttributes::_attribute_map }, + '... Class::MOP::Class attributes\'s a reader is &_attribute_map'); + +ok($class_mop_class_meta->find_attribute_by_name('attributes')->has_init_arg, '... Class::MOP::Class attributes has a init_arg'); +is($class_mop_class_meta->find_attribute_by_name('attributes')->init_arg, 'attributes', '... Class::MOP::Class attributes\'s a init_arg is attributes'); -ok($class_mop_class_meta->get_attribute('attributes')->has_default, '... Class::MOP::Class attributes has a default'); -is_deeply($class_mop_class_meta->get_attribute('attributes')->default('Foo'), +ok($class_mop_class_meta->find_attribute_by_name('attributes')->has_default, '... Class::MOP::Class attributes has a default'); +is_deeply($class_mop_class_meta->find_attribute_by_name('attributes')->default('Foo'), {}, '... Class::MOP::Class attributes\'s a default of {}'); -ok($class_mop_class_meta->get_attribute('attribute_metaclass')->has_reader, '... Class::MOP::Class attribute_metaclass has a reader'); -is_deeply($class_mop_class_meta->get_attribute('attribute_metaclass')->reader, - { 'attribute_metaclass' => \&Class::MOP::Class::attribute_metaclass }, +ok($class_mop_class_meta->find_attribute_by_name('attribute_metaclass')->has_reader, '... Class::MOP::Class attribute_metaclass has a reader'); +is_deeply($class_mop_class_meta->find_attribute_by_name('attribute_metaclass')->reader, + { 'attribute_metaclass' => \&Class::MOP::HasAttributes::attribute_metaclass }, '... Class::MOP::Class attribute_metaclass\'s a reader is &attribute_metaclass'); -ok($class_mop_class_meta->get_attribute('attribute_metaclass')->has_init_arg, '... Class::MOP::Class attribute_metaclass has a init_arg'); -is($class_mop_class_meta->get_attribute('attribute_metaclass')->init_arg, +ok($class_mop_class_meta->find_attribute_by_name('attribute_metaclass')->has_init_arg, '... Class::MOP::Class attribute_metaclass has a init_arg'); +is($class_mop_class_meta->find_attribute_by_name('attribute_metaclass')->init_arg, 'attribute_metaclass', '... Class::MOP::Class attribute_metaclass\'s a init_arg is attribute_metaclass'); -ok($class_mop_class_meta->get_attribute('attribute_metaclass')->has_default, '... Class::MOP::Class attribute_metaclass has a default'); -is($class_mop_class_meta->get_attribute('attribute_metaclass')->default, +ok($class_mop_class_meta->find_attribute_by_name('attribute_metaclass')->has_default, '... Class::MOP::Class attribute_metaclass has a default'); +is($class_mop_class_meta->find_attribute_by_name('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'); @@ -298,7 +309,7 @@ is(${$class_mop_class_meta->get_package_symbol('$VERSION')}, is_deeply( [ $class_mop_class_meta->superclasses ], - [ qw/Class::MOP::Module/ ], + [ qw/Class::MOP::Module Class::MOP::HasAttributes/ ], '... Class::MOP::Class->superclasses == [ Class::MOP::Module ]'); is_deeply( @@ -307,6 +318,9 @@ is_deeply( Class::MOP::Class Class::MOP::Module Class::MOP::Package + Class::MOP::HasMethods + Class::MOP::Object + Class::MOP::HasAttributes Class::MOP::Object / ], '... Class::MOP::Class->class_precedence_list == [ Class::MOP::Class Class::MOP::Module Class::MOP::Package ]'); @@ -315,3 +329,4 @@ is($class_mop_class_meta->attribute_metaclass, 'Class::MOP::Attribute', '... got is($class_mop_class_meta->method_metaclass, 'Class::MOP::Method', '... got the right value for method_metaclass'); is($class_mop_class_meta->instance_metaclass, 'Class::MOP::Instance', '... got the right value for instance_metaclass'); +done_testing;