use strict;
use warnings;
-use Test::More tests => 169;
+use Test::More tests => 191;
use Test::Exception;
BEGIN {
initialize
name
+ namespace
- add_package_variable get_package_variable has_package_variable remove_package_variable
+ 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
- version
+ version authority identifier
);
my @class_mop_class_methods = qw(
meta
- get_all_metaclasses get_all_metaclass_names get_all_metaclass_instances
+ initialize reinitialize create
- initialize reinitialize create create_anon_class
+ create_anon_class is_anon_class
instance_metaclass get_meta_instance
new_object clone_object
superclasses class_precedence_list
has_method get_method add_method remove_method alias_method
- get_method_list compute_all_applicable_methods
- find_all_methods_by_name find_next_method_by_name
+ 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
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);
}
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);
}
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);
}
# check for the right attributes
my @class_mop_package_attributes = (
- '$:package',
+ '$!package',
+ '%!namespace',
);
my @class_mop_module_attributes = (
+ '$!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
# ... 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_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_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,
+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 {}');
+ '... 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_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_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,
+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');
+ '... 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_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_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,
+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 $!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');
is($class_mop_class_meta->version, $Class::MOP::Class::VERSION, '... Class::MOP::Class->version');
-ok($class_mop_class_meta->has_package_variable('$VERSION'), '... Class::MOP::Class->has_package_variable($VERSION)');
-is(${$class_mop_class_meta->get_package_variable('$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,
- '... Class::MOP::Class->get_package_variable($VERSION)');
+ '... Class::MOP::Class->get_package_symbol($VERSION)');
is_deeply(
[ $class_mop_class_meta->superclasses ],
[ qw/
Class::MOP::Class
Class::MOP::Module
- Class::MOP::Package
+ Class::MOP::Package
+ Class::MOP::Object
/ ],
'... Class::MOP::Class->class_precedence_list == [ Class::MOP::Class Class::MOP::Module Class::MOP::Package ]');