6 use Test::More tests => 58;
14 my $attr = Class::MOP::Attribute->new('$test');
15 is($attr->meta, Class::MOP::Attribute->meta, '... instance and class both lead to the same meta');
19 my $meta = Class::MOP::Attribute->meta();
20 isa_ok($meta, 'Class::MOP::Class');
26 initialize_instance_slot
30 has_writer writer get_write_method get_write_method_ref
31 has_reader reader get_read_method get_read_method_ref
32 has_predicate predicate
36 has_default default is_default_a_coderef
37 has_initializer initializer
46 attach_to_class detach_from_class
59 [ sort $meta->get_method_list ],
61 '... our method list matches');
63 foreach my $method_name (@methods) {
64 ok($meta->has_method($method_name), '... Class::MOP::Attribute->has_method(' . $method_name . ')');
78 '@!associated_methods',
82 [ sort $meta->get_attribute_list ],
84 '... our attribute list matches');
86 foreach my $attribute_name (@attributes) {
87 ok($meta->has_attribute($attribute_name), '... Class::MOP::Attribute->has_attribute(' . $attribute_name . ')');
90 # We could add some tests here to make sure that
91 # the attribute have the appropriate
92 # accessor/reader/writer/predicate combinations,
93 # but that is getting a little excessive so I
94 # wont worry about it for now. Maybe if I get