Add inline_rebless_instance to metaclass
[gitmo/Class-MOP.git] / xt / author / pod_coverage.t
CommitLineData
9f32bdd8 1#!/usr/bin/perl
2
3use strict;
4use warnings;
5
6use Test::More;
7
0f352882 8use Test::Requires {
9 'Test::Pod::Coverage' => '1.04', # skip all if not installed
10};
9f32bdd8 11
12# This is a stripped down version of all_pod_coverage_ok which lets us
13# vary the trustme parameter per module.
14my @modules = all_modules();
15plan tests => scalar @modules;
16
17my %trustme = (
10c5d753 18 'Class::MOP' => [
19 'DEBUG_NO_META',
20 'HAVE_ISAREV',
21 'subname',
22 'in_global_destruction',
23 ],
9f32bdd8 24 'Class::MOP::Attribute' => ['process_accessors'],
c02d53a4 25 'Class::MOP::Class' => [
4054ae31 26 # deprecated
27 'alias_method',
2620be77 28 'compute_all_applicable_attributes',
4054ae31 29 'compute_all_applicable_methods',
30
31 # unfinished feature
32 'add_dependent_meta_instance',
33 'add_meta_instance_dependencies',
34 'invalidate_meta_instance',
35 'invalidate_meta_instances',
36 'remove_dependent_meta_instance',
37 'remove_meta_instance_dependencies',
38 'update_meta_instance_dependencies',
39
40 # effectively internal
41 'check_metaclass_compatibility',
42 'clone_instance',
43 'construct_class_instance',
44 'construct_instance',
4054ae31 45 'create_meta_instance',
4054ae31 46 'reset_package_cache_flag',
47 'update_package_cache_flag',
4054ae31 48
334d8f6e 49 # doc'd with rebless_instance
50 'rebless_instance_away',
b1aaf0dc 51
52 # deprecated
53 'get_attribute_map',
c02d53a4 54 ],
f5d1c6d0 55 'Class::MOP::Class::Immutable::Trait' => ['.+'],
56 'Class::MOP::Class::Immutable::Class::MOP::Class' => ['.+'],
b409c969 57 'Class::MOP::Deprecated' => ['.+'],
9b871d79 58 'Class::MOP::Instance' => [
fbedcfb3 59 qw( BUILDARGS
60 bless_instance_structure
61 is_dependent_on_superclasses ),
62 ],
20315887 63 'Class::MOP::Instance' => [
64 qw( BUILDARGS
65 bless_instance_structure
66 is_dependent_on_superclasses ),
67 ],
fbedcfb3 68 'Class::MOP::Method::Accessor' => [
69 qw( generate_accessor_method
70 generate_accessor_method_inline
71 generate_clearer_method
72 generate_clearer_method_inline
73 generate_predicate_method
74 generate_predicate_method_inline
75 generate_reader_method
76 generate_reader_method_inline
77 generate_writer_method
78 generate_writer_method_inline
79 initialize_body
80 )
81 ],
fbedcfb3 82 'Class::MOP::Method::Constructor' => [
83 qw( attributes
84 generate_constructor_method
85 generate_constructor_method_inline
86 initialize_body
87 meta_instance
a18e1521 88 options
fbedcfb3 89 )
90 ],
fbedcfb3 91 'Class::MOP::Method::Generated' => [
92 qw( new
93 definition_context
94 is_inline
95 initialize_body
96 )
97 ],
35cb21ab 98 'Class::MOP::MiniTrait' => ['.+'],
9b871d79 99 'Class::MOP::Mixin::AttributeCore' => ['.+'],
100 'Class::MOP::Mixin::HasAttributes' => ['.+'],
101 'Class::MOP::Mixin::HasMethods' => ['.+'],
102 'Class::MOP::Module' => ['create'],
b409c969 103 'Class::MOP::Package' => [ 'get_method_map', 'wrap_method_body' ],
9f32bdd8 104);
105
106for my $module ( sort @modules ) {
107 my $trustme = [];
108 if ( $trustme{$module} ) {
109 my $methods = join '|', @{ $trustme{$module} };
896dacc0 110 $trustme = [qr/^(?:$methods)$/];
9f32bdd8 111 }
112
113 pod_coverage_ok(
114 $module, { trustme => $trustme },
115 "Pod coverage for $module"
116 );
117}