Code

check_ping's timeout interval is only +1 if ping command has a timeout value.
[nagiosplug.git] / plugins / t / check_ping.t
1 #! /usr/bin/perl -w -I ..
2 #
3 # Ping Response Tests via check_ping
4 #
5 # $Id$
6 #
8 use strict;
9 use Test::More;
10 use NPTest;
12 plan tests => 20;
14 my $successOutput = '/PING (ok|OK) - Packet loss = +[0-9]{1,2}\%, +RTA = [\.0-9]+ ms/';
15 my $failureOutput = '/Packet loss = +[0-9]{1,2}\%, +RTA = [\.0-9]+ ms/';
17 my $host_responsive    = getTestParameter( "NP_HOST_RESPONSIVE",
18                                 "The hostname of system responsive to network requests",
19                                 "localhost" );
21 my $host_nonresponsive = getTestParameter( "NP_HOST_NONRESPONSIVE",
22                                 "The hostname of system not responsive to network requests",
23                                 "10.0.0.1" );
25 my $hostname_invalid   = getTestParameter( "NP_HOSTNAME_INVALID",
26                                 "An invalid (not known to DNS) hostname",
27                                 "nosuchhost" );
29 my $res;
31 $res = NPTest->testCmd(
32         "./check_ping -H $host_responsive -w 10,100% -c 10,100% -p 1"
33         );
34 is( $res->return_code, 0, "Syntax ok" );
35 like( $res->output, $successOutput, "Output OK" );
37 $res = NPTest->testCmd(
38         "./check_ping -H $host_responsive -w 0,0% -c 10,100% -p 1"
39         );
40 is( $res->return_code, 1, "Syntax ok, with forced warning" );
41 like( $res->output, $failureOutput, "Output OK" );
43 $res = NPTest->testCmd(
44         "./check_ping -H $host_responsive -w 0,0% -c 0,0% -p 1"
45         );
46 is( $res->return_code, 2, "Syntax ok, with forced critical" );
47 like( $res->output, $failureOutput, "Output OK" );
49 $res = NPTest->testCmd(
50         "./check_ping $host_responsive 100 100 1000 1000 -p 1"
51         );
52 is( $res->return_code, 0, "Old syntax ok" );
53 like( $res->output, $successOutput, "Output OK" );
55 $res = NPTest->testCmd(
56         "./check_ping $host_responsive 0 0 0 0 -p 1"
57         );
58 is( $res->return_code, 2, "Old syntax, with forced critical" );
59 like( $res->output, $failureOutput, "Output OK" );
62 # check_ping results will depend on whether the ping command discovered by 
63 # ./configure has a timeout option. If it does, then the timeout will
64 # be set, so check_ping will always get a response. If it doesn't
65 # then check_ping will timeout. We do 2 tests for check_ping's timeout
66 #  - 1 second
67 #  - 15 seconds 
68 # The latter should be higher than normal ping timeouts, so should always give a packet loss result
69 open(F, "../config.h") or die "Cannot open ../config.h";
70 @_ = grep /define PING_HAS_TIMEOUT 1|define PING_PACKETS_FIRST 1/, <F>;
71 my $has_timeout;
72 $has_timeout = 1 if (scalar @_ == 2);   # Need both defined
73 close F;
74 $res = NPTest->testCmd(
75         "./check_ping -H $host_nonresponsive -w 10,100% -c 10,100% -p 1 -t 1"
76         );
77 is( $res->return_code, 2, "Timeout 1 second - host nonresponsive" );
78 if ($has_timeout) {
79         like( $res->output, '/100%/', "Error contains '100%' string (for 100% packet loss)" );
80 } else {
81         like( $res->output, '/timed out/', "Error contains 'timed out' string" );
82 }
84 $res = NPTest->testCmd(
85         "./check_ping -H $host_nonresponsive -w 10,100% -c 10,100% -p 1 -t 15"
86         );
87 is( $res->return_code, 2, "Timeout 15 seconds - host nonresponsive" );
88 like( $res->output, '/100%/', "Error contains '100%' string (for 100% packet loss)" );
93 $res = NPTest->testCmd(
94         "./check_ping $host_nonresponsive -p 1 -t 1 100 100 1000 10000"
95         );
96 is( $res->return_code, 2, "Old syntax: Timeout - host nonresponsive" );
97 like( $res->output, '/100%/', "Error contains '100%' string (for 100% packet loss)" );
99 $res = NPTest->testCmd(
100         "./check_ping $hostname_invalid 0 0 0 0 -p 1 -t 1"
101         );
102 is( $res->return_code, 3, "Invalid hostname" );
103 like( $res->output, '/invalid hostname/i', "Error contains 'invalid hostname' string");
105 $res = NPTest->testCmd(
106         "./check_ping -w 100,10% -c 200,20%"
107         );
108 is( $res->return_code, 3, "No hostname" );
109 like( $res->output, '/You must specify a server address or host name/', "Output with appropriate error message");