X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Flive_component_controller_action_chained.t;h=ee502146cd32ed4cbc4edcc65b42c7f0daec269e;hp=0a8d32dc6b975370bec2a4c4feaac7a66d39a729;hb=8a6a6581d48a3c1c4d5f631cdb7cbda336c0e5e2;hpb=f88e7f694016c0878e1bbf68f5653118cd61f31a diff --git a/t/live_component_controller_action_chained.t b/t/live_component_controller_action_chained.t index 0a8d32d..ee50214 100644 --- a/t/live_component_controller_action_chained.t +++ b/t/live_component_controller_action_chained.t @@ -10,7 +10,7 @@ our $iters; BEGIN { $iters = $ENV{CAT_BENCH_ITERS} || 2; } -use Test::More tests => 72*$iters; +use Test::More tests => 101*$iters; use Catalyst::Test 'TestApp'; if ( $ENV{CAT_BENCHMARK} ) { @@ -19,11 +19,12 @@ if ( $ENV{CAT_BENCHMARK} ) { } else { for ( 1 .. $iters ) { - run_tests(); + run_tests($_); } } sub run_tests { + my ($run_number) = @_; # # This is a simple test where the parent and child actions are @@ -120,7 +121,7 @@ sub run_tests { # # The first three-chain test tries to call the action with :Args(1) - # specification. There's also a one action with a :Captures(1) + # specification. There's also a one action with a :CaptureArgs(1) # attribute, that should not be dispatched to. # { @@ -142,7 +143,7 @@ sub run_tests { # # This is the second three-chain test, it goes for the action that # handles "/one/$cap/two/$arg1/$arg2" paths. Should be the two action - # having :Args(2), not the one having :Captures(2). + # having :Args(2), not the one having :CaptureArgs(2). # { my @expected = qw[ @@ -162,9 +163,9 @@ sub run_tests { } # - # Last of the three-chain tests. Has no concurrent action with :Captures + # Last of the three-chain tests. Has no concurrent action with :CaptureArgs # and is more thought to simply test the chain as a whole and the 'two' - # action specifying :Captures. + # action specifying :CaptureArgs. # { my @expected = qw[ @@ -364,6 +365,27 @@ sub run_tests { } # + # This belongs to the former test but tests if two chained actions have + # priority over an action with one child action not having the Args() attr set. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained->priority_c1 + TestApp::Controller::Action::Chained->priority_c2_xyz + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/priority_c/1/xyz/'), + 'priority - no Args() order mismatch' ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; ', 'Content OK' ); + } + + # # Test dispatching between two controllers that are on the same level and # therefor have no parent/child relationship. # @@ -504,4 +526,189 @@ sub run_tests { $expected, 'Executed actions' ); is( $response->content, '1; 2', 'Content OK' ); } + + # + # Test behaviour of auto actions returning '1' for the chain. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained::Auto->auto + TestApp::Controller::Action::Chained::Auto::Foo->auto + TestApp::Controller::Action::Chained::Auto->foo + TestApp::Controller::Action::Chained::Auto::Foo->fooend + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/autochain1/1/fooend/2'), + "Behaviour when auto returns 1 correct" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Test behaviour of auto actions returning '0' for the chain. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained::Auto->auto + TestApp::Controller::Action::Chained::Auto::Bar->auto + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/autochain2/1/barend/2'), + "Behaviour when auto returns 0 correct" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Test what auto actions are run when namespaces are changed + # horizontally. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained::Auto->auto + TestApp::Controller::Action::Chained::Auto::Foo->auto + TestApp::Controller::Action::Chained::Auto::Bar->crossloose + TestApp::Controller::Action::Chained::Auto::Foo->crossend + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/auto_cross/1/crossend/2'), + "Correct auto actions are run on cross controller dispatch" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Test forwarding from auto action in chain dispatch. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained::Auto->auto + TestApp::Controller::Action::Chained::Auto::Forward->auto + TestApp::Controller::Action::Chained::Auto->fw3 + TestApp::Controller::Action::Chained::Auto->fw1 + TestApp::Controller::Action::Chained::Auto::Forward->forwardend + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/auto_forward/1/forwardend/2'), + "Forwarding out of auto in chain" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Detaching out of the auto action of a chain. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained::Auto->auto + TestApp::Controller::Action::Chained::Auto::Detach->auto + TestApp::Controller::Action::Chained::Auto->fw3 + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/auto_detach/1/detachend/2'), + "Detaching out of auto in chain" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Test forwarding from auto action in chain dispatch. + # + { + my $expected = undef; + + ok( my $response = request('http://localhost/chained/loose/23'), + "Loose end is not callable" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->header('Status'), 500, 'Status OK' ); + } + + # + # Test forwarding out of a chain. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained->chain_fw_a + TestApp::Controller::Action::Chained->fw_dt_target + TestApp::Controller::Action::Chained->chain_fw_b + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/chain_fw/1/end/2'), + "Forwarding out a chain" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Test detaching out of a chain. + # + { + my @expected = qw[ + TestApp::Controller::Action::Chained->begin + TestApp::Controller::Action::Chained->chain_dt_a + TestApp::Controller::Action::Chained->fw_dt_target + TestApp::Controller::Action::Chained->end + ]; + + my $expected = join( ", ", @expected ); + + ok( my $response = request('http://localhost/chained/chain_dt/1/end/2'), + "Forwarding out a chain" ); + is( $response->header('X-Catalyst-Executed'), + $expected, 'Executed actions' ); + is( $response->content, '1; 2', 'Content OK' ); + } + + # + # Test interception of recursive chains. This test was added because at + # one point during the :Chained development, Catalyst used to hang on + # recursive chains. + # + { + eval { require 'TestAppChainedRecursive.pm' }; + pass( "Interception of recursive chains" ); + } + + # + # Test failure of absolute path part arguments. + # + { + eval { require 'TestAppChainedAbsolutePathPart.pm' }; + if ($run_number == 1) { + like( $@, qr(foo/foo), + "Usage of absolute path part argument emits error" ); + } + else { pass( "Error on absolute path part arguments already tested" ) } + } }