Merge branch 'stable'
[gitmo/Class-MOP.git] / t / 000_load.t
index 75c293a..f6b3ec4 100644 (file)
@@ -1,21 +1,26 @@
 use strict;
 use warnings;
 
-use Test::More tests => 49;
+use Test::More;
 
 BEGIN {
     use_ok('Class::MOP');
+    use_ok('Class::MOP::Mixin');
+    use_ok('Class::MOP::Mixin::AttributeCore');
+    use_ok('Class::MOP::Mixin::HasAttributes');
+    use_ok('Class::MOP::Mixin::HasMethods');
     use_ok('Class::MOP::Package');
     use_ok('Class::MOP::Module');
     use_ok('Class::MOP::Class');
     use_ok('Class::MOP::Class::Immutable::Trait');
-    use_ok('Class::MOP::Attribute');
+    use_ok('Class::MOP::Method');
     use_ok('Class::MOP::Method');
     use_ok('Class::MOP::Method::Wrapped');
     use_ok('Class::MOP::Method::Inlined');
     use_ok('Class::MOP::Method::Generated');
     use_ok('Class::MOP::Method::Accessor');
     use_ok('Class::MOP::Method::Constructor');
+    use_ok('Class::MOP::Method::Meta');
     use_ok('Class::MOP::Instance');
     use_ok('Class::MOP::Object');
 }
@@ -27,8 +32,12 @@ my %METAS = (
     'Class::MOP::Method::Inlined' => Class::MOP::Method::Inlined->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::Method::Constructor' => Class::MOP::Method::Constructor->meta,
+    'Class::MOP::Method::Meta' => Class::MOP::Method::Meta->meta,
+    'Class::MOP::Mixin'   => Class::MOP::Mixin->meta,
+    'Class::MOP::Mixin::AttributeCore'   => Class::MOP::Mixin::AttributeCore->meta,
+    'Class::MOP::Mixin::HasAttributes'   => Class::MOP::Mixin::HasAttributes->meta,
+    'Class::MOP::Mixin::HasMethods'      => Class::MOP::Mixin::HasMethods->meta,
     'Class::MOP::Package'         => Class::MOP::Package->meta,
     'Class::MOP::Module'          => Class::MOP::Module->meta,
     'Class::MOP::Class'           => Class::MOP::Class->meta,
@@ -36,15 +45,24 @@ my %METAS = (
     'Class::MOP::Method::Wrapped' => Class::MOP::Method::Wrapped->meta,
     'Class::MOP::Instance'        => Class::MOP::Instance->meta,
     'Class::MOP::Object'          => Class::MOP::Object->meta,
-    'Class::MOP::Class::Immutable::Trait' => Class::MOP::Class::Immutable::Trait->meta,
+    'Class::MOP::Class::Immutable::Trait' => Class::MOP::class_of('Class::MOP::Class::Immutable::Trait'),
     'Class::MOP::Class::Immutable::Class::MOP::Class' => Class::MOP::Class::Immutable::Class::MOP::Class->meta,
 );
 
 ok( Class::MOP::is_class_loaded($_), '... ' . $_ . ' is loaded' )
     for keys %METAS;
 
-ok( $_->is_immutable(), '... ' . $_->name . ' is immutable' )
-    for values %METAS;
+for my $meta (values %METAS) {
+    # the trait shouldn't be made immutable, it doesn't actually do anything,
+    # and it doesn't even matter because it's not a class that will be
+    # instantiated
+    if ($meta->name eq 'Class::MOP::Class::Immutable::Trait') {
+        ok( $meta->is_mutable(), '... ' . $meta->name . ' is mutable' );
+    }
+    else {
+        ok( $meta->is_immutable(), '... ' . $meta->name . ' is immutable' );
+    }
+}
 
 is_deeply(
     {Class::MOP::get_all_metaclasses},
@@ -60,14 +78,19 @@ is_deeply(
         Class::MOP::Attribute->meta,
         Class::MOP::Class->meta,
         Class::MOP::Class::Immutable::Class::MOP::Class->meta,
-        Class::MOP::Class::Immutable::Trait->meta,
+        Class::MOP::class_of('Class::MOP::Class::Immutable::Trait'),
         Class::MOP::Instance->meta,
         Class::MOP::Method->meta,
         Class::MOP::Method::Accessor->meta,
         Class::MOP::Method::Constructor->meta,
         Class::MOP::Method::Generated->meta,
         Class::MOP::Method::Inlined->meta,
+        Class::MOP::Method::Meta->meta,
         Class::MOP::Method::Wrapped->meta,
+        Class::MOP::Mixin->meta,
+        Class::MOP::Mixin::AttributeCore->meta,
+        Class::MOP::Mixin::HasAttributes->meta,
+        Class::MOP::Mixin::HasMethods->meta,
         Class::MOP::Module->meta,
         Class::MOP::Object->meta,
         Class::MOP::Package->meta,
@@ -83,6 +106,10 @@ is_deeply(
             Class::MOP::Class
             Class::MOP::Class::Immutable::Class::MOP::Class
             Class::MOP::Class::Immutable::Trait
+            Class::MOP::Mixin
+            Class::MOP::Mixin::AttributeCore
+            Class::MOP::Mixin::HasAttributes
+            Class::MOP::Mixin::HasMethods
             Class::MOP::Instance
             Class::MOP::Method
             Class::MOP::Method::Accessor
@@ -90,6 +117,7 @@ is_deeply(
             Class::MOP::Method::Generated
             Class::MOP::Method::Inlined
             Class::MOP::Method::Wrapped
+            Class::MOP::Method::Meta
             Class::MOP::Module
             Class::MOP::Object
             Class::MOP::Package
@@ -101,22 +129,25 @@ is_deeply(
 # 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'
+    Class::MOP::Class->meta->meta, Class::MOP::Class->meta->meta->meta,
+    '... Class::MOP::Class->meta->meta == Class::MOP::Class->meta->meta->meta'
 );
 
 is(
-    Class::MOP::Class->meta->meta, Class::MOP::Class->meta->meta->meta,
-    '... Class::MOP::Class->meta->meta == Class::MOP::Class->meta->meta->meta'
+    Class::MOP::Class->meta->meta->meta, Class::MOP::Class->meta->meta->meta->meta,
+    '... Class::MOP::Class->meta->meta->meta == Class::MOP::Class->meta->meta->meta->meta'
 );
 
 is(
-    Class::MOP::Class->meta, Class::MOP::Class->meta->meta->meta,
-    '... Class::MOP::Class->meta == Class::MOP::Class->meta->meta->meta'
+    Class::MOP::Class->meta->meta, Class::MOP::Class->meta->meta->meta->meta,
+    '... Class::MOP::Class->meta->meta == Class::MOP::Class->meta->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'
+    Class::MOP::Class->meta->meta, Class::MOP::Class->meta->meta->meta->meta->meta,
+    '... Class::MOP::Class->meta->meta == Class::MOP::Class->meta->meta->meta->meta->meta'
 );
 
+isa_ok(Class::MOP::Class->meta, 'Class::MOP::Class');
+
+done_testing;