X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F010_self_introspection.t;h=7c0a962448feb1a968f6b9445e1d864623099efe;hb=78902d1df967dfe480294acbeb65e2e2bae4439e;hp=d321c63dcee2e2d387d00cf5b5111ae49f6efb8a;hpb=d7b2249e7fbce92cc716fea172cf338727478b78;p=gitmo%2FClass-MOP.git diff --git a/t/010_self_introspection.t b/t/010_self_introspection.t index d321c63..7c0a962 100644 --- a/t/010_self_introspection.t +++ b/t/010_self_introspection.t @@ -1,17 +1,13 @@ -#!/usr/bin/perl - use strict; use warnings; -use Test::More tests => 199; +use Test::More; use Test::Exception; -BEGIN { - use_ok('Class::MOP'); - use_ok('Class::MOP::Class'); - use_ok('Class::MOP::Package'); - use_ok('Class::MOP::Module'); -} +use Class::MOP; +use Class::MOP::Class; +use Class::MOP::Package; +use Class::MOP::Module; { my $class = Class::MOP::Class->initialize('Foo'); @@ -28,61 +24,103 @@ my $class_mop_module_meta = Class::MOP::Module->meta(); isa_ok($class_mop_module_meta, 'Class::MOP::Module'); my @class_mop_package_methods = qw( + _new - initialize + initialize reinitialize name namespace - add_package_symbol get_package_symbol has_package_symbol remove_package_symbol - list_all_package_symbols remove_package_glob + add_package_symbol get_package_symbol has_package_symbol + remove_package_symbol get_or_add_package_symbol + list_all_package_symbols get_all_package_symbols remove_package_glob + + _package_stash - _deconstruct_variable_name + get_method_map ); my @class_mop_module_methods = qw( + _new - version authority identifier + _instantiate_module + + version authority identifier create ); my @class_mop_class_methods = qw( + _new + + is_pristine initialize reinitialize create - + update_package_cache_flag reset_package_cache_flag create_anon_class is_anon_class instance_metaclass get_meta_instance + inline_create_instance + inline_rebless_instance + create_meta_instance _create_meta_instance new_object clone_object - construct_instance construct_class_instance clone_instance - rebless_instance - check_metaclass_compatability - - attribute_metaclass method_metaclass - - superclasses subclasses class_precedence_list linearized_isa - - has_method get_method add_method remove_method alias_method - get_method_list get_method_map compute_all_applicable_methods + construct_instance _construct_instance + construct_class_instance _construct_class_instance + clone_instance _clone_instance + rebless_instance rebless_instance_back rebless_instance_away + _force_rebless_instance _fixup_attributes_after_rebless + check_metaclass_compatibility _check_metaclass_compatibility + _check_class_metaclass_compatibility _check_single_metaclass_compatibility + _class_metaclass_is_compatible _single_metaclass_is_compatible + _fix_metaclass_incompatibility _fix_class_metaclass_incompatibility + _fix_single_metaclass_incompatibility _base_metaclasses + _can_fix_metaclass_incompatibility + _class_metaclass_can_be_made_compatible + _single_metaclass_can_be_made_compatible + + _remove_generated_metaobjects + _restore_metaobjects_from + + 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 + + superclasses subclasses direct_subclasses class_precedence_list + linearized_isa _superclasses_updated + + 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 compute_all_applicable_attributes find_attribute_by_name + _attach_attribute + _post_add_attribute + remove_attribute + find_attribute_by_name + get_all_attributes - is_mutable is_immutable make_mutable make_immutable create_immutable_transformer + compute_all_applicable_attributes + get_attribute_map + + 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 _real_ref_name + _rebless_as_immutable _rebless_as_mutable _remove_inlined_code + + _immutable_metaclass + immutable_trait immutable_options + constructor_name constructor_class destructor_class DESTROY ); # check the class ... -is_deeply([ sort @class_mop_class_methods ], [ sort $class_mop_class_meta->get_method_list ], '... got the correct method list for class'); +is_deeply([ sort $class_mop_class_meta->get_method_list ], [ sort @class_mop_class_methods ], '... got the correct method list for class'); -foreach my $method_name (@class_mop_class_methods) { +foreach my $method_name (sort @class_mop_class_methods) { ok($class_mop_class_meta->has_method($method_name), '... Class::MOP::Class->has_method(' . $method_name . ')'); { no strict 'refs'; @@ -94,9 +132,9 @@ foreach my $method_name (@class_mop_class_methods) { ## check the package .... -is_deeply([ sort @class_mop_package_methods ], [ sort $class_mop_package_meta->get_method_list ], '... got the correct method list for package'); +is_deeply([ sort $class_mop_package_meta->get_method_list ], [ sort @class_mop_package_methods ], '... got the correct method list for package'); -foreach my $method_name (@class_mop_package_methods) { +foreach my $method_name (sort @class_mop_package_methods) { ok($class_mop_package_meta->has_method($method_name), '... Class::MOP::Package->has_method(' . $method_name . ')'); { no strict 'refs'; @@ -108,9 +146,9 @@ foreach my $method_name (@class_mop_package_methods) { ## check the module .... -is_deeply([ sort @class_mop_module_methods ], [ sort $class_mop_module_meta->get_method_list ], '... got the correct method list for module'); +is_deeply([ sort $class_mop_module_meta->get_method_list ], [ sort @class_mop_module_methods ], '... got the correct method list for module'); -foreach my $method_name (@class_mop_module_methods) { +foreach my $method_name (sort @class_mop_module_methods) { ok($class_mop_module_meta->has_method($method_name), '... Class::MOP::Module->has_method(' . $method_name . ')'); { no strict 'refs'; @@ -125,7 +163,7 @@ foreach my $method_name (@class_mop_module_methods) { foreach my $non_method_name (qw( confess - blessed reftype + blessed subname svref_2object )) { @@ -135,37 +173,38 @@ foreach my $non_method_name (qw( # check for the right attributes my @class_mop_package_attributes = ( - '$!package', - '%!namespace', + 'package', + 'namespace', ); my @class_mop_module_attributes = ( - '$!version', - '$!authority' + 'version', + 'authority' ); my @class_mop_class_attributes = ( - '@!superclasses', - '%!methods', - '%!attributes', - '$!attribute_metaclass', - '$!method_metaclass', - '$!instance_metaclass' + 'superclasses', + 'instance_metaclass', + 'immutable_trait', + 'constructor_name', + 'constructor_class', + 'destructor_class', ); # check class is_deeply( - [ sort @class_mop_class_attributes ], [ sort $class_mop_class_meta->get_attribute_list ], - '... got the right list of attributes'); + [ sort @class_mop_class_attributes ], + '... got the right list of attributes' +); is_deeply( + [ sort keys %{$class_mop_class_meta->_attribute_map} ], [ sort @class_mop_class_attributes ], - [ sort keys %{$class_mop_class_meta->get_attribute_map} ], '... got the right list of attributes'); -foreach my $attribute_name (@class_mop_class_attributes) { +foreach my $attribute_name (sort @class_mop_class_attributes) { ok($class_mop_class_meta->has_attribute($attribute_name), '... Class::MOP::Class->has_attribute(' . $attribute_name . ')'); isa_ok($class_mop_class_meta->get_attribute($attribute_name), 'Class::MOP::Attribute'); } @@ -173,16 +212,16 @@ foreach my $attribute_name (@class_mop_class_attributes) { # check module is_deeply( - [ sort @class_mop_package_attributes ], [ sort $class_mop_package_meta->get_attribute_list ], + [ sort @class_mop_package_attributes ], '... got the right list of attributes'); is_deeply( + [ sort keys %{$class_mop_package_meta->_attribute_map} ], [ sort @class_mop_package_attributes ], - [ sort keys %{$class_mop_package_meta->get_attribute_map} ], '... got the right list of attributes'); -foreach my $attribute_name (@class_mop_package_attributes) { +foreach my $attribute_name (sort @class_mop_package_attributes) { ok($class_mop_package_meta->has_attribute($attribute_name), '... Class::MOP::Package->has_attribute(' . $attribute_name . ')'); isa_ok($class_mop_package_meta->get_attribute($attribute_name), 'Class::MOP::Attribute'); } @@ -190,16 +229,16 @@ foreach my $attribute_name (@class_mop_package_attributes) { # check package is_deeply( - [ sort @class_mop_module_attributes ], [ sort $class_mop_module_meta->get_attribute_list ], + [ sort @class_mop_module_attributes ], '... got the right list of attributes'); is_deeply( + [ sort keys %{$class_mop_module_meta->_attribute_map} ], [ sort @class_mop_module_attributes ], - [ sort keys %{$class_mop_module_meta->get_attribute_map} ], '... got the right list of attributes'); -foreach my $attribute_name (@class_mop_module_attributes) { +foreach my $attribute_name (sort @class_mop_module_attributes) { ok($class_mop_module_meta->has_attribute($attribute_name), '... Class::MOP::Module->has_attribute(' . $attribute_name . ')'); isa_ok($class_mop_module_meta->get_attribute($attribute_name), 'Class::MOP::Attribute'); } @@ -208,58 +247,75 @@ foreach my $attribute_name (@class_mop_module_attributes) { # ... package -ok($class_mop_package_meta->get_attribute('$!package')->has_reader, '... Class::MOP::Class $!package has a reader'); -is(ref($class_mop_package_meta->get_attribute('$!package')->reader), 'HASH', '... Class::MOP::Class $!package\'s a reader is { name => sub { ... } }'); +ok($class_mop_package_meta->get_attribute('package')->has_reader, '... Class::MOP::Class package has a reader'); +is(ref($class_mop_package_meta->get_attribute('package')->reader), 'HASH', '... Class::MOP::Class package\'s a reader is { name => sub { ... } }'); -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('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 +# ... class, but inherited from HasMethods +ok($class_mop_class_meta->find_attribute_by_name('method_metaclass')->has_reader, '... Class::MOP::Class method_metaclass has a reader'); +is_deeply($class_mop_class_meta->find_attribute_by_name('method_metaclass')->reader, + { 'method_metaclass' => \&Class::MOP::Mixin::HasMethods::method_metaclass }, + '... Class::MOP::Class method_metaclass\'s a reader is &method_metaclass'); -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->find_attribute_by_name('method_metaclass')->has_init_arg, '... Class::MOP::Class method_metaclass has a init_arg'); +is($class_mop_class_meta->find_attribute_by_name('method_metaclass')->init_arg, + 'method_metaclass', + '... Class::MOP::Class method_metaclass\'s init_arg is method_metaclass'); + +ok($class_mop_class_meta->find_attribute_by_name('method_metaclass')->has_default, '... Class::MOP::Class method_metaclass has a default'); +is($class_mop_class_meta->find_attribute_by_name('method_metaclass')->default, + 'Class::MOP::Method', + '... Class::MOP::Class method_metaclass\'s a default is Class::MOP:::Method'); + +ok($class_mop_class_meta->find_attribute_by_name('wrapped_method_metaclass')->has_reader, '... Class::MOP::Class wrapped_method_metaclass has a reader'); +is_deeply($class_mop_class_meta->find_attribute_by_name('wrapped_method_metaclass')->reader, + { 'wrapped_method_metaclass' => \&Class::MOP::Mixin::HasMethods::wrapped_method_metaclass }, + '... Class::MOP::Class wrapped_method_metaclass\'s a reader is &wrapped_method_metaclass'); + +ok($class_mop_class_meta->find_attribute_by_name('wrapped_method_metaclass')->has_init_arg, '... Class::MOP::Class wrapped_method_metaclass has a init_arg'); +is($class_mop_class_meta->find_attribute_by_name('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->find_attribute_by_name('method_metaclass')->has_default, '... Class::MOP::Class method_metaclass has a default'); +is($class_mop_class_meta->find_attribute_by_name('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('%!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::Mixin::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'); + '... 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 {}'); + '... 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 }, - '... Class::MOP::Class $!attribute_metaclass\'s a reader is &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'); + '... 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'); + '... Class::MOP::Class attribute_metaclass\'s a default is Class::MOP:::Attribute'); # check the values of some of the methods @@ -273,7 +329,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::Mixin::HasMethods/ ], '... Class::MOP::Class->superclasses == [ Class::MOP::Module ]'); is_deeply( @@ -283,6 +339,10 @@ is_deeply( Class::MOP::Module Class::MOP::Package Class::MOP::Object + Class::MOP::Mixin::HasAttributes + Class::MOP::Mixin + Class::MOP::Mixin::HasMethods + Class::MOP::Mixin / ], '... Class::MOP::Class->class_precedence_list == [ Class::MOP::Class Class::MOP::Module Class::MOP::Package ]'); @@ -290,3 +350,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;