X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Farg_constraints.t;h=8bfa08572ed4e224e32d40e901fef0ede98b8208;hb=9228a8ec8f3ed3938ad1463d1bf8d49a9aa5e748;hp=cfd4f0983be48644aa789dd1c1587ea97eb0f83a;hpb=b684787167ee18eb7e81245f55e0b48a72a8a1b8;p=catagits%2FCatalyst-Runtime.git diff --git a/t/arg_constraints.t b/t/arg_constraints.t index cfd4f09..8bfa085 100644 --- a/t/arg_constraints.t +++ b/t/arg_constraints.t @@ -1,12 +1,16 @@ use warnings; use strict; +use HTTP::Request::Common; +use utf8; BEGIN { use Test::More; - eval "use Types::Standard; 1;" || do { - plan skip_all => "Trouble loading Types::Standard => $@"; + eval "use Type::Tiny; 1" || do { + plan skip_all => "Trouble loading Type::Tiny and friends => $@"; }; +} +BEGIN { package MyApp::Types; $INC{'MyApp/Types.pm'} = __FILE__; @@ -17,7 +21,7 @@ BEGIN { use Types::Standard -types; use Type::Library -base, - -declare => qw( UserId User ContextLike ); + -declare => qw( UserId Heart User ContextLike ); extends "Types::Standard"; @@ -28,6 +32,10 @@ BEGIN { as Int, where { $_ < 5 }; + declare Heart, + as Str, + where { $_ eq '♥' }; + # Tests using this are skipped pending deeper thought coerce User, from ContextLike, @@ -58,7 +66,7 @@ BEGIN { use Moose; use MooseX::MethodAttributes; - use MyApp::Types qw/Tuple Int Str StrMatch ArrayRef UserId User/; + use MyApp::Types qw/Tuple Int Str StrMatch ArrayRef UserId User Heart/; extends 'Catalyst::Controller'; @@ -105,7 +113,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') } @@ -135,7 +143,23 @@ 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 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 heart :Local Args(Heart) { } + + sub utf8_base :Chained(/) CaptureArgs(Heart) { } + sub utf8_end :Chained(utf8_base) PathPart('') Args(Heart) { } sub default :Default { my ($self, $c, $int) = @_; @@ -295,23 +319,124 @@ 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 { # 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; + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('user'), 2) }; + is $url, 'http://localhost/user/2'; + } + + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('user'), [2]) }; + is $url, 'http://localhost/user/2'; + } + + { + ok my $url = ! eval { $c->uri_for($c->controller('Root')->action_for('user'), [20]) }; + } + + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('finally'), [1,2,3,4,4],6) }; + is $url, 'http://localhost/chain_base/1/2/3/4/4/6'; + } + + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('finally'), [1,2,3,4,4,6]) }; + is $url, 'http://localhost/chain_base/1/2/3/4/4/6'; + } + + { + ok my $url = ! eval { $c->uri_for($c->controller('Root')->action_for('finally'), [1,2,3,4,5,6]) }; + } + + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('finally'), ['a',2,3,4,4,6]) }; + is $url, 'http://localhost/chain_base/a/2/3/4/4/6'; + } + + { + ok my $url = ! eval { $c->uri_for($c->controller('Root')->action_for('finally'), ['a','1',3,4,4,'a']) }; + } + + { + ok my $url = ! eval { $c->uri_for($c->controller('Root')->action_for('finally'), ['a','a',3,4,4,'6']) }; + } + + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('heart'), ['♥']) }; + is $url, 'http://localhost/heart/%E2%99%A5'; + } + + { + ok my $url = ! eval { $c->uri_for($c->controller('Root')->action_for('heart'), ['1']) }; + } + + { + ok my $url = eval { $c->uri_for($c->controller('Root')->action_for('utf8_end'), ['♥','♥']) }; + is $url, 'http://localhost/utf8_base/%E2%99%A5/%E2%99%A5'; + } + + { + ok my $url = ! eval { $c->uri_for($c->controller('Root')->action_for('utf8_end'), ['2','1']) }; + } + } done_testing;