X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fmulti_content_type.t;h=521f46340555cfe8abfb7ce31a4e0599668ed10d;hb=97ae89ab316de422a55b3b3252ab4dbabfcdbdcd;hp=2748ebc3b15a239c80de837d8c65f2ff20cc42da;hpb=6bc863629dfa3bec1d938eb5a7af7ef68fd3849f;p=catagits%2FTest-WWW-Mechanize-Catalyst.git diff --git a/t/multi_content_type.t b/t/multi_content_type.t index 2748ebc..521f463 100644 --- a/t/multi_content_type.t +++ b/t/multi_content_type.t @@ -10,12 +10,12 @@ BEGIN { $ENV{CATALYST_SERVER} ||= "http://localhost:$PORT"; } -use Test::More tests => 6; +use Test::More tests => 8; use Test::Exception; BEGIN { diag( - "###################################################################\n", + "\n###################################################################\n", "Starting an external Catalyst HTTP server on port $PORT\n", "To change the port, please set the TWMC_TEST_PORT env variable.\n", "(The server will be automatically shut-down right after the tests).\n", @@ -29,18 +29,34 @@ $SIG{INT} = sub { warn "INT:$$"; exit }; use_ok 'ExternalCatty'; my $pid = ExternalCatty->background($PORT); -use Test::WWW::Mechanize::Catalyst 'ExternalCatty'; +use Test::WWW::Mechanize::Catalyst; my $m = Test::WWW::Mechanize::Catalyst->new; -lives_ok { $m->get_ok( '/', 'Get a multi Content-Type response' ) } -'Survive to a multi Content-Type sting'; +my $skip = 0; +TRY_CONNECT: { + eval { $m->get('/') }; -is( $m->ct, 'text/html', 'Multi Content-Type Content-Type' ); -$m->title_is( 'Root', 'Multi Content-Type title' ); -$m->content_contains( "Hello, test \x{263A}!", 'Multi Content-Type body' ); + if ($@ || $m->content =~ /Can't connect to \w+:$PORT/) { + $skip = $@ || $m->content; + } +} + +SKIP: { + skip $skip, 7 if $skip; + lives_ok { $m->get_ok( '/', 'Get a multi Content-Type response' ) } + 'Survive to a multi Content-Type sting'; + + is( $m->ct, 'text/html', 'Multi Content-Type Content-Type' ); + $m->title_is( 'Root', 'Multi Content-Type title' ); + $m->content_contains( "Hello, test \x{263A}!", 'Multi Content-Type body' ); + + # Test a redirect with a remote server now too. + $m->get_ok( '/hello' ); + is($m->uri, "$ENV{CATALYST_SERVER}/"); +} END { - if ( $pid > 0 ) { + if ( $pid && $pid != 0 ) { kill 9, $pid; } }