X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F000_load.t;h=a69ba3a13cbb50a219e5be7afe3813ee528915d3;hb=ef7d3a1dd5a8ad74b3c8a1beaad10e70b650d381;hp=61be01a501a64aaccb4061626681aea8c9029343;hpb=6e57504d833b252832d0f5306f0db97784647148;p=gitmo%2FClass-MOP.git diff --git a/t/000_load.t b/t/000_load.t index 61be01a..a69ba3a 100644 --- a/t/000_load.t +++ b/t/000_load.t @@ -1,60 +1,150 @@ -#!/usr/bin/perl - use strict; use warnings; -use Test::More tests => 16; +use Test::More tests => 42; BEGIN { use_ok('Class::MOP'); + use_ok('Class::MOP::Package'); + use_ok('Class::MOP::Module'); use_ok('Class::MOP::Class'); + use_ok('Class::MOP::Immutable'); use_ok('Class::MOP::Attribute'); - use_ok('Class::MOP::Method'); - use_ok('Class::MOP::Instance'); - use_ok('Class::MOP::Object'); + use_ok('Class::MOP::Method'); + use_ok('Class::MOP::Method::Wrapped'); + use_ok('Class::MOP::Method::Generated'); + use_ok('Class::MOP::Method::Accessor'); + use_ok('Class::MOP::Method::Constructor'); + use_ok('Class::MOP::Instance'); + use_ok('Class::MOP::Object'); } # make sure we are tracking metaclasses correctly +my @CLASS_MOP_CLASS_IMMUTABLE_CLASSES + = map { 'Class::MOP::Class::__ANON__::SERIAL::' . $_ } 1..11; + my %METAS = ( - 'Class::MOP::Attribute' => Class::MOP::Attribute->meta, - 'Class::MOP::Package' => Class::MOP::Package->meta, - 'Class::MOP::Module' => Class::MOP::Module->meta, - 'Class::MOP::Class' => Class::MOP::Class->meta, - 'Class::MOP::Method' => Class::MOP::Method->meta, - 'Class::MOP::Instance' => Class::MOP::Instance->meta, - 'Class::MOP::Object' => Class::MOP::Object->meta, + 'Class::MOP::Attribute' => Class::MOP::Attribute->meta, + 'Class::MOP::Method::Generated' => Class::MOP::Method::Generated->meta, + 'Class::MOP::Method::Accessor' => Class::MOP::Method::Accessor->meta, + 'Class::MOP::Method::Constructor' => + Class::MOP::Method::Constructor->meta, + 'Class::MOP::Package' => Class::MOP::Package->meta, + 'Class::MOP::Module' => Class::MOP::Module->meta, + 'Class::MOP::Class' => Class::MOP::Class->meta, + 'Class::MOP::Method' => Class::MOP::Method->meta, + 'Class::MOP::Method::Wrapped' => Class::MOP::Method::Wrapped->meta, + 'Class::MOP::Instance' => Class::MOP::Instance->meta, + 'Class::MOP::Object' => Class::MOP::Object->meta, ); -ok($_->is_immutable(), '... ' . $_->name . ' is immutable') for values %METAS; +ok( Class::MOP::is_class_loaded($_), '... ' . $_ . ' is loaded' ) + for keys %METAS; + +ok( $_->is_immutable(), '... ' . $_->name . ' is immutable' ) + for values %METAS; is_deeply( - { Class::MOP::Class->get_all_metaclasses }, - \%METAS, - '... got all the metaclasses'); + {Class::MOP::get_all_metaclasses}, + { + %METAS, + map { $_ => $_->meta } @CLASS_MOP_CLASS_IMMUTABLE_CLASSES + }, + '... got all the metaclasses' +); is_deeply( - [ sort { $a->name cmp $b->name } Class::MOP::Class->get_all_metaclass_instances ], - [ - Class::MOP::Attribute->meta, - Class::MOP::Class->meta, - Class::MOP::Instance->meta, + [ + sort { $a->name cmp $b->name } Class::MOP::get_all_metaclass_instances + ], + [ + Class::MOP::Attribute->meta, + Class::MOP::Class->meta, + ( map { $_->meta } sort @CLASS_MOP_CLASS_IMMUTABLE_CLASSES ), + Class::MOP::Instance->meta, Class::MOP::Method->meta, - Class::MOP::Module->meta, - Class::MOP::Object->meta, - Class::MOP::Package->meta, + Class::MOP::Method::Accessor->meta, + Class::MOP::Method::Constructor->meta, + Class::MOP::Method::Generated->meta, + Class::MOP::Method::Wrapped->meta, + Class::MOP::Module->meta, + Class::MOP::Object->meta, + Class::MOP::Package->meta, ], - '... got all the metaclass instances'); + '... got all the metaclass instances' +); is_deeply( - [ sort Class::MOP::Class->get_all_metaclass_names ], - [ qw/ - Class::MOP::Attribute - Class::MOP::Class - Class::MOP::Instance - Class::MOP::Method - Class::MOP::Module - Class::MOP::Object - Class::MOP::Package - / ], - '... got all the metaclass names'); \ No newline at end of file + [ sort { $a cmp $b } Class::MOP::get_all_metaclass_names() ], + [ + sort qw/ + Class::MOP::Attribute + Class::MOP::Class + Class::MOP::Instance + Class::MOP::Method + Class::MOP::Method::Accessor + Class::MOP::Method::Constructor + Class::MOP::Method::Generated + Class::MOP::Method::Wrapped + Class::MOP::Module + Class::MOP::Object + Class::MOP::Package + /, @CLASS_MOP_CLASS_IMMUTABLE_CLASSES + ], + '... got all the metaclass names' +); + +is_deeply( + [ + map { $_->meta->identifier } + sort { $a cmp $b } Class::MOP::get_all_metaclass_names() + ], + [ + "Class::MOP::Attribute-" + . $Class::MOP::Attribute::VERSION + . "-cpan:STEVAN", + "Class::MOP::Class-" . $Class::MOP::Class::VERSION . "-cpan:STEVAN", + ( sort @CLASS_MOP_CLASS_IMMUTABLE_CLASSES ), + "Class::MOP::Instance-" + . $Class::MOP::Instance::VERSION + . "-cpan:STEVAN", + "Class::MOP::Method-" . $Class::MOP::Method::VERSION . "-cpan:STEVAN", + "Class::MOP::Method::Accessor-" + . $Class::MOP::Method::Accessor::VERSION + . "-cpan:STEVAN", + "Class::MOP::Method::Constructor-" + . $Class::MOP::Method::Constructor::VERSION + . "-cpan:STEVAN", + "Class::MOP::Method::Generated-" + . $Class::MOP::Method::Generated::VERSION + . "-cpan:STEVAN", + "Class::MOP::Method::Wrapped-" + . $Class::MOP::Method::Wrapped::VERSION + . "-cpan:STEVAN", + "Class::MOP::Module-" . $Class::MOP::Module::VERSION . "-cpan:STEVAN", + "Class::MOP::Object-" . $Class::MOP::Object::VERSION . "-cpan:STEVAN", + "Class::MOP::Package-" + . $Class::MOP::Package::VERSION + . "-cpan:STEVAN", + ], + '... got all the metaclass identifiers' +); + +# testing the meta-circularity of the system + +is( + Class::MOP::Class->meta, Class::MOP::Class->meta->meta, + '... Class::MOP::Class->meta == Class::MOP::Class->meta->meta' +); + +is( + Class::MOP::Class->meta, Class::MOP::Class->meta->meta->meta, + '... Class::MOP::Class->meta == Class::MOP::Class->meta->meta->meta' +); + +is( + Class::MOP::Class->meta, Class::MOP::Class->meta->meta->meta->meta, + '... Class::MOP::Class->meta == Class::MOP::Class->meta->meta->meta->meta' +); +