[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