Commit | Line | Data |
dc4fc8c7 |
1 | use strict; |
2 | use warnings; |
3 | |
4 | use Test::Exception; |
5 | use Test::More; |
2542cb3d |
6 | |
7 | use Test::Requires { |
8 | 'Test::Warn' => '0.21', |
9 | }; |
dc4fc8c7 |
10 | |
11 | { |
12 | throws_ok { |
13 | eval 'package Foo; use Package::DeprecationManager;'; |
14 | die $@ if $@; |
15 | } |
16 | qr/^\QYou must provide a hash reference -deprecations parameter when importing Package::DeprecationManager/, |
17 | 'must provide a set of deprecations when using Package::DeprecationManager'; |
18 | } |
19 | |
20 | { |
21 | package Foo; |
22 | |
23 | use Package::DeprecationManager -deprecations => { |
bce3492c |
24 | 'Foo::foo' => '0.02', |
25 | 'Foo::bar' => '0.03', |
26 | 'Foo::baz' => '1.21', |
27 | 'not a sub' => '1.23', |
dc4fc8c7 |
28 | }; |
29 | |
30 | sub foo { |
31 | deprecated('foo is deprecated'); |
32 | } |
33 | |
34 | sub bar { |
35 | deprecated('bar is deprecated'); |
36 | } |
37 | |
38 | sub baz { |
39 | deprecated(); |
40 | } |
bce3492c |
41 | |
42 | sub quux { |
43 | if ( $_[0] > 5 ) { |
44 | deprecated( |
45 | message => 'quux > 5 has been deprecated', |
46 | feature => 'not a sub', |
47 | ); |
48 | } |
49 | } |
c9ed2327 |
50 | |
51 | sub varies { |
52 | deprecated("The varies sub varies: $_[0]"); |
53 | } |
54 | |
dc4fc8c7 |
55 | } |
56 | |
57 | { |
58 | package Bar; |
59 | |
60 | Foo->import(); |
61 | |
62 | ::warning_is{ Foo::foo() } |
63 | { carped => 'foo is deprecated' }, |
64 | 'deprecation warning for foo'; |
65 | |
66 | ::warning_is{ Foo::bar() } |
67 | { carped => 'bar is deprecated' }, |
68 | 'deprecation warning for bar'; |
69 | |
70 | ::warning_is{ Foo::baz() } |
71 | { carped => 'Foo::baz has been deprecated since version 1.21' }, |
72 | 'deprecation warning for baz, and message is generated by Package::DeprecationManager'; |
73 | |
74 | ::warning_is{ Foo::foo() } q{}, 'no warning on second call to foo'; |
75 | |
76 | ::warning_is{ Foo::bar() } q{}, 'no warning on second call to bar'; |
77 | |
78 | ::warning_is{ Foo::baz() } q{}, 'no warning on second call to baz'; |
c9ed2327 |
79 | |
80 | ::warning_is{ Foo::varies(1) } |
81 | { carped => "The varies sub varies: 1" }, |
82 | 'warning for varies sub'; |
83 | |
84 | ::warning_is{ Foo::varies(2) } |
85 | { carped => "The varies sub varies: 2" }, |
86 | 'warning for varies sub with different error'; |
87 | |
88 | ::warning_is{ Foo::varies(1) } |
89 | q{}, |
90 | 'no warning for varies sub with same message as first call'; |
dc4fc8c7 |
91 | } |
92 | |
93 | { |
94 | package Baz; |
95 | |
96 | Foo->import( -api_version => '0.01' ); |
97 | |
98 | ::warning_is{ Foo::foo() } |
99 | q{}, |
100 | 'no warning for foo with api_version = 0.01'; |
101 | |
102 | ::warning_is{ Foo::bar() } |
103 | q{}, |
104 | 'no warning for bar with api_version = 0.01'; |
105 | |
106 | ::warning_is{ Foo::baz() } |
107 | q{}, |
108 | 'no warning for baz with api_version = 0.01'; |
109 | } |
110 | |
dc4fc8c7 |
111 | { |
112 | package Quux; |
113 | |
114 | Foo->import( -api_version => '1.17' ); |
115 | |
116 | ::warning_is{ Foo::foo() } |
117 | { carped => 'foo is deprecated' }, |
118 | 'deprecation warning for foo with api_version = 1.17'; |
119 | |
120 | ::warning_is{ Foo::bar() } |
121 | { carped => 'bar is deprecated' }, |
122 | 'deprecation warning for bar with api_version = 1.17'; |
123 | |
124 | ::warning_is{ Foo::baz() } |
125 | q{}, |
126 | 'no warning for baz with api_version = 1.17'; |
127 | } |
128 | |
bce3492c |
129 | { |
130 | package Another; |
131 | |
132 | Foo->import(); |
133 | |
134 | ::warning_is{ Foo::quux(1) } |
135 | q{}, |
136 | 'no warning for quux(1)'; |
137 | |
138 | ::warning_is{ Foo::quux(10) } |
139 | { carped => 'quux > 5 has been deprecated' }, |
140 | 'got a warning for quux(10)'; |
141 | } |
142 | |
d26afdef |
143 | |
144 | { |
145 | package Dep; |
146 | |
147 | use Package::DeprecationManager -deprecations => { |
148 | 'foo' => '1.00', |
149 | }, |
37bcd4f7 |
150 | -ignore => [ 'My::Package1', 'My::Package2' ]; |
d26afdef |
151 | |
152 | sub foo { |
153 | deprecated('foo is deprecated'); |
154 | } |
155 | } |
156 | |
157 | { |
37bcd4f7 |
158 | package Dep2; |
159 | |
160 | use Package::DeprecationManager -deprecations => { |
161 | 'bar' => '1.00', |
162 | }, |
163 | -ignore => [ 'My::Package2' ]; |
164 | |
165 | sub bar { |
166 | deprecated('bar is deprecated'); |
167 | } |
168 | } |
169 | |
170 | { |
e546f61d |
171 | package Dep3; |
172 | |
173 | use Package::DeprecationManager -deprecations => { |
174 | 'baz' => '1.00', |
175 | }, |
176 | -ignore => [ qr/My::Package[12]/ ]; |
177 | |
178 | sub baz { |
179 | deprecated('baz is deprecated'); |
180 | } |
181 | } |
182 | |
183 | { |
37bcd4f7 |
184 | package My::Package1; |
d26afdef |
185 | |
186 | sub foo { Dep::foo() } |
37bcd4f7 |
187 | sub bar { Dep2::bar() } |
e546f61d |
188 | sub baz { Dep3::baz() } |
d26afdef |
189 | } |
190 | |
191 | { |
37bcd4f7 |
192 | package My::Package2; |
d26afdef |
193 | |
37bcd4f7 |
194 | sub foo { My::Package1::foo() } |
195 | sub bar { My::Package1::bar() } |
e546f61d |
196 | sub baz { My::Package1::baz() } |
d26afdef |
197 | } |
198 | |
199 | { |
200 | package My::Baz; |
201 | |
e546f61d |
202 | ::warning_like{ My::Package1::bar() } |
203 | qr/^bar is deprecated at t.basic\.t line \d+/, |
204 | 'deprecation warning for call to My::Package1::bar()'; |
205 | |
37bcd4f7 |
206 | ::warning_like{ My::Package2::foo() } |
d26afdef |
207 | qr/^foo is deprecated at t.basic\.t line \d+/, |
37bcd4f7 |
208 | 'deprecation warning for call to My::Package2::foo()'; |
209 | |
e546f61d |
210 | ::warning_like{ My::Package1::baz() } |
211 | qr/^baz is deprecated at t.basic\.t line \d+/, |
212 | 'deprecation warning for call to My::Package2::foo()'; |
d26afdef |
213 | } |
214 | |
215 | { |
216 | package My::Baz; |
217 | |
218 | Dep->import( -api_version => '0.8' ); |
219 | |
37bcd4f7 |
220 | ::warning_is{ My::Package2::foo() } |
d26afdef |
221 | q{}, |
37bcd4f7 |
222 | 'no warning when calling My::Package2::foo()'; |
d26afdef |
223 | } |
224 | |
dc4fc8c7 |
225 | done_testing(); |