X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Flib%2FTestApp.pm;h=e14e3dc0d199054351b9a8a4423b6909e08f52b6;hb=d9d8aa5102e2b961d4f5f0bdd76d9dbcbcefc1dd;hp=acb4a646ecfb1bad0015aab49b0a37512bd0db66;hpb=4d989a5da1809be1088a985e02dff19f89b8cfd6;p=catagits%2FCatalyst-Runtime.git diff --git a/t/lib/TestApp.pm b/t/lib/TestApp.pm index acb4a64..e14e3dc 100644 --- a/t/lib/TestApp.pm +++ b/t/lib/TestApp.pm @@ -1,18 +1,50 @@ package TestApp; use strict; -use Catalyst qw[Test::Errors Test::Headers]; +use Catalyst qw/ + Test::MangleDollarUnderScore + Test::Errors + Test::Headers + Test::Plugin + Test::Inline + +TestApp::Plugin::FullyQualified + +TestApp::Plugin::AddDispatchTypes + +TestApp::Role +/; +use Catalyst::Utils; + +use Moose; +use namespace::autoclean; our $VERSION = '0.01'; -TestApp->config( - name => 'TestApp', - root => '/Users/chansen/src/MyApp/root', -); +TestApp->config( name => 'TestApp', root => '/some/dir' ); + +if (eval { Class::MOP::load_class('CatalystX::LeakChecker'); 1 }) { + with 'CatalystX::LeakChecker'; + + has leaks => ( + is => 'ro', + default => sub { [] }, + ); +} + +sub found_leaks { + my ($ctx, @leaks) = @_; + push @{ $ctx->leaks }, @leaks; +} + +sub count_leaks { + my ($ctx) = @_; + return scalar @{ $ctx->leaks }; +} TestApp->setup; -#sub execute { return shift->NEXT::execute(@_); } # does not work, bug? +sub index : Private { + my ( $self, $c ) = @_; + $c->res->body('root index'); +} sub global_action : Private { my ( $self, $c ) = @_; @@ -22,7 +54,7 @@ sub global_action : Private { sub execute { my $c = shift; my $class = ref( $c->component( $_[0] ) ) || $_[0]; - my $action = $c->actions->{reverse}->{"$_[1]"} || "$_[1]"; + my $action = $_[1]->reverse; my $method; @@ -32,12 +64,63 @@ sub execute { elsif ( $action =~ /\/(\w+)$/ ) { $method = $1; } + elsif ( $action =~ /^(\w+)$/ ) { + $method = $action; + } - my $executed = sprintf( "%s->%s", $class, $method ) - if ( $class && $method ); + if ( $class && $method && $method !~ /^_/ ) { + my $executed = sprintf( "%s->%s", $class, $method ); + my @executed = $c->response->headers->header('X-Catalyst-Executed'); + push @executed, $executed; + $c->response->headers->header( + 'X-Catalyst-Executed' => join ', ', + @executed + ); + } - $c->response->headers->push_header( 'X-Catalyst-Executed' => $executed ); return $c->SUPER::execute(@_); } +# Replace the very large HTML error page with +# useful info if something crashes during a test +sub finalize_error { + my $c = shift; + + $c->next::method(@_); + + $c->res->status(500); + $c->res->body( 'FATAL ERROR: ' . join( ', ', @{ $c->error } ) ); +} + +sub class_forward_test_method :Private { + my ( $self, $c ) = @_; + $c->response->headers->header( 'X-Class-Forward-Test-Method' => 1 ); +} + +sub loop_test : Local { + my ( $self, $c ) = @_; + + for( 1..1001 ) { + $c->forward( 'class_forward_test_method' ); + } +} + +sub recursion_test : Local { + my ( $self, $c ) = @_; + $c->forward( 'recursion_test' ); +} + +{ + no warnings 'redefine'; + sub Catalyst::Log::error { } +} + +# Make sure we can load Inline plugins. + +package Catalyst::Plugin::Test::Inline; + +use strict; + +use base qw/Class::Data::Inheritable/; + 1;