Commit | Line | Data |
dd4e6fd2 |
1 | #!perl |
2 | |
3 | use strict; |
4 | use warnings; |
5 | |
6 | use FindBin; |
9770ad56 |
7 | use lib "$FindBin::Bin/../../../lib"; |
dd4e6fd2 |
8 | |
232fd394 |
9 | our $iters; |
10 | |
11 | BEGIN { $iters = $ENV{CAT_BENCH_ITERS} || 2; } |
12 | |
13 | use Test::More tests => 21*$iters; |
dd4e6fd2 |
14 | use Catalyst::Test 'TestApp'; |
15 | |
232fd394 |
16 | if ( $ENV{CAT_BENCHMARK} ) { |
17 | require Benchmark; |
5a6c7ff6 |
18 | Benchmark::timethis( $iters, \&run_tests ); |
232fd394 |
19 | } |
20 | else { |
21 | for ( 1 .. $iters ) { |
22 | run_tests(); |
23 | } |
24 | } |
25 | |
26 | sub run_tests { |
d8c66af5 |
27 | { |
28 | my @expected = qw[ |
29 | TestApp::Controller::Action::Inheritance->begin |
30 | TestApp::Controller::Action::Inheritance->auto |
31 | TestApp::Controller::Action::Inheritance->default |
32 | TestApp::View::Dump::Request->process |
33 | TestApp::Controller::Action::Inheritance->end |
34 | ]; |
dd4e6fd2 |
35 | |
d8c66af5 |
36 | my $expected = join( ", ", @expected ); |
dd4e6fd2 |
37 | |
d8c66af5 |
38 | ok( my $response = request('http://localhost/action/inheritance'), |
39 | 'Request' ); |
40 | ok( $response->is_success, 'Response Successful 2xx' ); |
41 | is( $response->content_type, 'text/plain', 'Response Content-Type' ); |
42 | is( $response->header('X-Catalyst-Action'), 'default', 'Test Action' ); |
43 | is( |
44 | $response->header('X-Test-Class'), |
45 | 'TestApp::Controller::Action::Inheritance', |
46 | 'Test Class' |
47 | ); |
48 | is( $response->header('X-Catalyst-Executed'), |
49 | $expected, 'Executed actions' ); |
50 | like( |
51 | $response->content, |
52 | qr/^bless\( .* 'Catalyst::Request' \)$/s, |
53 | 'Content is a serialized Catalyst::Request' |
54 | ); |
55 | } |
dd4e6fd2 |
56 | |
d8c66af5 |
57 | { |
58 | my @expected = qw[ |
59 | TestApp::Controller::Action::Inheritance::A->begin |
60 | TestApp::Controller::Action::Inheritance->auto |
61 | TestApp::Controller::Action::Inheritance::A->auto |
62 | TestApp::Controller::Action::Inheritance::A->default |
63 | TestApp::View::Dump::Request->process |
64 | TestApp::Controller::Action::Inheritance::A->end |
65 | ]; |
dd4e6fd2 |
66 | |
d8c66af5 |
67 | my $expected = join( ", ", @expected ); |
dd4e6fd2 |
68 | |
d8c66af5 |
69 | ok( my $response = request('http://localhost/action/inheritance/a'), |
70 | 'Request' ); |
71 | ok( $response->is_success, 'Response Successful 2xx' ); |
72 | is( $response->content_type, 'text/plain', 'Response Content-Type' ); |
73 | is( $response->header('X-Catalyst-Action'), 'default', 'Test Action' ); |
74 | is( |
75 | $response->header('X-Test-Class'), |
76 | 'TestApp::Controller::Action::Inheritance::A', |
77 | 'Test Class' |
78 | ); |
79 | is( $response->header('X-Catalyst-Executed'), |
80 | $expected, 'Executed actions' ); |
81 | like( |
82 | $response->content, |
83 | qr/^bless\( .* 'Catalyst::Request' \)$/s, |
84 | 'Content is a serialized Catalyst::Request' |
85 | ); |
86 | } |
dd4e6fd2 |
87 | |
d8c66af5 |
88 | { |
89 | my @expected = qw[ |
90 | TestApp::Controller::Action::Inheritance::A::B->begin |
91 | TestApp::Controller::Action::Inheritance->auto |
92 | TestApp::Controller::Action::Inheritance::A->auto |
93 | TestApp::Controller::Action::Inheritance::A::B->auto |
94 | TestApp::Controller::Action::Inheritance::A::B->default |
95 | TestApp::View::Dump::Request->process |
96 | TestApp::Controller::Action::Inheritance::A::B->end |
97 | ]; |
dd4e6fd2 |
98 | |
d8c66af5 |
99 | my $expected = join( ", ", @expected ); |
dd4e6fd2 |
100 | |
d8c66af5 |
101 | ok( my $response = request('http://localhost/action/inheritance/a/b'), |
102 | 'Request' ); |
103 | ok( $response->is_success, 'Response Successful 2xx' ); |
104 | is( $response->content_type, 'text/plain', 'Response Content-Type' ); |
105 | is( $response->header('X-Catalyst-Action'), 'default', 'Test Action' ); |
106 | is( |
107 | $response->header('X-Test-Class'), |
108 | 'TestApp::Controller::Action::Inheritance::A::B', |
109 | 'Test Class' |
110 | ); |
111 | is( $response->header('X-Catalyst-Executed'), |
112 | $expected, 'Executed actions' ); |
113 | like( |
114 | $response->content, |
115 | qr/^bless\( .* 'Catalyst::Request' \)$/s, |
116 | 'Content is a serialized Catalyst::Request' |
117 | ); |
118 | } |
dd4e6fd2 |
119 | } |