|
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");
|