X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F010_self_introspection.t;h=2f0f17ba5d17f06418a68284367fe5bef938df44;hb=9b871d792c4f7ec085870ab705c0ea2b615ebe2d;hp=067a264dc90dde0fcc563e7659a0e1a98adad346;hpb=3aad1e203e3bb072b423f28b991540913f98d5d4;p=gitmo%2FClass-MOP.git diff --git a/t/010_self_introspection.t b/t/010_self_introspection.t index 067a264..2f0f17b 100644 --- a/t/010_self_introspection.t +++ b/t/010_self_introspection.t @@ -34,13 +34,6 @@ 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 @@ -79,8 +72,6 @@ my @class_mop_class_methods = qw( add_dependent_meta_instance remove_dependent_meta_instance invalidate_meta_instances invalidate_meta_instance - attribute_metaclass - superclasses subclasses direct_subclasses class_precedence_list linearized_isa _superclasses_updated @@ -89,9 +80,13 @@ my @class_mop_class_methods = qw( add_before_method_modifier add_after_method_modifier add_around_method_modifier - has_attribute get_attribute add_attribute remove_attribute - get_attribute_list _attribute_map get_all_attributes compute_all_applicable_attributes find_attribute_by_name + _attach_attribute + _post_add_attribute + remove_attribute + find_attribute_by_name + get_all_attributes + compute_all_applicable_attributes get_attribute_map is_mutable is_immutable make_mutable make_immutable @@ -166,9 +161,6 @@ foreach my $non_method_name (qw( my @class_mop_package_attributes = ( 'package', 'namespace', - 'method_metaclass', - 'wrapped_method_metaclass', - '_methods', ); my @class_mop_module_attributes = ( @@ -178,8 +170,6 @@ my @class_mop_module_attributes = ( my @class_mop_class_attributes = ( 'superclasses', - 'attributes', - 'attribute_metaclass', 'instance_metaclass', 'immutable_trait', 'constructor_name', @@ -249,66 +239,67 @@ 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 }, +# ... 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::Mixin::HasMethods::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, +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->get_attribute('method_metaclass')->has_default, '... Class::MOP::Package method_metaclass has a default'); -is($class_mop_package_meta->get_attribute('method_metaclass')->default, +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->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 }, +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::Mixin::HasMethods::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, +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->get_attribute('method_metaclass')->has_default, '... Class::MOP::Package method_metaclass has a default'); -is($class_mop_package_meta->get_attribute('method_metaclass')->default, +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'); -# ... class +# ... class, but inherited from HasAttributes -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, - { '_attribute_map' => \&Class::MOP::Class::_attribute_map }, +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::Mixin::HasAttributes::_attribute_map }, '... Class::MOP::Class attributes\'s a reader is &_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, +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::Mixin::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'); @@ -324,7 +315,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::Mixin::HasAttributes/ ], '... Class::MOP::Class->superclasses == [ Class::MOP::Module ]'); is_deeply( @@ -334,6 +325,10 @@ is_deeply( Class::MOP::Module Class::MOP::Package Class::MOP::Object + Class::MOP::Mixin::HasMethods + Class::MOP::Mixin + Class::MOP::Mixin::HasAttributes + Class::MOP::Mixin / ], '... Class::MOP::Class->class_precedence_list == [ Class::MOP::Class Class::MOP::Module Class::MOP::Package ]');