X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Foptional_http-server.t;fp=t%2Foptional_http-server.t;h=a518df05a584c596a9a432c210a3e54b533cd251;hb=66741f94ac93b7ba0989db3556d0e3fe36c1be87;hp=0000000000000000000000000000000000000000;hpb=587b0f5882d4f5e128ae082758da37b065a3efde;p=catagits%2FCatalyst-Runtime.git diff --git a/t/optional_http-server.t b/t/optional_http-server.t new file mode 100644 index 0000000..a518df0 --- /dev/null +++ b/t/optional_http-server.t @@ -0,0 +1,69 @@ +#!perl + +use strict; +use warnings; + +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}; +plan skip_all => 'File::Copy::Recursive required' if $@; +plan tests => 1; + +# clean up +rmtree "$FindBin::Bin/../../t/tmp" if -d "$FindBin::Bin/../../t/tmp"; + +# create a TestApp and copy the test libs into it +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/../.."; +File::Copy::Recursive::dircopy( 't/live/lib', 't/tmp/TestApp/lib' ); + +# remove TestApp's tests +rmtree 't/tmp/TestApp/t'; + +# spawn the standalone HTTP server +my $port = 30000 + int rand(1 + 10000); +my $pid = open my $server, + "perl -I$FindBin::Bin/../../lib $FindBin::Bin/../../t/tmp/TestApp/script/testapp_server.pl -port $port 2>&1 |" + or die "Unable to spawn standalone HTTP server: $!"; + +# wait for it to start +print "Waiting for server to start...\n"; +while ( check_port( 'localhost', $port ) != 1 ) { + sleep 1; +} + +# run the testsuite against the HTTP server +$ENV{CATALYST_SERVER} = "http://localhost:$port"; +system( 'prove -r -Ilib/ t/live/' ); + +# shut it down +kill 'INT', $pid; +close $server; + +# clean up +rmtree "$FindBin::Bin/../../t/tmp" if -d "$FindBin::Bin/../../t/tmp"; + +ok( 'done' ); + +sub check_port { + my ( $host, $port ) = @_; + + my $remote = IO::Socket::INET->new( + Proto => "tcp", + PeerAddr => $host, + PeerPort => $port + ); + if ($remote) { + close $remote; + return 1; + } + else { + return 0; + } +}