Blame t/idle-timeout.t

Packit 4e8bc4
#!/usr/bin/perl
Packit 4e8bc4
Packit 4e8bc4
use strict;
Packit 4e8bc4
use warnings;
Packit 4e8bc4
Packit 4e8bc4
use Test::More tests => 11;
Packit 4e8bc4
Packit 4e8bc4
use FindBin qw($Bin);
Packit 4e8bc4
use lib "$Bin/lib";
Packit 4e8bc4
use MemcachedTest;
Packit 4e8bc4
Packit 4e8bc4
# start up a server with 10 maximum connections
Packit 4e8bc4
my $server = new_memcached("-o idle_timeout=3 -l 127.0.0.1");
Packit 4e8bc4
my $sock = $server->sock;
Packit 4e8bc4
Packit 4e8bc4
# Make sure we can talk to start with
Packit 4e8bc4
my $stats = mem_stats($sock);
Packit 4e8bc4
is($stats->{idle_kicks}, "0", "check stats initial");
Packit 4e8bc4
isnt($sock->connected(), undef, "check connected");
Packit 4e8bc4
Packit 4e8bc4
# Make sure we don't timeout when active
Packit 4e8bc4
for (my $i = 0; $i < 6; $i++) {
Packit 4e8bc4
    $stats = mem_stats($sock);
Packit 4e8bc4
    isnt($stats->{version}, undef, "check active $i");
Packit 4e8bc4
}
Packit 4e8bc4
$stats = mem_stats($sock);
Packit 4e8bc4
is($stats->{idle_kicks}, "0", "check stats 2");
Packit 4e8bc4
Packit 4e8bc4
# Make sure we do timeout when not
Packit 4e8bc4
sleep(5);
Packit 4e8bc4
mem_stats($sock);   # Network activity, so socket code will see dead socket
Packit 4e8bc4
sleep(1);
Packit 4e8bc4
# we run SSL tests over TCP; hence IO::Socket::SSL returns
Packit 4e8bc4
# '' upon disconnecting with the server.
Packit 4e8bc4
if (enabled_tls_testing()) {
Packit 4e8bc4
    is($sock->connected(),'', "check disconnected");
Packit 4e8bc4
} else {
Packit 4e8bc4
    is($sock->connected(),undef, "check disconnected");
Packit 4e8bc4
}
Packit 4e8bc4
Packit 4e8bc4
$sock = $server->sock;
Packit 4e8bc4
$stats = mem_stats($sock);
Packit 4e8bc4
isnt($stats->{idle_kicks}, 0, "check stats timeout");