Commit | Line | Data |
fc7ec1d9 |
1 | package Catalyst::Test; |
2 | |
3 | use strict; |
4 | use UNIVERSAL::require; |
fc7ec1d9 |
5 | |
e05c5e3c |
6 | $ENV{CATALYST_ENGINE} = 'Test'; |
fc7ec1d9 |
7 | |
8 | =head1 NAME |
9 | |
10 | Catalyst::Test - Test Catalyst applications |
11 | |
12 | =head1 SYNOPSIS |
13 | |
49faa307 |
14 | # Helper |
49faa307 |
15 | script/test.pl |
16 | |
fc7ec1d9 |
17 | # Tests |
18 | use Catalyst::Test 'TestApp'; |
19 | request('index.html'); |
20 | get('index.html'); |
21 | |
45374ac6 |
22 | # Run tests against a remote server |
d96e14c2 |
23 | CATALYST_SERVER='http://localhost:3000/' prove -l lib/ t/ |
45374ac6 |
24 | |
b6898a9f |
25 | # Tests with inline apps need to use Catalyst::Engine::Test |
26 | package TestApp; |
27 | |
28 | use Catalyst qw[-Engine=Test]; |
29 | |
30 | __PACKAGE__->action( |
31 | foo => sub { |
32 | my ( $self, $c ) = @_; |
33 | $c->res->output('bar'); |
34 | } |
35 | ); |
36 | |
37 | package main; |
38 | |
39 | use Test::More tests => 1; |
40 | use Catalyst::Test 'TestApp'; |
41 | |
42 | ok( get('/foo') =~ /bar/ ); |
43 | |
fc7ec1d9 |
44 | =head1 DESCRIPTION |
45 | |
46 | Test Catalyst applications. |
47 | |
48 | =head2 METHODS |
49 | |
bea4160a |
50 | =over 4 |
51 | |
52 | =item get |
fc7ec1d9 |
53 | |
54 | Returns the content. |
55 | |
56 | my $content = get('foo/bar?test=1'); |
57 | |
bea4160a |
58 | =item request |
fc7ec1d9 |
59 | |
60 | Returns a C<HTTP::Response> object. |
61 | |
62 | my $res =request('foo/bar?test=1'); |
63 | |
64 | =cut |
65 | |
fc7ec1d9 |
66 | sub import { |
66d9e175 |
67 | my $self = shift; |
45374ac6 |
68 | my $class = shift; |
69 | |
70 | my ( $get, $request ); |
71 | |
d96e14c2 |
72 | if ( $ENV{CATALYST_SERVER} ) { |
45374ac6 |
73 | $request = sub { remote_request(@_) }; |
74 | $get = sub { remote_request(@_)->content }; |
75 | } |
76 | |
77 | else { |
bc024080 |
78 | $class->require; |
9ffadf88 |
79 | my $error = $UNIVERSAL::require::ERROR; |
aa777f56 |
80 | die qq/Couldn't load "$class", "$error"/ if $@; |
e646f111 |
81 | |
d96e14c2 |
82 | $class->import; |
83 | |
45374ac6 |
84 | $request = sub { $class->run(@_) }; |
85 | $get = sub { $class->run(@_)->content }; |
49faa307 |
86 | } |
45374ac6 |
87 | |
88 | no strict 'refs'; |
89 | my $caller = caller(0); |
90 | *{"$caller\::request"} = $request; |
91 | *{"$caller\::get"} = $get; |
92 | } |
93 | |
523d44ec |
94 | my $agent; |
95 | |
bea4160a |
96 | =item remote_request |
97 | |
98 | Do an actual remote rquest using LWP. |
99 | |
100 | =cut |
101 | |
45374ac6 |
102 | sub remote_request { |
103 | my $request = shift; |
104 | |
105 | require LWP::UserAgent; |
106 | |
45374ac6 |
107 | unless ( ref $request ) { |
108 | |
9ffadf88 |
109 | my $uri = |
110 | ( $request =~ m/http/i ) |
45374ac6 |
111 | ? URI->new($request) |
112 | : URI->new( 'http://localhost' . $request ); |
113 | |
114 | $request = $uri->canonical; |
115 | } |
116 | |
45374ac6 |
117 | unless ( ref $request eq 'HTTP::Request' ) { |
118 | $request = HTTP::Request->new( 'GET', $request ); |
119 | } |
120 | |
523d44ec |
121 | my $server = URI->new( $ENV{CATALYST_SERVER} ); |
122 | |
123 | if ( $server->path =~ m|^(.+)?/$| ) { |
9ffadf88 |
124 | $server->path("$1"); # need to be quoted |
523d44ec |
125 | } |
126 | |
127 | $request->uri->scheme( $server->scheme ); |
128 | $request->uri->host( $server->host ); |
129 | $request->uri->port( $server->port ); |
130 | $request->uri->path( $server->path . $request->uri->path ); |
131 | |
132 | unless ($agent) { |
133 | $agent = LWP::UserAgent->new( |
9ffadf88 |
134 | |
135 | # cookie_jar => {}, |
523d44ec |
136 | keep_alive => 1, |
137 | max_redirect => 0, |
138 | timeout => 60, |
139 | ); |
140 | $agent->env_proxy; |
141 | } |
45374ac6 |
142 | |
143 | return $agent->request($request); |
fc7ec1d9 |
144 | } |
145 | |
bea4160a |
146 | =back |
147 | |
fc7ec1d9 |
148 | =head1 SEE ALSO |
149 | |
150 | L<Catalyst>. |
151 | |
152 | =head1 AUTHOR |
153 | |
154 | Sebastian Riedel, C<sri@cpan.org> |
155 | |
156 | =head1 COPYRIGHT |
157 | |
158 | This program is free software, you can redistribute it and/or modify it under |
159 | the same terms as Perl itself. |
160 | |
161 | =cut |
162 | |
163 | 1; |