X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F010_self_introspection.t;h=1ca00811d59fa507a30e3798b1cd93b3c9e8f659;hb=b7bdffc385af1765c710357109b620b93ff14eae;hp=24572a5ed6eef5465c83525fb90547a25bd4128a;hpb=be7677c7dd446a9fef66fab0f258f5c1826ecc90;p=gitmo%2FClass-MOP.git diff --git a/t/010_self_introspection.t b/t/010_self_introspection.t index 24572a5..1ca0081 100644 --- a/t/010_self_introspection.t +++ b/t/010_self_introspection.t @@ -3,14 +3,14 @@ use strict; use warnings; -use Test::More tests => 183; +use Test::More tests => 197; use Test::Exception; BEGIN { use_ok('Class::MOP'); - use_ok('Class::MOP::Class'); - use_ok('Class::MOP::Package'); - use_ok('Class::MOP::Module'); + use_ok('Class::MOP::Class'); + use_ok('Class::MOP::Package'); + use_ok('Class::MOP::Module'); } { @@ -28,64 +28,66 @@ my $class_mop_module_meta = Class::MOP::Module->meta(); isa_ok($class_mop_module_meta, 'Class::MOP::Module'); my @class_mop_package_methods = qw( - meta + meta initialize name namespace - - add_package_symbol get_package_symbol has_package_symbol remove_package_symbol + + add_package_symbol get_package_symbol has_package_symbol remove_package_symbol list_all_package_symbols remove_package_glob - + _deconstruct_variable_name ); my @class_mop_module_methods = qw( - meta + meta version authority identifier ); my @class_mop_class_methods = qw( meta - - initialize reinitialize create create_anon_class - + + initialize reinitialize create + + create_anon_class is_anon_class + instance_metaclass get_meta_instance new_object clone_object construct_instance construct_class_instance clone_instance check_metaclass_compatability - + attribute_metaclass method_metaclass - - superclasses class_precedence_list - + + superclasses class_precedence_list linearized_isa + has_method get_method add_method remove_method alias_method - get_method_list 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 + get_method_list get_method_map 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 - - is_mutable is_immutable make_immutable - + + is_mutable is_immutable make_mutable make_immutable create_immutable_transformer + DESTROY ); - -# check the class ... - + +# 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'); foreach my $method_name (@class_mop_class_methods) { ok($class_mop_class_meta->has_method($method_name), '... Class::MOP::Class->has_method(' . $method_name . ')'); { no strict 'refs'; - is($class_mop_class_meta->get_method($method_name), + is($class_mop_class_meta->get_method($method_name)->body, \&{'Class::MOP::Class::' . $method_name}, - '... Class::MOP::Class->get_method(' . $method_name . ') == &Class::MOP::Class::' . $method_name); + '... Class::MOP::Class->get_method(' . $method_name . ') == &Class::MOP::Class::' . $method_name); } } @@ -97,9 +99,9 @@ foreach my $method_name (@class_mop_package_methods) { ok($class_mop_package_meta->has_method($method_name), '... Class::MOP::Package->has_method(' . $method_name . ')'); { no strict 'refs'; - is($class_mop_package_meta->get_method($method_name), + is($class_mop_package_meta->get_method($method_name)->body, \&{'Class::MOP::Package::' . $method_name}, - '... Class::MOP::Package->get_method(' . $method_name . ') == &Class::MOP::Package::' . $method_name); + '... Class::MOP::Package->get_method(' . $method_name . ') == &Class::MOP::Package::' . $method_name); } } @@ -111,9 +113,9 @@ foreach my $method_name (@class_mop_module_methods) { ok($class_mop_module_meta->has_method($method_name), '... Class::MOP::Module->has_method(' . $method_name . ')'); { no strict 'refs'; - is($class_mop_module_meta->get_method($method_name), + is($class_mop_module_meta->get_method($method_name)->body, \&{'Class::MOP::Module::' . $method_name}, - '... Class::MOP::Module->get_method(' . $method_name . ') == &Class::MOP::Module::' . $method_name); + '... Class::MOP::Module->get_method(' . $method_name . ') == &Class::MOP::Module::' . $method_name); } } @@ -126,25 +128,28 @@ foreach my $non_method_name (qw( subname svref_2object )) { - ok(!$class_mop_class_meta->has_method($non_method_name), '... NOT Class::MOP::Class->has_method(' . $non_method_name . ')'); + ok(!$class_mop_class_meta->has_method($non_method_name), '... NOT Class::MOP::Class->has_method(' . $non_method_name . ')'); } # 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 = ( - '%:attributes', - '$:attribute_metaclass', - '$:method_metaclass', - '$:instance_metaclass' + '@!superclasses', + '%!methods', + '%!attributes', + '$!attribute_metaclass', + '$!method_metaclass', + '$!instance_metaclass' ); # check class @@ -153,15 +158,15 @@ is_deeply( [ sort @class_mop_class_attributes ], [ sort $class_mop_class_meta->get_attribute_list ], '... got the right list of attributes'); - + is_deeply( [ sort @class_mop_class_attributes ], [ sort keys %{$class_mop_class_meta->get_attribute_map} ], - '... got the right list of attributes'); + '... got the right list of attributes'); foreach my $attribute_name (@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'); + 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'); } # check module @@ -170,90 +175,90 @@ is_deeply( [ sort @class_mop_package_attributes ], [ sort $class_mop_package_meta->get_attribute_list ], '... got the right list of attributes'); - + is_deeply( [ sort @class_mop_package_attributes ], [ sort keys %{$class_mop_package_meta->get_attribute_map} ], - '... got the right list of attributes'); + '... got the right list of attributes'); foreach my $attribute_name (@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'); + 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'); } -# check package +# check package is_deeply( [ sort @class_mop_module_attributes ], [ sort $class_mop_module_meta->get_attribute_list ], '... got the right list of attributes'); - + is_deeply( [ sort @class_mop_module_attributes ], [ sort keys %{$class_mop_module_meta->get_attribute_map} ], - '... got the right list of attributes'); + '... got the right list of attributes'); foreach my $attribute_name (@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'); + 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'); } ## check the attributes themselves # ... 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 -ok($class_mop_class_meta->get_attribute('%:attributes')->has_reader, '... Class::MOP::Class %:attributes has a reader'); -is(ref($class_mop_class_meta->get_attribute('%:attributes')->reader), - 'HASH', - '... 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, - ':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'), - {}, - '... 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($class_mop_class_meta->get_attribute('$:attribute_metaclass')->reader, - '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, - ':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, - '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($class_mop_class_meta->get_attribute('$:method_metaclass')->reader, - '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('%!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, + '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'), + {}, + '... 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->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, + '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, + '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'); # check the values of some of the methods @@ -261,23 +266,23 @@ is($class_mop_class_meta->name, 'Class::MOP::Class', '... Class::MOP::Class->nam is($class_mop_class_meta->version, $Class::MOP::Class::VERSION, '... Class::MOP::Class->version'); ok($class_mop_class_meta->has_package_symbol('$VERSION'), '... Class::MOP::Class->has_package_symbol($VERSION)'); -is(${$class_mop_class_meta->get_package_symbol('$VERSION')}, - $Class::MOP::Class::VERSION, +is(${$class_mop_class_meta->get_package_symbol('$VERSION')}, + $Class::MOP::Class::VERSION, '... Class::MOP::Class->get_package_symbol($VERSION)'); is_deeply( - [ $class_mop_class_meta->superclasses ], - [ qw/Class::MOP::Module/ ], + [ $class_mop_class_meta->superclasses ], + [ qw/Class::MOP::Module/ ], '... Class::MOP::Class->superclasses == [ Class::MOP::Module ]'); - + is_deeply( - [ $class_mop_class_meta->class_precedence_list ], + [ $class_mop_class_meta->class_precedence_list ], [ qw/ Class::MOP::Class Class::MOP::Module - Class::MOP::Package - Class::MOP::Object - / ], + Class::MOP::Package + Class::MOP::Object + / ], '... Class::MOP::Class->class_precedence_list == [ Class::MOP::Class Class::MOP::Module Class::MOP::Package ]'); is($class_mop_class_meta->attribute_metaclass, 'Class::MOP::Attribute', '... got the right value for attribute_metaclass');