Will flatten the capture args in uri_for
[catagits/Catalyst-Runtime.git] / t / optional_threads.t
diff --git a/t/optional_threads.t b/t/optional_threads.t
new file mode 100644 (file)
index 0000000..baa4089
--- /dev/null
@@ -0,0 +1,55 @@
+#!perl
+
+use strict;
+use warnings;
+
+use Test::More;
+BEGIN {
+    plan skip_all => 'set TEST_THREADS to enable this test'
+        unless $ENV{TEST_THREADS};
+}
+
+use FindBin;
+use lib "$FindBin::Bin/lib";
+use Catalyst::Test 'TestApp';
+use Catalyst::Request;
+use Config;
+use HTTP::Response;
+
+if ( $Config{useithreads} && !$ENV{CATALYST_SERVER} ) {
+    require threads;
+    plan tests => 3;
+}
+else {
+    if ( $ENV{CATALYST_SERVER} ) {
+        plan skip_all => 'Using remote server';
+    }
+    else {
+        plan skip_all => 'Needs a Perl with ithreads enabled';
+    }
+}
+no warnings 'redefine';
+sub request {
+    my $thr = threads->new( 
+        sub { Catalyst::Test::local_request('TestApp',@_) },
+        @_ 
+    );
+    $thr->join;
+}
+
+# test that running inside a thread works ok
+{
+    my @expected = qw[
+        TestApp::Controller::Action::Default->begin
+        TestApp::Controller::Action::Default->default
+        TestApp::View::Dump::Request->process
+        TestApp->end
+    ];
+
+    my $expected = join( ", ", @expected );
+    
+    ok( my $response = request('http://localhost/action/default'), 'Request' );
+    ok( $response->is_success, 'Response Successful 2xx' );
+    is( $response->header('X-Catalyst-Executed'), $expected, 'Executed actions' );
+}