use IO::Socket;
use Test::More;
+plan skip_all => 'set TEST_LIGHTTPD to enable this test'
+ unless $ENV{TEST_LIGHTTPD};
+
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 $@;
-my $lighttpd_bin = $ENV{LIGHTTPD_BIN};
-plan skip_all => 'Please set LIGHTTPD_BIN to run this test'
+eval "use Test::Harness";
+plan skip_all => 'Test::Harness required' if $@;
+
+my $lighttpd_bin = $ENV{LIGHTTPD_BIN} || `which lighttpd`;
+chomp $lighttpd_bin;
+
+plan skip_all => 'Please set LIGHTTPD_BIN to the path to lighttpd'
unless $lighttpd_bin && -x $lighttpd_bin;
plan tests => 1;
)
END
-open(my $lightconf, '>', "$docroot/lighttpd.conf") or die "Can't open $docroot/lighttpd.conf: $!";
+open(my $lightconf, '>', "$docroot/lighttpd.conf")
+ or die "Can't open $docroot/lighttpd.conf: $!";
print {$lightconf} $conf or die "Write error: $!";
close $lightconf;
or die "Unable to spawn lighttpd: $!";
# wait for it to start
-print "Waiting for server to start...\n";
while ( check_port( 'localhost', $port ) != 1 ) {
+ diag "Waiting for server to start...";
sleep 1;
}
# run the testsuite against the server
$ENV{CATALYST_SERVER} = "http://localhost:$port/deep/path";
-system( 'prove -r -Ilib/ t/live_*' );
+
+my @tests = glob('t/live_*');
+eval {
+ runtests(@tests);
+};
+ok(!$@, 'lighttpd tests ran OK');
# shut it down
kill 'INT', $pid;
# clean up
rmtree "$FindBin::Bin/../t/tmp" if -d "$FindBin::Bin/../t/tmp";
-ok( 'done' );
-
sub check_port {
my ( $host, $port ) = @_;