actually document the new request body_data method
[catagits/Catalyst-Runtime.git] / t / deprecated.t
1 #!/usr/bin/perl
2
3 use strict;
4 use warnings;
5 use FindBin qw/$Bin/;
6 use lib "$Bin/lib";
7 use Test::More tests => 4;
8
9 my $warnings;
10 BEGIN { # Do this at compile time in case we generate a warning when use
11         # DeprecatedTestApp
12     $SIG{__WARN__} = sub {
13         $warnings++ if $_[0] =~ /uses NEXT, which is deprecated/;
14         $warnings++ if $_[0] =~ /trying to use NEXT, which is deprecated/;
15     };
16 }
17 use Catalyst; # Cause catalyst to be used so I can fiddle with the logging.
18 my $mvc_warnings;
19 BEGIN {
20     my $logger = Class::MOP::Class->create_anon_class(
21     methods => {
22         debug => sub {0},
23         info  => sub {0},
24         warn => sub {
25             if ($_[1] =~ /switch your class names/) {
26                $mvc_warnings++;
27                 return;
28             }
29             die "Caught unexpected warning: " . $_[1];
30         },
31     },
32 )->new_object;
33     Catalyst->log($logger);
34 }
35
36 use Catalyst::Test 'DeprecatedTestApp';
37 is( $mvc_warnings, 1, 'Get the ::MVC:: warning' );
38
39 ok( my $response = request('http://localhost/'), 'Request' );
40 is( $response->header('X-Catalyst-Plugin-Deprecated'), '1', 'NEXT plugin ran correctly' );
41
42 is( $warnings, 1, 'Got one and only one Adopt::NEXT warning');