X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Flive%2Fengine%2Frequest%2Fparameters.t;fp=t%2Fengine%2Frequest%2Fparameters.t;h=f399b78858e76928f62c56c8b138b808dc8efea1;hp=68fb7cdfc1dce0c169691a6fc92aacc1a6833424;hb=fbcc39ad23f2bbecf5d84c9ba581e6af86fcd460;hpb=21465c884872c1ec8c30acd72796445f9eaacb31 diff --git a/t/engine/request/parameters.t b/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 --- a/t/engine/request/parameters.t +++ b/t/live/engine/request/parameters.t @@ -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' ); }