X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Flib%2FTestApp.pm;h=e14e3dc0d199054351b9a8a4423b6909e08f52b6;hb=d9d8aa5102e2b961d4f5f0bdd76d9dbcbcefc1dd;hp=cdb9d6ed1ce01c0d6cd34912e43de6f4c5baefcf;hpb=1627551a60fe1e220d390a565f793dea27cd36a6;p=catagits%2FCatalyst-Runtime.git diff --git a/t/lib/TestApp.pm b/t/lib/TestApp.pm index cdb9d6e..e14e3dc 100644 --- a/t/lib/TestApp.pm +++ b/t/lib/TestApp.pm @@ -2,17 +2,43 @@ package TestApp; use strict; 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' ); +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 index : Private { @@ -28,7 +54,7 @@ sub global_action : Private { sub execute { my $c = shift; my $class = ref( $c->component( $_[0] ) ) || $_[0]; - my $action = "$_[1]"; + my $action = $_[1]->reverse; my $method; @@ -55,6 +81,17 @@ 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 } ) ); +} + sub class_forward_test_method :Private { my ( $self, $c ) = @_; $c->response->headers->header( 'X-Class-Forward-Test-Method' => 1 ); @@ -77,4 +114,13 @@ sub recursion_test : Local { 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;