#!/usr/bin/perl -w use strict; use Test::More tests => 7; use Test::HexString; use IO::Async::Loop; use IO::Async::Test; use FCGI::Async; use t::lib::TestFCGI; my $request; my ( $S, $selfaddr ) = make_server_sock; my $loop = IO::Async::Loop->new(); testing_loop( $loop ); my $fcgi = FCGI::Async->new( loop => $loop, handle => $S, on_request => sub { $request = $_[1] }, ); ok( defined $fcgi, 'defined $fcgi' ); isa_ok( $fcgi, "FCGI::Async", '$fcgi isa FCGI::Async' ); my $C = connect_client_sock( $selfaddr ); # Got it - now pretend to be an FCGI client, such as how a webserver would # behave. $C->syswrite( # Begin fcgi_trans( type => 1, id => 1, data => "\0\1\0\0\0\0\0\0" ) . # No parameters fcgi_trans( type => 4, id => 1, data => "" ) . # No STDIN fcgi_trans( type => 5, id => 1, data => "" ) ); wait_for { defined $request }; isa_ok( $request, 'FCGI::Async::Request', '$request isa FCGI::Async::Request' ); is_deeply( $request->params, {}, '$request has empty params hash' ); is( $request->read_stdin_line, undef, '$request has empty STDIN' ); $request->finish; my $expect; $expect = # End of STDOUT fcgi_trans( type => 6, id => 1, data => "" ) . # End request fcgi_trans( type => 3, id => 1, data => "\0\0\0\0\0\0\0\0" ); my $buffer; $buffer = ""; wait_for_stream { length $buffer >= length $expect } $C => $buffer; is_hexstr( $buffer, $expect, 'FastCGI end request record' ); # Since we didn't specify FCGI_KEEP_CONN, we expect that $C should now be # closed, and that reading any more will give us EOF my $l = $C->sysread( $buffer, 8192 ); is( $l, 0, 'Client connection now closed' );