X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FEngine%2FTest.pm;h=8173bdef41643381f325b4029dc4d4e5f0af7987;hb=b14151e76ebbd0a776e7955238ce1afbc1985a33;hp=a5f9ca472e27018a8fd5fecde75ad76bec4a6906;hpb=d837e1a7eadff19ff04373ad19d22fa293e19db5;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Engine/Test.pm b/lib/Catalyst/Engine/Test.pm index a5f9ca4..8173bde 100644 --- a/lib/Catalyst/Engine/Test.pm +++ b/lib/Catalyst/Engine/Test.pm @@ -1,9 +1,11 @@ package Catalyst::Engine::Test; use strict; -use base 'Catalyst::Engine::HTTP::Base'; - +use base 'Catalyst::Engine::CGI'; use Catalyst::Utils; +use HTTP::Response; +use HTTP::Status; +use NEXT; =head1 NAME @@ -31,47 +33,102 @@ This is the Catalyst engine specialized for testing. =head1 OVERLOADED METHODS -This class overloads some methods from C. +This class overloads some methods from C. =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, $request ) = @_; - + my ( $self, $class, $request ) = @_; + $request = Catalyst::Utils::request($request); - $request->header( + $request->header( 'Host' => sprintf( '%s:%d', $request->uri->host, $request->uri->port ) ); - my $http = Catalyst::Engine::HTTP::Base::struct->new( - address => '127.0.0.1', - hostname => 'localhost', - request => $request, - response => HTTP::Response->new + # 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, ); - $http->response->date(time); + # 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; + } + } + + # 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. -=head1 AUTHOR +=head1 AUTHORS + +Sebastian Riedel, + +Christian Hansen, -Sebastian Riedel, C -Christian Hansen, C +Andy Grundman, =head1 COPYRIGHT