X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Flib%2FTestApp.pm;h=b6d937449231d0a7723272b8d7f636d979c05f24;hb=cf013d38de7a842c70c9d237a9ee3c18f0a42948;hp=594dfa3a4c0b4a2526db7beaf088f3ad693fa2ed;hpb=66741f94ac93b7ba0989db3556d0e3fe36c1be87;p=catagits%2FCatalyst-Runtime.git diff --git a/t/lib/TestApp.pm b/t/lib/TestApp.pm index 594dfa3..b6d9374 100644 --- a/t/lib/TestApp.pm +++ b/t/lib/TestApp.pm @@ -1,29 +1,50 @@ package TestApp; use strict; -use Catalyst qw/Test::Errors Test::Headers Test::Plugin/; +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 => '/some/dir' ); -TestApp->setup; +if (eval { Class::MOP::load_class('CatalystX::LeakChecker'); 1 }) { + with 'CatalystX::LeakChecker'; + + has leaks => ( + is => 'ro', + default => sub { [] }, + ); +} -sub index : Private { - my ( $self, $c ) = @_; - $c->res->body('root index'); +sub found_leaks { + my ($ctx, @leaks) = @_; + push @{ $ctx->leaks }, @leaks; } -sub global_action : Private { - my ( $self, $c ) = @_; - $c->forward('TestApp::View::Dump::Request'); +sub count_leaks { + my ($ctx) = @_; + return scalar @{ $ctx->leaks }; } +TestApp->setup; + sub execute { my $c = shift; my $class = ref( $c->component( $_[0] ) ) || $_[0]; - my $action = "$_[1]"; + my $action = $_[1]->reverse; my $method; @@ -50,8 +71,28 @@ sub execute { 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 } ) ); +} + { 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;