[Catalyst-commits] r11867 - in
Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib:
. TestAppDoubleAutoBug
zby at dev.catalyst.perl.org
zby at dev.catalyst.perl.org
Tue Nov 17 15:21:01 GMT 2009
Author: zby
Date: 2009-11-17 15:21:01 +0000 (Tue, 17 Nov 2009)
New Revision: 11867
Added:
Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug/Context.pm
Modified:
Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug.pm
Log:
separate context class for TestAppDoubleAutoBug
Added: Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug/Context.pm
===================================================================
--- Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug/Context.pm (rev 0)
+++ Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug/Context.pm 2009-11-17 15:21:01 UTC (rev 11867)
@@ -0,0 +1,60 @@
+package TestAppDoubleAutoBug::Context;
+use Moose;
+extends 'Catalyst::Context';
+
+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 };
+}
+
+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(@_);
+}
+
+after prepare_action => sub{
+ my $c = shift;
+ $c->res->header( 'X-Catalyst-Action' => $c->req->action );
+};
+
+1;
+
Modified: Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug.pm
===================================================================
--- Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug.pm 2009-11-17 14:59:57 UTC (rev 11866)
+++ Catalyst-Runtime/5.80/branches/basic-app-ctx-separation-cleaned/t/lib/TestAppDoubleAutoBug.pm 2009-11-17 15:21:01 UTC (rev 11867)
@@ -9,12 +9,12 @@
Test::Plugin
/;
-use TestApp::Context;
+use TestAppDoubleAutoBug::Context;
our $VERSION = '0.01';
__PACKAGE__->config( name => 'TestAppDoubleAutoBug', root => '/some/dir' );
-__PACKAGE__->context_class( 'TestApp::Context' );
+__PACKAGE__->context_class( 'TestAppDoubleAutoBug::Context' );
__PACKAGE__->setup;
1;
More information about the Catalyst-commits
mailing list