package Catalyst::Engine::Test;
use strict;
-use base 'Catalyst::Engine::HTTP';
+use base 'Catalyst::Engine::CGI';
+use Catalyst::Utils;
+use HTTP::Response;
+use HTTP::Status;
+use NEXT;
=head1 NAME
=head1 OVERLOADED METHODS
-This class overloads some methods from C<Catalyst::Engine::HTTP>.
+This class overloads some methods from C<Catalyst::Engine::CGI>.
=over 4
-=item $c->run
+=item finalize_headers
+
+=cut
+
+sub finalize_headers {
+ my ( $self, $c ) = @_;
+ my $protocol = $c->request->protocol;
+ my $status = $c->response->status;
+ my $message = status_message($status);
+ print "$protocol $status $message\n";
+ $c->response->headers->date(time);
+ $self->NEXT::finalize_headers($c);
+}
+
+=item $self->run($c)
=cut
sub run {
- my $class = shift;
- my $request = shift || '/';
+ my ( $self, $class, $request ) = @_;
- unless ( ref $request ) {
+ $request = Catalyst::Utils::request($request);
- my $uri = ( $request =~ m/http/i )
- ? URI->new($request)
- : URI->new( 'http://localhost' . $request );
+ $request->header(
+ 'Host' => sprintf( '%s:%d', $request->uri->host, $request->uri->port )
+ );
- $request = $uri->canonical;
- }
+ # We emulate CGI
+ local %ENV = (
+ PATH_INFO => $request->uri->path || '',
+ QUERY_STRING => $request->uri->query || '',
+ REMOTE_ADDR => '127.0.0.1',
+ REMOTE_HOST => 'localhost',
+ REQUEST_METHOD => $request->method,
+ SERVER_NAME => 'localhost',
+ SERVER_PORT => $request->uri->port,
+ SERVER_PROTOCOL => 'HTTP/1.1',
+ %ENV,
+ );
- unless ( ref $request eq 'HTTP::Request' ) {
- $request = HTTP::Request->new( 'GET', $request );
+ # Headers
+ for my $header ( $request->header_field_names ) {
+ my $name = uc $header;
+ $name = 'COOKIE' if $name eq 'COOKIES';
+ $name =~ tr/-/_/;
+ $name = 'HTTP_' . $name
+ unless $name =~ m/\A(?:CONTENT_(?:LENGTH|TYPE)|COOKIE)\z/;
+ my $value = $request->header($header);
+ if ( exists $ENV{$name} ) {
+ $ENV{$name} .= "; $value";
+ }
+ else {
+ $ENV{$name} = $value;
+ }
}
- my $http = Catalyst::Engine::HTTP::LWP->new(
- request => $request,
- address => '127.0.0.1',
- hostname => 'localhost'
- );
+ # STDIN
+ local *STDIN;
+ my $input = $request->content;
+ open STDIN, '<', \$input;
+
+ # STDOUT
+ local *STDOUT;
+ my $output = '';
+ open STDOUT, '>', \$output;
- $class->handler($http);
+ # Process
+ $class->handle_request;
- return $http->response;
+ # Response
+ return HTTP::Response->parse($output);
}
+=item $self->read_chunk($c, $buffer, $length)
+
+=cut
+
+sub read_chunk { shift; shift; *STDIN->read(@_); }
+
=back
=head1 SEE ALSO
L<Catalyst>.
-=head1 AUTHOR
+=head1 AUTHORS
+
+Sebastian Riedel, <sri@cpan.org>
+
+Christian Hansen, <ch@ngmedia.com>
-Sebastian Riedel, C<sri@cpan.org>
-Christian Hansen, C<ch@ngmedia.com>
+Andy Grundman, <andy@hybridized.org>
=head1 COPYRIGHT