Merged 5.49_01 (r1339) from refactored branch to trunk
[catagits/Catalyst-Runtime.git] / t / live / engine / request / parameters.t
similarity index 51%
rename from t/engine/request/parameters.t
rename to t/live/engine/request/parameters.t
index 68fb7cd..f399b78 100644 (file)
@@ -6,7 +6,7 @@ use warnings;
 use FindBin;
 use lib "$FindBin::Bin/../../lib";
 
-use Test::More tests => 19;
+use Test::More tests => 28;
 use Catalyst::Test 'TestApp';
 
 use Catalyst::Request;
@@ -17,63 +17,63 @@ use URI;
 {
     my $creq;
 
-    my $parameters = { 
-        'a' => [qw(A b C d E f G)],
-    };
-    
+    my $parameters = { 'a' => [qw(A b C d E f G)], };
+
     my $query = join( '&', map { 'a=' . $_ } @{ $parameters->{a} } );
-    
-    ok( my $response = request("http://localhost/dump/request?$query"), 'Request' );
+
+    ok( my $response = request("http://localhost/dump/request?$query"),
+        'Request' );
     ok( $response->is_success, 'Response Successful 2xx' );
     is( $response->content_type, 'text/plain', 'Response Content-Type' );
-    like( $response->content, qr/^bless\( .* 'Catalyst::Request' \)$/s, 'Content is a serialized Catalyst::Request' );
+    like(
+        $response->content,
+        qr/^bless\( .* 'Catalyst::Request' \)$/s,
+        'Content is a serialized Catalyst::Request'
+    );
     ok( eval '$creq = ' . $response->content, 'Unserialize Catalyst::Request' );
     isa_ok( $creq, 'Catalyst::Request' );
     is( $creq->method, 'GET', 'Catalyst::Request method' );
-    is_deeply( $creq->parameters, $parameters, 'Catalyst::Request parameters' );
+    is_deeply( $creq->{parameters}, $parameters,
+        'Catalyst::Request parameters' );
 }
 
 {
     my $creq;
 
-    my $parameters = { 
+    my $parameters = {
         'a' => [qw(A b C d E f G)],
         '%' => [ '%', '"', '& - &' ],
     };
 
-    my $request = POST( 'http://localhost/dump/request/a/b?a=1&a=2&a=3', 
+    my $request = POST(
+        'http://localhost/dump/request/a/b?a=1&a=2&a=3',
         'Content'      => $parameters,
         'Content-Type' => 'application/x-www-form-urlencoded'
     );
 
-    # Query string. I'm not sure the order is consistent in all enviroments,
-    # we need to test this with:
-    # [x] C::E::Test and C::E::HTTP
-    # [x] MP13
-    # [x] MP19
-    # [x] MP20
-    # [x] CGI
-
     unshift( @{ $parameters->{a} }, 1, 2, 3 );
-    
+
     ok( my $response = request($request), 'Request' );
     ok( $response->is_success, 'Response Successful 2xx' );
     is( $response->content_type, 'text/plain', 'Response Content-Type' );
-    like( $response->content, qr/^bless\( .* 'Catalyst::Request' \)$/s, 'Content is a serialized Catalyst::Request' );
+    like(
+        $response->content,
+        qr/^bless\( .* 'Catalyst::Request' \)$/s,
+        'Content is a serialized Catalyst::Request'
+    );
     ok( eval '$creq = ' . $response->content, 'Unserialize Catalyst::Request' );
     isa_ok( $creq, 'Catalyst::Request' );
     is( $creq->method, 'POST', 'Catalyst::Request method' );
-    is_deeply( $creq->parameters, $parameters, 'Catalyst::Request parameters' );
+    is_deeply( $creq->{parameters}, $parameters,
+        'Catalyst::Request parameters' );
     is_deeply( $creq->arguments, [qw(a b)], 'Catalyst::Request arguments' );
-    is_deeply( $creq->uploads, {}, 'Catalyst::Request uploads' );
-    is_deeply( $creq->cookies, {}, 'Catalyst::Request cookie' );
+    is_deeply( $creq->{uploads}, {}, 'Catalyst::Request uploads' );
+    is_deeply( $creq->cookies,   {}, 'Catalyst::Request cookie' );
 }
 
-__END__
 # http://dev.catalyst.perl.org/ticket/37
 # multipart/form-data parameters that contain 'http://'
-# Not testing in trunk because this is an HTTP::Message bug
-# http://rt.cpan.org/NoAuth/Bug.html?id=13025
+# was an HTTP::Message bug, but HTTP::Body handles it properly now
 {
     my $creq;
 
@@ -88,5 +88,28 @@ __END__
 
     ok( my $response = request($request), 'Request' );
     ok( eval '$creq = ' . $response->content, 'Unserialize Catalyst::Request' );
-    is_deeply( $creq->parameters, $parameters, 'Catalyst::Request parameters' );
+    is_deeply( $creq->{parameters}, $parameters, 'Catalyst::Request parameters' );
+}
+
+# raw query string support
+{
+    my $creq;
+    
+    my $parameters = {
+        a => 1,
+    };
+
+    my $request = POST(
+        'http://localhost/dump/request/a/b?query_string',
+        'Content'      => $parameters,
+        'Content-Type' => 'application/x-www-form-urlencoded'
+    );
+    
+    ok( my $response = request($request), 'Request' );
+    ok( eval '$creq = ' . $response->content, 'Unserialize Catalyst::Request' );
+    is( $creq->{uri}->query, 'query_string', 'Catalyst::Request POST query_string' );
+    
+    ok( $response = request('http://localhost/dump/request/a/b?x=1&y=1&z=1'), 'Request' );
+    ok( eval '$creq = ' . $response->content, 'Unserialize Catalyst::Request' );
+    is( $creq->{uri}->query, 'x=1&y=1&z=1', 'Catalyst::Request GET query_string' );
 }