annotate t/03_stats.t @ 0:17fc6afc155e CACHE_MEMCACHED_1_24

Cache::Memcached 1.24
author Maxim Dounin <mdounin@mdounin.ru>
date Sun, 30 Sep 2007 16:23:31 +0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
1 # -*-perl-*-
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
2
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
3 use strict;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
4 use Test::More;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
5 use Cache::Memcached;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
6 use IO::Socket::INET;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
7
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
8 my $testaddr = "127.0.0.1:11211";
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
9 my $msock = IO::Socket::INET->new(PeerAddr => $testaddr,
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
10 Timeout => 3);
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
11
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
12 my @misc_stats_keys = qw/ bytes bytes_read bytes_written
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
13 cmd_get cmd_set connection_structures curr_items
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
14 get_hits get_misses
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
15 total_connections total_items
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
16 /;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
17
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
18 if ($msock) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
19 plan tests => 24 + scalar(@misc_stats_keys);
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
20 } else {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
21 plan skip_all => "No memcached instance running at $testaddr\n";
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
22 exit 0;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
23 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
24
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
25 my $memd = Cache::Memcached->new({
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
26 servers => [ $testaddr ],
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
27 namespace => "Cache::Memcached::t/$$/" . (time() % 100) . "/",
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
28 });
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
29
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
30 my $misc_stats = $memd->stats('misc');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
31 ok($misc_stats, 'got misc stats');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
32 isa_ok($misc_stats, 'HASH', 'misc stats');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
33 isa_ok($misc_stats->{'total'}, 'HASH', 'misc stats total');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
34 isa_ok($misc_stats->{'hosts'}, 'HASH', 'misc stats hosts');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
35 isa_ok($misc_stats->{'hosts'}{$testaddr}, 'HASH',
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
36 "misc stats hosts $testaddr");
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
37
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
38 foreach my $stat_key (@misc_stats_keys) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
39 ok(exists $misc_stats->{'total'}{$stat_key},
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
40 "misc stats total contains $stat_key");
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
41 ok(exists $misc_stats->{'hosts'}{$testaddr}{'misc'}{$stat_key},
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
42 "misc stats hosts $testaddr misc contains $stat_key");
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
43 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
44
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
45 my $got_malloc = 0;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
46 foreach my $stat_key (keys %{$misc_stats->{'total'}}) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
47 if ($stat_key =~ /^malloc/) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
48 $got_malloc = 1;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
49 last;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
50 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
51 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
52 ok(! $got_malloc, 'no malloc stats in misc stats');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
53
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
54 my $malloc_stats = $memd->stats('malloc');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
55 ok($malloc_stats, 'got malloc stats');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
56 isa_ok($malloc_stats, 'HASH', 'malloc stats');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
57 isa_ok($malloc_stats->{'total'}, 'HASH', 'malloc stats total');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
58 isa_ok($misc_stats->{'hosts'}, 'HASH', 'malloc stats hosts');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
59 isa_ok($misc_stats->{'hosts'}{$testaddr}, 'HASH',
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
60 "malloc stats host $testaddr");
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
61
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
62 $got_malloc = 0;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
63 foreach my $stat_key (keys %{$malloc_stats->{'total'}}) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
64 if ($stat_key =~ /^malloc/) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
65 $got_malloc = 1;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
66 last;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
67 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
68 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
69 ok($got_malloc, 'malloc stats in malloc stats');
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
70
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
71 my $got_misc = 0;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
72 foreach my $stat_key (@misc_stats_keys) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
73 if (exists $malloc_stats->{'total'}{$stat_key}) {
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
74 $got_misc = 1;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
75 last;
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
76 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
77 }
17fc6afc155e Cache::Memcached 1.24
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
78 ok(! $got_misc, 'no misc stats in malloc stats');