use strict;
use Catalyst qw/
+ Test::MangleDollarUnderScore
Test::Errors
- Test::Headers
Test::Plugin
Test::Inline
+TestApp::Plugin::FullyQualified
/;
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'; # LeakChecker dose not work yet with Catalyst::Context - zby
-sub index : Private {
- my ( $self, $c ) = @_;
- $c->res->body('root index');
+ has leaks => (
+ is => 'ro',
+ default => sub { [] },
+ );
}
-sub global_action : Private {
- my ( $self, $c ) = @_;
- $c->forward('TestApp::View::Dump::Request');
+sub found_leaks {
+ my ($ctx, @leaks) = @_;
+ push @{ $ctx->leaks }, @leaks;
}
-sub execute {
- my $c = shift;
- my $class = ref( $c->component( $_[0] ) ) || $_[0];
- my $action = $_[1]->reverse;
+sub count_leaks {
+ my ($ctx) = @_;
+ return scalar @{ $ctx->leaks };
+}
- my $method;
+TestApp->context_class( 'TestApp::Context' );
+TestApp->setup;
- if ( $action =~ /->(\w+)$/ ) {
- $method = $1;
- }
- elsif ( $action =~ /\/(\w+)$/ ) {
- $method = $1;
- }
- elsif ( $action =~ /^(\w+)$/ ) {
- $method = $action;
- }
+around prepare => sub {
+ my $orig = shift;
+ my $self = shift;
+
+ my $c = $self->$orig(@_);
- 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->header( 'X-Catalyst-Engine' => $c->engine );
+ $c->response->header( 'X-Catalyst-Debug' => $c->debug ? 1 : 0 );
+
+ {
+ my $components = join( ', ', sort keys %{ $c->components } );
+ $c->response->header( 'X-Catalyst-Components' => $components );
}
- return $c->SUPER::execute(@_);
-}
+ {
+ no strict 'refs';
+ my $plugins = join ', ', $self->registered_plugins;
+ $c->response->header( 'X-Catalyst-Plugins' => $plugins );
+ }
-# 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 } ) );
-}
+ return $c;
+};
-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 ) = @_;
+{
+ package TestApp::Context;
+ use Moose;
+ extends 'Catalyst::Context';
+
+ sub execute {
+ my $c = shift;
+ my $class = ref( $c->component( $_[0] ) ) || $_[0];
+ my $action = $_[1]->reverse;
+
+ my $method;
+
+ if ( $action =~ /->(\w+)$/ ) {
+ $method = $1;
+ }
+ elsif ( $action =~ /\/(\w+)$/ ) {
+ $method = $1;
+ }
+ elsif ( $action =~ /^(\w+)$/ ) {
+ $method = $action;
+ }
+
+ 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(@_);
+ }
- for( 1..1001 ) {
- $c->forward( 'class_forward_test_method' );
+ # 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 recursion_test : Local {
- my ( $self, $c ) = @_;
- $c->forward( 'recursion_test' );
+ after prepare_action => sub{
+ my $c = shift;
+ $c->res->header( 'X-Catalyst-Action' => $c->req->action );
+ };
+
}
{