|
Packit |
4e8bc4 |
#!/usr/bin/perl
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
use strict;
|
|
Packit |
4e8bc4 |
use Test::More tests => 12;
|
|
Packit |
4e8bc4 |
use FindBin qw($Bin);
|
|
Packit |
4e8bc4 |
use lib "$Bin/lib";
|
|
Packit |
4e8bc4 |
use MemcachedTest;
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
## First make sure we report UNIX-domain sockets correctly
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
my $filename = "/tmp/memcachetest$$";
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
my $server = new_memcached("-s $filename");
|
|
Packit |
4e8bc4 |
my $sock = $server->sock;
|
|
Packit |
4e8bc4 |
my $stats_sock = $server->new_sock;
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
ok(-S $filename, "creating unix domain socket $filename");
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
print $sock "set foo 0 0 6\r\n";
|
|
Packit |
4e8bc4 |
sleep(1); # so we can test secs_since_last_cmd is nonzero
|
|
Packit |
4e8bc4 |
print $stats_sock "stats conns\r\n";
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
my $stats;
|
|
Packit |
4e8bc4 |
while (<$stats_sock>) {
|
|
Packit |
4e8bc4 |
last if /^(\.|END)/;
|
|
Packit |
4e8bc4 |
$stats .= $_;
|
|
Packit |
4e8bc4 |
}
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
like($stats, qr/STAT \d+:addr /);
|
|
Packit |
4e8bc4 |
$stats =~ m/STAT (\d+):addr unix:(.*[^\r\n])/g;
|
|
Packit |
4e8bc4 |
my $listen_fd = $1;
|
|
Packit |
4e8bc4 |
my $socket_path = $2;
|
|
Packit |
4e8bc4 |
# getsockname(2) doesn't return socket path on GNU/Hurd (and maybe others)
|
|
Packit |
4e8bc4 |
SKIP: {
|
|
Packit |
4e8bc4 |
skip "socket path checking on GNU kernel", 1 if ($^O eq 'gnu');
|
|
Packit |
4e8bc4 |
is($socket_path, $filename, "unix domain socket path reported correctly");
|
|
Packit |
4e8bc4 |
};
|
|
Packit |
4e8bc4 |
$stats =~ m/STAT (\d+):state conn_listening\r\n/g;
|
|
Packit |
4e8bc4 |
is($1, $listen_fd, "listen socket fd reported correctly");
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
like($stats, qr/STAT \d+:state conn_nread/,
|
|
Packit |
4e8bc4 |
"one client is sending data");
|
|
Packit |
4e8bc4 |
like($stats, qr/STAT \d+:state conn_parse_cmd/,
|
|
Packit |
4e8bc4 |
"one client is in command processing");
|
|
Packit |
4e8bc4 |
like($stats, qr/STAT \d+:secs_since_last_cmd [1-9]\r/,
|
|
Packit |
4e8bc4 |
"nonzero secs_since_last_cmd");
|
|
Packit |
4e8bc4 |
like($stats, qr/STAT \d+:listen_addr unix:\/tmp\/memcachetest\d+\r/,
|
|
Packit |
4e8bc4 |
"found listen_addr for the UNIX-domain socket");
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
$server->stop;
|
|
Packit |
4e8bc4 |
unlink($filename);
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
## Now look at TCP
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
$server = new_memcached("-l 0.0.0.0");
|
|
Packit |
4e8bc4 |
$sock = $server->sock;
|
|
Packit |
4e8bc4 |
$stats_sock = $server->new_sock;
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
print $sock "set foo 0 0 6\r\n";
|
|
Packit |
4e8bc4 |
print $stats_sock "stats conns\r\n";
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
$stats = '';
|
|
Packit |
4e8bc4 |
while (<$stats_sock>) {
|
|
Packit |
4e8bc4 |
last if /^(\.|END)/;
|
|
Packit |
4e8bc4 |
$stats .= $_;
|
|
Packit |
4e8bc4 |
}
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
like($stats, qr/STAT \d+:state conn_listen/, "there is a listen socket");
|
|
Packit |
4e8bc4 |
$stats =~ m/STAT \d+:addr udp:0.0.0.0:(\d+)/;
|
|
Packit |
4e8bc4 |
is($1, $server->udpport, "udp port number is correct");
|
|
Packit |
4e8bc4 |
$stats =~ m/STAT \d+:addr tcp:0.0.0.0:(\d+)/;
|
|
Packit |
4e8bc4 |
print STDERR "PORT: ", $server->port, "\n";
|
|
Packit |
4e8bc4 |
is($1, $server->port, "tcp port number is correct");
|
|
Packit |
4e8bc4 |
|
|
Packit |
4e8bc4 |
$stats =~ m/STAT \d+:listen_addr tcp:0.0.0.0:(\d+)/;
|
|
Packit |
4e8bc4 |
is($1, $server->port, "listen_addr is correct for the tcp port");
|