MojoX-HTTP-Async

 view release on metacpan or  search on metacpan

t/inactivity_timeout.t  view on Meta::CPAN

package main;

use 5.020;
use utf8;
use strict;
use warnings;
use experimental qw/ signatures /;
use bytes ();

use lib 'lib/', 't/lib';

use Test::More ('import' => [qw/ done_testing is ok use_ok /]);
use Test::Utils qw/ get_listen_socket start_server notify_parent /;

use Time::HiRes qw/ sleep /;


my $slots = 2;
my $host = 'localhost';
my $request_timeout = 3;
my $connect_timeout = 3;
my $inactivity_timeout = 1;

BEGIN { use_ok('MojoX::HTTP::Async') };

sub on_start_cb ($port) {

    my $client;
    my $socket = get_listen_socket($host, $port);

    notify_parent();

    while (my $peer = accept($client, $socket)) {

        my $pid;

        if ($pid = fork()) { # parent
            sleep(0.05);
        } elsif ($pid == 0) { # child
            close($socket);
            sleep($request_timeout + 1);
            exit(0);
        } else {
            die("Can't fork: $!");
        }
    }
}


my $server = start_server(\&on_start_cb, $host);
my $ua = MojoX::HTTP::Async->new(
    'host' => $host,
    'port' => $server->port(),
    'slots' => $slots,
    'connect_timeout' => $connect_timeout,
    'request_timeout' => $request_timeout,
    'inactivity_conn_ts' => $inactivity_timeout,
);

# one slot is free and one slot is busy
ok($ua->add("/page/01.html"), "Adding the first request");

sleep($inactivity_timeout + 0.1);

my $n = $ua->refresh_connections();

is($n, 1, "Checking the amount of renewed slots");

# both slots are busy
ok($ua->add("/page/02.html"), "Adding the second request");
ok($ua->add("/page/03.html"), "Adding the third request");

sleep($inactivity_timeout + 0.1);

$n = $ua->refresh_connections();

is($n, 2, "Checking the amount of renewed slots");

# all connections are fresh
ok($ua->add("/page/04.html"), "Adding the fourth request");
ok($ua->add("/page/05.html"), "Adding the fifth request");

$n = $ua->refresh_connections();
is($n, 0, "Checking the amount of renewed slots");

# there are no expired connections
$ua->close_all();

ok($ua->add("/page/06.html"), "Adding the sixth request");
ok($ua->add("/page/07.html"), "Adding the seventh request");

sleep($inactivity_timeout * 0.5);

$n = $ua->refresh_connections();
is($n, 0, "Checking the amount of renewed slots");

done_testing();

$ua->close_all();
$server->stop();

1;
__END__



( run in 1.048 second using v1.01-cache-2.11-cpan-39bf76dae61 )