diff options
author | Jacob Hansen <jhansen@op5.com> | 2021-05-19 13:13:47 +0200 |
---|---|---|
committer | Jacob Hansen <jhansen@op5.com> | 2021-05-19 13:36:04 +0200 |
commit | 0bbcb60f02d6f78561f684adb0294870a3522e4f (patch) | |
tree | d9ce1ec175d2b75280a08754a75191ad5d05ef94 | |
parent | 227369bb3bec2a44ebece952a9085bfb032a7a0e (diff) | |
download | monitoring-plugins-0bbcb60f02d6f78561f684adb0294870a3522e4f.tar.gz |
Refactor check_fping
* Set correct amount of tests based on conditionals.
* When running the test as non-root, we would previously check is the
setuid bit is set. This doesn't seem to be needed, so just check if the
binary is executable for the user running the test.
* Use cmp_ok to check if tests succeeds rather than couting.
Signed-off-by: Jacob Hansen <jhansen@op5.com>
-rw-r--r-- | plugins/t/check_fping.t | 29 |
1 files changed, 14 insertions, 15 deletions
diff --git a/plugins/t/check_fping.t b/plugins/t/check_fping.t index 03a6110e..67b357b2 100644 --- a/plugins/t/check_fping.t +++ b/plugins/t/check_fping.t | |||
@@ -5,31 +5,30 @@ | |||
5 | # | 5 | # |
6 | 6 | ||
7 | use strict; | 7 | use strict; |
8 | use Test; | 8 | use Test::More; |
9 | use NPTest; | 9 | use NPTest; |
10 | 10 | ||
11 | use vars qw($tests); | ||
12 | |||
13 | BEGIN {$tests = 4; plan tests => $tests} | ||
14 | |||
15 | my $host_responsive = getTestParameter("NP_HOST_RESPONSIVE", "The hostname of system responsive to network requests", "localhost"); | 11 | my $host_responsive = getTestParameter("NP_HOST_RESPONSIVE", "The hostname of system responsive to network requests", "localhost"); |
16 | my $host_nonresponsive = getTestParameter("NP_HOST_NONRESPONSIVE", "The hostname of system not responsive to network requests", "10.0.0.1"); | 12 | my $host_nonresponsive = getTestParameter("NP_HOST_NONRESPONSIVE", "The hostname of system not responsive to network requests", "10.0.0.1"); |
17 | my $hostname_invalid = getTestParameter("NP_HOSTNAME_INVALID", "An invalid (not known to DNS) hostname", "nosuchhost"); | 13 | my $hostname_invalid = getTestParameter("NP_HOSTNAME_INVALID", "An invalid (not known to DNS) hostname", "nosuchhost"); |
18 | 14 | ||
19 | my $t; | 15 | my $res; |
20 | 16 | ||
21 | my $fping = qx(which fping 2> /dev/null); | 17 | my $fping = qx(which fping 2> /dev/null); |
22 | chomp($fping); | 18 | chomp($fping); |
23 | if( ! -x "./check_fping") { | 19 | if( ! -x "./check_fping") { |
24 | $t += skipMissingCmd( "./check_fping", $tests ); | 20 | plan skip_all => "check_fping not found, skipping tests"; |
25 | } | 21 | } |
26 | elsif ( $> != 0 && (!$fping || ! -u $fping)) { | 22 | elsif ( !$fping || !-x $fping ) { |
27 | $t += skipMsg( "./check_fping", $tests ); | 23 | plan skip_all => "fping not found or cannot be executed, skipping tests"; |
28 | } else { | 24 | } else { |
29 | $t += checkCmd( "./check_fping $host_responsive", 0, '/^FPING OK - /' ); | 25 | plan tests => 3; |
30 | $t += checkCmd( "./check_fping $host_nonresponsive", 2, '/^FPING CRITICAL - /' ); | 26 | $res = NPTest->testCmd( "./check_fping $host_responsive" ); |
31 | $t += checkCmd( "./check_fping $hostname_invalid", 3, '/^FPING UNKNOWN - /' ); | 27 | cmp_ok( $res->return_code, '==', 0, "Responsive host returns OK"); |
32 | } | ||
33 | 28 | ||
34 | exit(0) if defined($Test::Harness::VERSION); | 29 | $res = NPTest->testCmd( "./check_fping $host_nonresponsive" ); |
35 | exit($tests - $t); | 30 | cmp_ok( $res->return_code, '==', 2, "Non-Responsive host returns Critical"); |
31 | |||
32 | $res = NPTest->testCmd( "./check_fping $hostname_invalid" ); | ||
33 | cmp_ok( $res->return_code, '==', 3, "Invalid host returns Unknown"); | ||
34 | } | ||