X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Faggregate%2Funit_core_uri_for_action.t;h=89079f9dfad631868f469ed34379cd7149cba0df;hb=76cd735d8ebdc1896bd3d7c95e2bd842baaebb73;hp=d4f4148ebcfa56f05d2bf7a5170b361d5ea38f2a;hpb=ae29b412955743885e80350085167b54b69672da;p=catagits%2FCatalyst-Runtime.git diff --git a/t/aggregate/unit_core_uri_for_action.t b/t/aggregate/unit_core_uri_for_action.t index d4f4148..89079f9 100644 --- a/t/aggregate/unit_core_uri_for_action.t +++ b/t/aggregate/unit_core_uri_for_action.t @@ -8,7 +8,7 @@ use lib "$FindBin::Bin/../lib"; use Test::More; -plan tests => 28; +plan tests => 30; use_ok('TestApp'); @@ -21,6 +21,8 @@ my $private_action = $dispatcher->get_action_by_path( '/class_forward_test_method' ); +warn $dispatcher->uri_for_action($private_action); + ok(!defined($dispatcher->uri_for_action($private_action)), "Private action returns undef for URI"); @@ -97,6 +99,10 @@ my $context = TestApp->new( { namespace => 'yada', } ); +is($context->uri_for($context->controller('Action')), + "http://127.0.0.1/foo/yada/action/", + "uri_for a controller"); + is($context->uri_for($path_action), "http://127.0.0.1/foo/action/relative/relative", "uri_for correct for path action"); @@ -120,52 +126,54 @@ is($context->uri_for($chained_action, [ 1 ], 2, { q => 1 }), # More Chained with Context Tests # { - sub __action { shift->get_action_by_path( @_ ) } - - is( $context->uri_for( __action( $dispatcher, '/action/chained/endpoint2' ), [1,2], (3,4), { x => 5 } ), + is( $context->uri_for_action( '/action/chained/endpoint2', [1,2], (3,4), { x => 5 } ), 'http://127.0.0.1/foo/chained/foo2/1/2/end2/3/4?x=5', - 'uri_for correct for chained with multiple captures and args' ); + 'uri_for_action correct for chained with multiple captures and args' ); - is( $context->uri_for( __action( $dispatcher, '/action/chained/three_end' ), [1,2,3], (4,5,6) ), + is( $context->uri_for_action( '/action/chained/three_end', [1,2,3], (4,5,6) ), 'http://127.0.0.1/foo/chained/one/1/two/2/3/three/4/5/6', - 'uri_for correct for chained with multiple capturing actions' ); + 'uri_for_action correct for chained with multiple capturing actions' ); - my $action_needs_two = __action( $dispatcher, '/action/chained/endpoint2' ); + my $action_needs_two = '/action/chained/endpoint2'; - ok( ! defined( $context->uri_for($action_needs_two, [1], (2,3)) ), - 'uri_for returns undef for not enough captures' ); + ok( ! defined( $context->uri_for_action($action_needs_two, [1], (2,3)) ), + 'uri_for_action returns undef for not enough captures' ); - is( $context->uri_for($action_needs_two, [1,2], (2,3)), + is( $context->uri_for_action($action_needs_two, [1,2], (2,3)), 'http://127.0.0.1/foo/chained/foo2/1/2/end2/2/3', - 'uri_for returns correct uri for correct captures' ); + 'uri_for_action returns correct uri for correct captures' ); - ok( ! defined( $context->uri_for($action_needs_two, [1,2,3], (2,3)) ), - 'uri_for returns undef for too many captures' ); + ok( ! defined( $context->uri_for_action($action_needs_two, [1,2,3], (2,3)) ), + 'uri_for_action returns undef for too many captures' ); - is( $context->uri_for($action_needs_two, [1,2], (3)), + is( $context->uri_for_action($action_needs_two, [1,2], (3)), 'http://127.0.0.1/foo/chained/foo2/1/2/end2/3', - 'uri_for returns uri with lesser args than specified on action' ); + 'uri_for_action returns uri with lesser args than specified on action' ); - is( $context->uri_for($action_needs_two, [1,2], (3,4,5)), + is( $context->uri_for_action($action_needs_two, [1,2], (3,4,5)), 'http://127.0.0.1/foo/chained/foo2/1/2/end2/3/4/5', - 'uri_for returns uri with more args than specified on action' ); + 'uri_for_action returns uri with more args than specified on action' ); - is( $context->uri_for($action_needs_two, [1,''], (3,4)), + is( $context->uri_for_action($action_needs_two, [1,''], (3,4)), 'http://127.0.0.1/foo/chained/foo2/1//end2/3/4', - 'uri_for returns uri with empty capture on undef capture' ); + 'uri_for_action returns uri with empty capture on undef capture' ); - is( $context->uri_for($action_needs_two, [1,2], ('',3)), + is( $context->uri_for_action($action_needs_two, [1,2], ('',3)), 'http://127.0.0.1/foo/chained/foo2/1/2/end2//3', - 'uri_for returns uri with empty arg on undef argument' ); + 'uri_for_action returns uri with empty arg on undef argument' ); - is( $context->uri_for($action_needs_two, [1,2], (3,'')), + is( $context->uri_for_action($action_needs_two, [1,2], (3,'')), 'http://127.0.0.1/foo/chained/foo2/1/2/end2/3/', - 'uri_for returns uri with empty arg on undef last argument' ); + 'uri_for_action returns uri with empty arg on undef last argument' ); - my $complex_chained = __action( $dispatcher, '/action/chained/empty_chain_f' ); - is( $context->uri_for( $complex_chained, [23], (13), {q => 3} ), + my $complex_chained = '/action/chained/empty_chain_f'; + is( $context->uri_for_action( $complex_chained, [23], (13), {q => 3} ), 'http://127.0.0.1/foo/chained/empty/23/13?q=3', - 'uri_for returns correct uri for chain with many empty path parts' ); -} + 'uri_for_action returns correct uri for chain with many empty path parts' ); + + eval { $context->uri_for_action( '/does/not/exist' ) }; + like $@, qr{^Can't find action for path '/does/not/exist'}, + 'uri_for_action croaks on nonexistent path'; +}