X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F010_self_introspection.t;h=04efa2de01cf031ee03d4882b84f3e2d638e53f0;hb=939ec2879f2eef695c063d980c47ecf5c6437481;hp=c81cb01030111a889f967531cfbcaedb23a19026;hpb=0708313d80515eebcc37dd2cfa6537ca3971c827;p=gitmo%2FClass-MOP.git diff --git a/t/010_self_introspection.t b/t/010_self_introspection.t index c81cb01..04efa2d 100644 --- a/t/010_self_introspection.t +++ b/t/010_self_introspection.t @@ -2,7 +2,7 @@ use strict; use warnings; use Test::More; -use Test::Exception; +use Test::Fatal; use Class::MOP; use Class::MOP::Class; @@ -31,10 +31,11 @@ my @class_mop_package_methods = qw( 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 get_or_add_package_symbol list_all_package_symbols get_all_package_symbols remove_package_glob - _deconstruct_variable_name + _package_stash get_method_map ); @@ -52,28 +53,43 @@ my @class_mop_class_methods = qw( is_pristine - initialize create - - update_package_cache_flag - reset_package_cache_flag + initialize reinitialize create create_anon_class is_anon_class instance_metaclass get_meta_instance + _inline_create_instance + _inline_rebless_instance + _inline_get_mop_slot _inline_set_mop_slot _inline_clear_mop_slot create_meta_instance _create_meta_instance new_object clone_object + _inline_new_object _inline_default_value _inline_preserve_weak_metaclasses + _inline_slot_initializer _inline_extra_init _inline_fallback_constructor + _inline_generate_instance _inline_params _inline_slot_initializers + _generate_fallback_constructor 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 + linearized_isa _superclasses_updated _superclass_metas 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 @@ -92,8 +108,8 @@ my @class_mop_class_methods = qw( 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 + _inline_destructor _immutable_options _real_ref_name + _rebless_as_immutable _rebless_as_mutable _remove_inlined_code _immutable_metaclass immutable_trait immutable_options @@ -239,36 +255,36 @@ 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'); -# ... 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, +# ... 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::Package method_metaclass\'s a reader is &method_metaclass'); + '... Class::MOP::Class 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, +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::Package method_metaclass\'s init_arg is method_metaclass'); + '... Class::MOP::Class 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, +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::Package method_metaclass\'s a default is Class::MOP:::Method'); + '... Class::MOP::Class 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, +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::Package wrapped_method_metaclass\'s a reader is &wrapped_method_metaclass'); + '... Class::MOP::Class 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, +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::Package wrapped_method_metaclass\'s init_arg is wrapped_method_metaclass'); + '... Class::MOP::Class 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, +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::Package method_metaclass\'s a default is Class::MOP:::Method'); + '... Class::MOP::Class method_metaclass\'s a default is Class::MOP:::Method'); # ... class, but inherited from HasAttributes @@ -315,7 +331,7 @@ is(${$class_mop_class_meta->get_package_symbol('$VERSION')}, is_deeply( [ $class_mop_class_meta->superclasses ], - [ qw/Class::MOP::Module Class::MOP::Mixin::HasAttributes/ ], + [ qw/Class::MOP::Module Class::MOP::Mixin::HasAttributes Class::MOP::Mixin::HasMethods/ ], '... Class::MOP::Class->superclasses == [ Class::MOP::Module ]'); is_deeply( @@ -325,10 +341,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::Mixin::HasMethods + Class::MOP::Mixin / ], '... Class::MOP::Class->class_precedence_list == [ Class::MOP::Class Class::MOP::Module Class::MOP::Package ]');