diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-06-06 17:50:16 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-06-06 17:50:16 +0000 |
commit | 5ac2026f7eed78958d69d051e7a8e993dcf51205 (patch) | |
tree | 298c3d2f08bdfe5689998b11892d72a897985be1 /t/metaclasses/metarole_on_anon.t | |
download | Moose-tarball-5ac2026f7eed78958d69d051e7a8e993dcf51205.tar.gz |
Moose-2.1405HEADMoose-2.1405master
Diffstat (limited to 't/metaclasses/metarole_on_anon.t')
-rw-r--r-- | t/metaclasses/metarole_on_anon.t | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/t/metaclasses/metarole_on_anon.t b/t/metaclasses/metarole_on_anon.t new file mode 100644 index 0000000..816e6b4 --- /dev/null +++ b/t/metaclasses/metarole_on_anon.t @@ -0,0 +1,51 @@ +use strict; +use warnings; + +use Test::More; + +use Moose (); +use Moose::Meta::Class; +use Moose::Util::MetaRole; + +{ + package Foo; + use Moose; +} + +{ + package Role::Bar; + use Moose::Role; +} + +my $anon_name; + +{ + my $anon_class = Moose::Meta::Class->create_anon_class( + superclasses => ['Foo'], + cache => 1, + ); + + $anon_name = $anon_class->name; + + ok( $anon_name->meta, 'anon class has a metaclass' ); +} + +ok( + $anon_name->meta, + 'cached anon class still has a metaclass after \$anon_class goes out of scope' +); + +Moose::Util::MetaRole::apply_metaroles( + for => $anon_name, + class_metaroles => { + class => ['Role::Bar'], + }, +); + +BAIL_OUT('Cannot continue if the anon class does not have a metaclass') + unless $anon_name->can('meta'); + +my $meta = $anon_name->meta; +ok( $meta, 'cached anon class still has a metaclass applying a metarole' ); + +done_testing; |