Fixed my bug
Sebastian Riedel [Fri, 21 Oct 2005 15:00:39 +0000 (15:00 +0000)]
lib/Catalyst/Engine/Test.pm
lib/Catalyst/Utils.pm

index 5dd0523..04cc522 100644 (file)
@@ -2,7 +2,7 @@ package Catalyst::Engine::Test;
 
 use strict;
 use base 'Catalyst::Engine::CGI';
-use HTTP::Request;
+use Catalyst::Utils;
 use HTTP::Response;
 use HTTP::Status;
 use NEXT;
@@ -58,22 +58,7 @@ sub finalize_headers {
 sub run {
     my ( $self, $class, $request ) = @_;
 
-    # Construct request
-    unless ( ref $request ) {
-        if ( $request =~ m/http/i ) {
-            $request = URI->new($request)->canonical;
-        }
-        else {
-            $request = URI->new( 'http://localhost' . $request )->canonical;
-        }
-    }
-    unless ( ref $request eq 'HTTP::Request' ) {
-        $request = HTTP::Request->new( 'GET', $request );
-    }
-
-    $request->header(
-        'Host' => sprintf( '%s:%d', $request->uri->host, $request->uri->port )
-    );
+    $request = Catalyst::Utils::request($request);
 
     # We emulate CGI
     local %ENV = (
index c76a247..bbef4d5 100644 (file)
@@ -224,6 +224,32 @@ sub reflect_actions {
     return $actions;
 }
 
+=item request($request)
+
+Returns a HTTP::Request object.
+
+=cut
+
+sub request {
+    my $request = shift;
+    unless ( ref $request ) {
+        if ( $request =~ m/http/i ) {
+            $request = URI->new($request)->canonical;
+        }
+        else {
+            $request = URI->new( 'http://localhost' . $request )->canonical;
+        }
+    }
+    unless ( ref $request eq 'HTTP::Request' ) {
+        $request = HTTP::Request->new( 'GET', $request );
+    }
+
+    $request->header(
+        'Host' => sprintf( '%s:%d', $request->uri->host, $request->uri->port )
+    );
+    return $request;
+}
+
 =back
 
 =head1 AUTHOR