X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Flib%2FTestApp.pm;h=3d50a73f454f052b7b9f031a15d7557298bbf9e0;hp=3bd3763d006cd32dbd2e99613f8550a8b9b2dc48;hb=88e5a8b0c4d28e46b8ba6b6b9567063e57af9063;hpb=9cdb85d28dad6a60a5b5d3241c0073567d6983b8 diff --git a/t/lib/TestApp.pm b/t/lib/TestApp.pm index 3bd3763..3d50a73 100644 --- a/t/lib/TestApp.pm +++ b/t/lib/TestApp.pm @@ -1,10 +1,9 @@ package TestApp; - use strict; use Catalyst qw/ Test::MangleDollarUnderScore - Test::Errors - Test::Headers + Test::Errors + Test::Headers Test::Plugin Test::Inline +TestApp::Plugin::FullyQualified @@ -12,9 +11,10 @@ use Catalyst qw/ +TestApp::Role /; use Catalyst::Utils; +use Class::Load 'try_load_class'; use Moose; -use namespace::autoclean; +use namespace::clean -except => [ 'meta' ]; # ----------- # t/aggregate/unit_core_ctx_attr.t pukes until lazy is true @@ -42,14 +42,25 @@ has 'my_greeting_obj_lazy' => ( our $VERSION = '0.01'; -TestApp->config( name => 'TestApp', root => '/some/dir', use_request_uri_for_path => 1 ); +TestApp->config( + name => 'TestApp', + root => '/some/dir', + use_request_uri_for_path => 1, + 'Controller::Action::Action' => { + action_args => { + action_action_nine => { another_extra_arg => 13 } + } + }, + encoding => 'UTF-8', + abort_chain_on_error_fix => 1, +); # Test bug found when re-adjusting the metaclass compat code in Moose # in 292360. Test added to Moose in 4b760d6, but leave this attribute # above ->setup so we have some generated methods to be double sure. has an_attribute_before_we_change_base_classes => ( is => 'ro'); -if ($::setup_leakchecker && eval { Class::MOP::load_class('CatalystX::LeakChecker'); 1 }) { +if ($::setup_leakchecker && try_load_class('CatalystX::LeakChecker')) { with 'CatalystX::LeakChecker'; has leaks => ( @@ -104,9 +115,9 @@ sub execute { # 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 } ) ); } @@ -116,12 +127,24 @@ sub finalize_error { sub Catalyst::Log::error { } } -# Make sure we can load Inline plugins. +# Pretend to be Plugin::Session and hook finalize_headers to send a header -package Catalyst::Plugin::Test::Inline; +sub finalize_headers { + my $c = shift; -use strict; + $c->res->header('X-Test-Header', 'valid'); -use base qw/Class::Data::Inheritable/; + my $call_count = $c->stash->{finalize_headers_call_count} || 0; + $call_count++; + $c->stash(finalize_headers_call_count => $call_count); + $c->res->header('X-Test-Header-Call-Count' => $call_count); + + return $c->maybe::next::method(@_); +} + +# Make sure we can load Inline plugins. + +package Catalyst::Plugin::Test::Inline; +use Moose; 1;