| 12
 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
 
 | #!/usr/bin/perl -w
#
# ~/check_logfiles/test/026case.t
#
#  Test that all the Perl modules we require are available.
#
use strict;
use Test::More tests => 3;
use Cwd;
use lib "../plugins-scripts";
use Nagios::CheckLogfiles::Test;
use constant TESTDIR => ".";
if ($^O ne "aix") {
  diag ("this test only runs on aix if at all");
  ok(1); ok(1); ok(1);
  exit 0;
}
my $cl = Nagios::CheckLogfiles::Test->new({
	protocolsdir => TESTDIR."/var/tmp",
	seekfilesdir => TESTDIR."/var/tmp",
	searches => [
	    {
	      tag => "mem",
	      type => "errpt",
	      criticalpatterns => ["Memory failure"],
	      options => "noprotocol"
	    }
	]    });
my $mem = $cl->get_search_by_tag("mem");
$mem->delete_logfile();
$mem->delete_seekfile();
$mem->trace("deleted logfile and 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.
$mem->trace(sprintf "+----------------------- test %d ------------------", 1);
$mem->trace("initial run");
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 0, 1, 0, 2));
# 2 now find the two criticals
$mem->trace(sprintf "+----------------------- test %d ------------------", 2);
$cl->reset();
sleep 1;
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 0, 2, 0, 2));
sleep 62;
# 3 now find the two criticals and the two warnings
$mem->trace(sprintf "+----------------------- test %d ------------------", 3);
$cl->reset();
sleep 1;
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 2, 2, 0, 2));
sleep 300;
# 3 now find the two criticals and the two warnings
# $mem->trace(sprintf "+----------------------- test %d ------------------", 3);
$cl->reset();
sleep 1;
$cl->run();
diag($cl->has_result());
diag($cl->{exitmessage});
ok($cl->expect_result(0, 2, 2, 0, 2));
 |