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 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
#!/usr/bin/perl -w
#
# ~/check_logfiles/test/040eventlog.t
#
# Test that all the Perl modules we require are available.
#
use strict;
use Test::More;
use Cwd;
use lib "../plugins-scripts";
use Nagios::CheckLogfiles::Test;
use constant TESTDIR => ".";
if (($^O ne "cygwin") and ($^O !~ /MSWin/)) {
diag("this is not a windows machine");
plan skip_all => 'Test only relevant on Windows';
} else {
plan tests => 5;
}
my $cl = Nagios::CheckLogfiles::Test->new({
protocolsdir => TESTDIR."/var/tmp",
seekfilesdir => TESTDIR."/var/tmp",
searches => [
{
tag => "ssh",
type => "psloglist",
criticalpatterns => ["Adobe", "Firewall" ],
psloglist => {
eventlog => "application",
}
}
] });
my $ssh = $cl->get_search_by_tag("ssh");
if (! -x $ssh->{clo}->{path}.($^O =~ /MSWin/ ? ".exe" : "")) {
diag(sprintf "!!! skipping tests. %s not installed!!!", $ssh->{clo}->{path});
foreach (1..5) {ok(1)};
exit 0;
}
$ssh->delete_seekfile();
$ssh->trace("deleted seekfile");
# 1 logfile will be created. there is no seekfile. position at the end of file
# and remember this as starting point for the next run.
$ssh->trace(sprintf "+----------------------- test %d ------------------", 1);
sleep 2;
$ssh->trace("initial run");
$cl->run(); # cleanup
$cl->reset();
diag("cleanup");
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 0, 0, 0, 0));
# 2 now find the two criticals
$ssh->trace(sprintf "+----------------------- test %d ------------------", 2);
$cl->reset();
sleep 30;
$ssh->logger(undef, undef, 1, "Firewall problem");
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 0, 0, 0, 0));
# 3 now find the two criticals and the two warnings
$ssh->trace(sprintf "+----------------------- test %d ------------------", 3);
$cl->reset();
sleep 120;
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 0, 1, 0, 2));
# 2 now find the two criticals
$ssh->trace(sprintf "+----------------------- test %d ------------------", 4);
$cl->reset();
$ssh->logger(undef, undef, 1, "Firewall problem");
sleep 10;
$ssh->logger(undef, undef, 1, "Firewall problem");
sleep 10;
$ssh->logger(undef, undef, 1, "Firewall problem");
sleep 10;
$ssh->logger(undef, undef, 1, "Firewall problem");
sleep 10;
$ssh->logger(undef, undef, 1, "Firewall problem2");
$ssh->logger(undef, undef, 1, "Firewall problem");
sleep 10;
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
#ok($cl->expect_result(0, 0, 6, 0, 2));
$cl->{perfdata} =~ /.*'ssh_criticals'=(\d+).*/;
my $found = $1;
diag(sprintf "reported %d errors so far. %d to come", $found, 6 - $found);
ok($cl->{exitmessage} =~ /CRITICAL/);
# 3 now find the two criticals and the two warnings
$ssh->trace(sprintf "+----------------------- test %d ------------------", 5);
$cl->reset();
sleep 65;
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 0, 6 - $found, 0, 2));
|