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=bb88a73d994a8343c2f4430028a70f212dc44b24;hp=e7f2ae281f1073d2edcfe7838f0487943d1c3fc4;hb=82010ea176741c7a4f2baf3f6f27377b1d9f6b15;hpb=dd4e6fd2152eea9f5b0c1f559575ced7684ef257 diff --git a/t/lib/TestApp.pm b/t/lib/TestApp.pm index e7f2ae2..bb88a73 100644 --- a/t/lib/TestApp.pm +++ b/t/lib/TestApp.pm @@ -1,37 +1,153 @@ 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 Class::Load 'try_load_class'; + +use Moose; +use namespace::autoclean; + +# ----------- +# t/aggregate/unit_core_ctx_attr.t pukes until lazy is true +package Greeting; +use Moose; +sub hello_notlazy { 'hello there' } +sub hello_lazy { 'hello there' } + +package TestApp; +has 'my_greeting_obj_notlazy' => ( + is => 'ro', + isa => 'Greeting', + default => sub { Greeting->new() }, + handles => [ qw( hello_notlazy ) ], + lazy => 0, +); +has 'my_greeting_obj_lazy' => ( + is => 'ro', + isa => 'Greeting', + default => sub { Greeting->new() }, + handles => [ qw( hello_lazy ) ], + lazy => 1, +); +# ----------- our $VERSION = '0.01'; -TestApp->config( - name => 'TestApp', - root => '/Users/chansen/src/MyApp/root', +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, ); -TestApp->setup; +# 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'); -#sub execute { return shift->NEXT::execute(@_); } # does not work, bug? +if ($::setup_leakchecker && try_load_class('CatalystX::LeakChecker')) { + 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 { - my $c = shift; - my $class = ref( $c->component($_[0]) ) || $_[0]; - my $action = $c->actions->{reverse}->{"$_[1]"} || "$_[1]"; + my $c = shift; + my $class = ref( $c->component( $_[0] ) ) || $_[0]; + my $action = $_[1]->reverse; my $method; - if ( $action =~ /->(\w+)$/ ) { - $method = $1; + if ( $action =~ /->(\w+)$/ ) { + $method = $1; } - elsif ( $action =~ /\/(\w+)$/ ) { - $method = $1; + elsif ( $action =~ /\/(\w+)$/ ) { + $method = $1; + } + elsif ( $action =~ /^(\w+)$/ ) { + $method = $action; } - my $executed = sprintf( "%s->%s", $class, $method ); - - $c->response->headers->push_header( 'X-Catalyst-Executed' => $executed ); + 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 + ); + } + no warnings 'recursion'; 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 { } +} + +# Pretend to be Plugin::Session and hook finalize_headers to send a header + +sub finalize_headers { + my $c = shift; + + $c->res->header('X-Test-Header', 'valid'); + + 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 strict; + +use base qw/Class::Data::Inheritable/; + 1;