X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F001_basic.t;h=a32333d79f71d6d81685659bfe2c65f101d97365;hb=52e5f955631bd1734feae3659100757b7925cbb7;hp=ce622a8a79d3b7f09cb7e3ca4bcbcacae5d97043;hpb=0882828ed7321340730125b1b2ccdd2f6fb122a5;p=gitmo%2FClass-MOP.git diff --git a/t/001_basic.t b/t/001_basic.t index ce622a8..a32333d 100644 --- a/t/001_basic.t +++ b/t/001_basic.t @@ -3,26 +3,27 @@ use strict; use warnings; -use Test::More no_plan => 1; +use Test::More tests => 23; use Test::Exception; -BEGIN { - use_ok('Class::MOP'); - use_ok('Class::MOP::Class'); -} +use Class::MOP; +use Class::MOP::Class; { package Foo; + use metaclass; our $VERSION = '0.01'; package Bar; our @ISA = ('Foo'); + + our $AUTHORITY = 'cpan:JRANDOM'; } -my $Foo = Foo->meta(); +my $Foo = Foo->meta; isa_ok($Foo, 'Class::MOP::Class'); -my $Bar = Bar->meta(); +my $Bar = Bar->meta; isa_ok($Bar, 'Class::MOP::Class'); is($Foo->name, 'Foo', '... Foo->name == Foo'); @@ -31,6 +32,12 @@ is($Bar->name, 'Bar', '... Bar->name == Bar'); is($Foo->version, '0.01', '... Foo->version == 0.01'); is($Bar->version, undef, '... Bar->version == undef'); +is($Foo->authority, undef, '... Foo->authority == undef'); +is($Bar->authority, 'cpan:JRANDOM', '... Bar->authority == cpan:JRANDOM'); + +is($Foo->identifier, 'Foo-0.01', '... Foo->identifier == Foo-0.01'); +is($Bar->identifier, 'Bar-cpan:JRANDOM', '... Bar->identifier == Bar-cpan:JRANDOM'); + is_deeply([$Foo->superclasses], [], '... Foo has no superclasses'); is_deeply([$Bar->superclasses], ['Foo'], '... Bar->superclasses == (Foo)'); @@ -51,7 +58,9 @@ is_deeply( # create a class using Class::MOP::Class ... my $Baz = Class::MOP::Class->create( - 'Baz' => '0.10' => ( + 'Baz' => ( + version => '0.10', + authority => 'cpan:YOMAMA', superclasses => [ 'Bar' ] )); isa_ok($Baz, 'Class::MOP::Class'); @@ -59,6 +68,9 @@ is(Baz->meta, $Baz, '... our metaclasses are singletons'); is($Baz->name, 'Baz', '... Baz->name == Baz'); is($Baz->version, '0.10', '... Baz->version == 0.10'); +is($Baz->authority, 'cpan:YOMAMA', '... Baz->authority == YOMAMA'); + +is($Baz->identifier, 'Baz-0.10-cpan:YOMAMA', '... Baz->identifier == Baz-0.10-cpan:YOMAMA'); is_deeply([$Baz->superclasses], ['Bar'], '... Baz->superclasses == (Bar)'); @@ -66,3 +78,4 @@ is_deeply( [ $Baz->class_precedence_list ], [ 'Baz', 'Bar', 'Foo', 'UNIVERSAL' ], '... Baz->class_precedence_list == (Baz, Bar, Foo, UNIVERSAL)'); +