X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Farg_constraints.t;h=a1cd3fd8b5bae223253812fea7989d52e88be2d7;hb=aef0cb5dc1b5dbadba8f6345587ea2012011108f;hp=a5c5c1c8c0339e946d6b38e4ebda5e27be06bbc5;hpb=bf4f16438595386223595dd82ecde9efe8aca8fe;p=catagits%2FCatalyst-Runtime.git diff --git a/t/arg_constraints.t b/t/arg_constraints.t index a5c5c1c..a1cd3fd 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 => $@"; }; @@ -105,7 +106,7 @@ BEGIN { sub chain_base :Chained(/) CaptureArgs(1) { } - sub any_priority_chain :Chained(chain_base) PathPart('') Args(1) { $_[1]->res->body('any_priority_chain') } + sub any_priority_chain :GET Chained(chain_base) PathPart('') Args(1) { $_[1]->res->body('any_priority_chain') } sub int_priority_chain :Chained(chain_base) PathPart('') Args(Int) { $_[1]->res->body('int_priority_chain') } @@ -121,12 +122,31 @@ BEGIN { sub int_priority_link :Chained(link_int) PathPart('') Args(Int) { $_[1]->res->body('int_priority_link') } - sub link_int_int :Chained(chain_base) PathPart('') CaptureArgs(Tuple[Int,Int]) { } + sub link_int_int :Chained(chain_base) PathPart('') CaptureArgs(Int,Int) { } sub any_priority_link2 :Chained(link_int_int) PathPart('') Args(1) { $_[1]->res->body('any_priority_link2') } sub int_priority_link2 :Chained(link_int_int) PathPart('') Args(Int) { $_[1]->res->body('int_priority_link2') } + sub link_tuple :Chained(chain_base) PathPart('') CaptureArgs(Tuple[Int,Int,Int]) { } + + sub any_priority_link3 :Chained(link_tuple) PathPart('') Args(1) { $_[1]->res->body('any_priority_link3') } + + sub int_priority_link3 :Chained(link_tuple) PathPart('') Args(Int) { $_[1]->res->body('int_priority_link3') } + + 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_post2 :POST 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 :POST 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) = @_; @@ -276,11 +296,90 @@ SKIP: { is $res->content, 'default'; } -#{ - # URI testing - #my ($res, $c) = ctx_request '/'; +{ + my $res = request '/chain_base/100/100/100/100/100'; + is $res->content, 'int_priority_link3'; +} +{ + my $res = request '/chain_base/100/ss/100/100/100'; + 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'; +} + +=over + +| /chain_base/* | /chain_base (1) | +| | => /chained_zero (0) | +| /chain_base/* | /chain_base (1) | +| | => POST /chained_zero_post (0) + +=cut + +{ + my $res = request PUT '/chain_base2/capture/1'; + is $res->content, 'chained_zero3'; +} + +{ + my $res = request '/chain_base2/capture/1'; + is $res->content, 'chained_zero3'; +} + +{ + my $res = request POST '/chain_base2/capture/1'; + is $res->content, 'chained_zero3'; +} + +{ + my $res = request PUT '/chain_base2/capture'; + is $res->content, 'chained_zero2'; +} + +{ + my $res = request '/chain_base2/capture'; + is $res->content, 'chained_zero2'; +} + +{ + my $res = request POST '/chain_base2/capture'; + is $res->content, 'chained_zero2'; +} + +=over + +| /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 '/'; + ok my $url1 = $c->uri_for($c->controller('Root')->action_for('finally'), [1,2,3,4,5],6); + warn $url1; + + ok my $url2 = $c->uri_for($c->controller('Root')->action_for('finally'), [1,2,3,4,5,6]); + warn $url2; +} +