X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Farg_constraints.t;h=fb3a3a7f0971104c0464030825c9f6bf301e26cf;hp=cfd4f0983be48644aa789dd1c1587ea97eb0f83a;hb=b40370866bf21a54428e3193b83ea6dabdd70d9e;hpb=b684787167ee18eb7e81245f55e0b48a72a8a1b8 diff --git a/t/arg_constraints.t b/t/arg_constraints.t index cfd4f09..fb3a3a7 100644 --- a/t/arg_constraints.t +++ b/t/arg_constraints.t @@ -1,5 +1,6 @@ use warnings; use strict; +use HTTP::Request::Common; BEGIN { use Test::More; @@ -105,7 +106,10 @@ BEGIN { sub chain_base :Chained(/) CaptureArgs(1) { } - sub any_priority_chain :Chained(chain_base) PathPart('') Args(1) { $_[1]->res->body('any_priority_chain') } + sub chained_zero_post :POST Chained(chain_base) PathPart('') Args(0) { $_[1]->res->body('chained_zero_post') } + sub chained_zero : Chained(chain_base) PathPart('') Args(0) { $_[1]->res->body('chained_zero') } + + 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') } @@ -135,7 +139,8 @@ BEGIN { sub link2_int :Chained(link_tuple) PathPart('') CaptureArgs(UserId) { } - sub finally :Chained(link2_int) PathPart('') Args(Int) { $_[1]->res->body('finally') } + 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 default :Default { my ($self, $c, $int) = @_; @@ -295,12 +300,51 @@ 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'; +} + +=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_base/capture'; + is $res->content, 'chained_zero'; +} + +{ + my $res = request '/chain_base/capture'; + is $res->content, 'chained_zero'; +} + +{ + my $res = request POST '/chain_base/capture'; + is $res->content, 'chained_zero_post'; +} + =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