X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Flive_engine_request_parameters.t;h=684660ae16c24b8012cd2d641635378fb6fee8dc;hp=1f1091f20944bd9126e59e6408a453d9ee0e5765;hb=2f3812528068bc1d9f7840067f0c03d36cd47e6d;hpb=7d22a5373b8e3c57c1c6a9cae3d246efb840a8ea diff --git a/t/live_engine_request_parameters.t b/t/live_engine_request_parameters.t index 1f1091f..684660a 100644 --- a/t/live_engine_request_parameters.t +++ b/t/live_engine_request_parameters.t @@ -6,13 +6,12 @@ use warnings; use FindBin; use lib "$FindBin::Bin/lib"; -use Test::More tests => 35; +use Test::More tests => 53; use Catalyst::Test 'TestApp'; use Catalyst::Request; use HTTP::Headers; use HTTP::Request::Common; -use URI; { my $creq; @@ -33,7 +32,7 @@ use URI; 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, + is_deeply( $creq->parameters, $parameters, 'Catalyst::Request parameters' ); } @@ -44,7 +43,17 @@ use URI; ok( $response->is_success, 'Response Successful 2xx' ); is( $response->content_type, 'text/plain', 'Response Content-Type' ); ok( eval '$creq = ' . $response->content ); - is $creq->{parameters}->{q}, 'foo+bar', '%2b not double decoded'; + is $creq->parameters->{q}, 'foo+bar', '%2b not double decoded'; +} + +{ + my $creq; + ok( my $response = request("http://localhost/dump/request?q=foo=bar"), + 'Request' ); + ok( $response->is_success, 'Response Successful 2xx' ); + is( $response->content_type, 'text/plain', 'Response Content-Type' ); + ok( eval '$creq = ' . $response->content ); + is $creq->parameters->{q}, 'foo=bar', '= not ignored'; } { @@ -75,10 +84,10 @@ use URI; 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, + 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->uploads, {}, 'Catalyst::Request uploads' ); is_deeply( $creq->cookies, {}, 'Catalyst::Request cookie' ); } @@ -100,7 +109,7 @@ use URI; 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 @@ -120,11 +129,34 @@ use URI; 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' ); + is( $creq->uri->query, 'query+string', 'Catalyst::Request POST query_string' ); is( $creq->query_keywords, 'query string', 'Catalyst::Request query_keywords' ); - is_deeply( $creq->{parameters}, $parameters, 'Catalyst::Request parameters' ); + is_deeply( $creq->parameters, $parameters, 'Catalyst::Request parameters' ); 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' ); + is( $creq->uri->query, 'x=1&y=1&z=1', 'Catalyst::Request GET query_string' ); +} + +{ + my $creq; + ok( my $response = request("http://localhost/dump/request?&&q="), + 'Request' ); + ok( $response->is_success, 'Response Successful 2xx' ); + is( $response->content_type, 'text/plain', 'Response Content-Type' ); + ok( eval '$creq = ' . $response->content ); + is( keys %{$creq->{parameters}}, 1, 'remove empty parameter' ); + is( $creq->{parameters}->{q}, '', 'empty parameter' ); +} + +{ + my $creq; + ok( my $response = request("http://localhost/dump/request?&0&q="), + 'Request' ); + ok( $response->is_success, 'Response Successful 2xx' ); + is( $response->content_type, 'text/plain', 'Response Content-Type' ); + ok( eval '$creq = ' . $response->content ); + is( keys %{$creq->{parameters}}, 2, 'remove empty parameter' ); + is( $creq->{parameters}->{q}, '', 'empty parameter' ); + ok( !defined $creq->{parameters}->{0}, 'empty parameter' ); }