11 This test demonstrates the ability to extend
12 Moose meta-level classes using Moose itself.
17 package My::Meta::Class;
20 extends 'Moose::Meta::Class';
22 around 'create_anon_class' => sub {
24 my ($self, %options) = @_;
25 $options{superclasses} = [ 'Moose::Object' ]
26 unless exists $options{superclasses};
27 $next->($self, %options);
31 my $anon = My::Meta::Class->create_anon_class();
32 isa_ok($anon, 'My::Meta::Class');
33 isa_ok($anon, 'Moose::Meta::Class');
34 isa_ok($anon, 'Class::MOP::Class');
37 [ $anon->superclasses ],
39 '... got the default superclasses');
42 package My::Meta::Attribute::DefaultReadOnly;
45 extends 'Moose::Meta::Attribute';
49 my ($self, $name, %options) = @_;
51 unless exists $options{is};
52 $next->($self, $name, %options);
57 my $attr = My::Meta::Attribute::DefaultReadOnly->new('foo');
58 isa_ok($attr, 'My::Meta::Attribute::DefaultReadOnly');
59 isa_ok($attr, 'Moose::Meta::Attribute');
60 isa_ok($attr, 'Class::MOP::Attribute');
62 ok($attr->has_reader, '... the attribute has a reader (as expected)');
63 ok(!$attr->has_writer, '... the attribute does not have a writer (as expected)');
64 ok(!$attr->has_accessor, '... the attribute does not have an accessor (as expected)');
68 my $attr = My::Meta::Attribute::DefaultReadOnly->new('foo', (is => 'rw'));
69 isa_ok($attr, 'My::Meta::Attribute::DefaultReadOnly');
70 isa_ok($attr, 'Moose::Meta::Attribute');
71 isa_ok($attr, 'Class::MOP::Attribute');
73 ok(!$attr->has_reader, '... the attribute does not have a reader (as expected)');
74 ok(!$attr->has_writer, '... the attribute does not have a writer (as expected)');
75 ok($attr->has_accessor, '... the attribute does have an accessor (as expected)');