summaryrefslogtreecommitdiff
path: root/t/02_dbstats.t
blob: b2f2e0231cd9811a66a013cbeb30982af9358e67 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#!perl

## Test the "dbstats" action

use 5.006;
use strict;
use warnings;
use Data::Dumper;
use Test::More tests => 42;
use lib 't','.';
use CP_Testing;

use vars qw/$dbh $result $t $host $dbname/;

my $cp = CP_Testing->new( {default_action => 'dbstats'} );

$dbh = $cp->test_database_handle();
$dbh->{AutoCommit} = 1;
$dbname = $cp->get_dbname;
$host = $cp->get_host();

my $S = q{Action 'dbstats'};

$t = qq{$S rejects -w};
is($cp->run('-w 0'), "ERROR: This action is for cacti use only and takes no warning or critical arguments\n", $t);

$t = qq{$S rejects -c};
is($cp->run('-c 0'), "ERROR: This action is for cacti use only and takes no warning or critical arguments\n", $t);

$t = qq{$S identifies database};
$result = $cp->run("--dbname $dbname");
like ($result, qr{\bdbname:$dbname}, $t);

$t = qq{$S finds stats for database };
$result = $cp->run('--nodbname');
study $result;

for (qw(template0 template1 postgres ardala beedeebeedee)) {
    like($result, qr[dbname:$_], $t . $_);
}
$t = qq{$S retrieves stats for };
my $t1 = qq{$S returns integer for };
study $result;

for (qw(backends commits rollbacks read hit idxscan idxtupread idxtupfetch idxblksread
        idxblkshit seqscan seqtupread ret fetch ins upd del)) {
    like($result, qr:\b$_\b:, $t . $_);
    like($result, qr{\b$_:\d+\b}, $t1 . $_);
}

exit;