X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Farg_constraints.t;h=8d74aa87d131f845ce51d64147de5b19b054dec6;hb=2a1c08c07e5a7fe716d5bfe897e5b27fc179300a;hp=02ef73235d35e2c2e3a35e878d1ebb552ed8dd81;hpb=90102012feccf317d3ed075ea8dc04c2cee95fb5;p=catagits%2FCatalyst-Runtime.git diff --git a/t/arg_constraints.t b/t/arg_constraints.t index 02ef732..8d74aa8 100644 --- a/t/arg_constraints.t +++ b/t/arg_constraints.t @@ -1,9 +1,10 @@ use warnings; use strict; +use HTTP::Request::Common; BEGIN { use Test::More; - eval "use Types::Standard; 1;" || do { + eval "use Types::Standard; use Type::Utils; use Type::Library; 1;" || do { plan skip_all => "Trouble loading Types::Standard => $@"; }; @@ -135,8 +136,19 @@ BEGIN { sub link2_int :Chained(link_tuple) PathPart('') CaptureArgs(UserId) { } + sub finally2 :GET Chained(link2_int) PathPart('') Args { $_[1]->res->body('finally2') } sub finally :GET Chained(link2_int) PathPart('') Args(Int) { $_[1]->res->body('finally') } + sub chain_base2 :Chained(/) CaptureArgs(1) { } + + sub chained_zero_again : Chained(chain_base2) PathPart('') Args(0) { $_[1]->res->body('chained_zero_again') } + sub chained_zero_post2 : Chained(chain_base2) PathPart('') Args(0) { $_[1]->res->body('chained_zero_post2') } + sub chained_zero2 : Chained(chain_base2) PathPart('') Args(0) { $_[1]->res->body('chained_zero2') } + + sub chained_zero_post3 : Chained(chain_base2) PathPart('') Args(1) { $_[1]->res->body('chained_zero_post3') } + sub chained_zero3 : Chained(chain_base2) PathPart('') Args(1) { $_[1]->res->body('chained_zero3') } + + sub default :Default { my ($self, $c, $int) = @_; $c->res->body('default'); @@ -295,15 +307,65 @@ SKIP: { is $res->content, 'default'; } +{ + my $res = request '/chain_base/1/2/3/3/3/6'; + is $res->content, 'finally'; +} + +{ + my $res = request '/chain_base/1/2/3/3/3/a'; + is $res->content, 'finally2'; +} + +{ + my $res = request '/chain_base/1/2/3/3/3/6/7/8/9'; + is $res->content, 'finally2'; +} + + +{ + my $res = request PUT '/chain_base2/capture/1'; + is $res->content, 'chained_zero3', "request PUT '/chain_base2/capture/1'"; +} + +{ + my $res = request '/chain_base2/capture/1'; + is $res->content, 'chained_zero3', "request '/chain_base2/capture/1'"; +} + +{ + my $res = request POST '/chain_base2/capture/1'; + is $res->content, 'chained_zero3', "request POST '/chain_base2/capture/1'"; +} + +{ + my $res = request PUT '/chain_base2/capture'; + is $res->content, 'chained_zero2', "request PUT '/chain_base2/capture'"; +} + +{ + my $res = request '/chain_base2/capture'; + is $res->content, 'chained_zero2', "request '/chain_base2/capture'"; +} + +{ + my $res = request POST '/chain_base2/capture'; + is $res->content, 'chained_zero2', "request POST '/chain_base2/capture'"; +} + =over -| /chain_base/*/*/*/*/*/* | /chain_base (1) | -| | -> /link_tuple (3) | -| | -> /link2_int (1) | -| | => /finally (missing...) | +| /chain_base/*/*/*/*/*/* | /chain_base (1) +| | -> /link_tuple (Tuple[Int,Int,Int]) +| | -> /link2_int (UserId) +| | => GET /finally (Int) =cut + +done_testing; + +__END__ { # URI testing my ($res, $c) = ctx_request '/'; @@ -314,4 +376,3 @@ SKIP: { warn $url2; } -done_testing;