X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Foptional_http-server.t;h=fbef97f4cfdd1336e82c8d0651998a43fb0a1a9e;hb=547f880602b1b5f8b89839829763b2e36dbd29e7;hp=d03a10718e76ba544b317f6efd3da3ee9af4a91d;hpb=a2e038a1e9cbc0f1ea32b7087e6b47efe3af082f;p=catagits%2FCatalyst-Runtime.git diff --git a/t/optional_http-server.t b/t/optional_http-server.t index d03a107..fbef97f 100644 --- a/t/optional_http-server.t +++ b/t/optional_http-server.t @@ -7,12 +7,17 @@ use File::Path; use FindBin; use IO::Socket; use Test::More; -eval "use File::Copy::Recursive"; plan skip_all => 'set TEST_HTTP to enable this test' unless $ENV{TEST_HTTP}; +eval "use Catalyst::Devel 1.0"; +plan skip_all => 'Catalyst::Devel required' if $@; +eval "use File::Copy::Recursive"; plan skip_all => 'File::Copy::Recursive required' if $@; plan tests => 1; +# Run a single test by providing it as the first arg +my $single_test = shift; + # clean up rmtree "$FindBin::Bin/../t/tmp" if -d "$FindBin::Bin/../t/tmp"; @@ -20,7 +25,7 @@ rmtree "$FindBin::Bin/../t/tmp" if -d "$FindBin::Bin/../t/tmp"; mkdir "$FindBin::Bin/../t/tmp"; chdir "$FindBin::Bin/../t/tmp"; system "perl -I$FindBin::Bin/../lib $FindBin::Bin/../script/catalyst.pl TestApp"; -chdir "$FindBin::Bin/../.."; +chdir "$FindBin::Bin/.."; File::Copy::Recursive::dircopy( 't/lib', 't/tmp/TestApp/lib' ); # remove TestApp's tests @@ -40,7 +45,13 @@ while ( check_port( 'localhost', $port ) != 1 ) { # run the testsuite against the HTTP server $ENV{CATALYST_SERVER} = "http://localhost:$port"; -system( 'prove -r -Ilib/ t/live_*' ); + +if ( $single_test ) { + system( "perl -Ilib/ $single_test" ); +} +else { + system( 'prove -r -Ilib/ t/live_*' ); +} # shut it down kill 'INT', $pid;