[nagiosplug] check_dhcp test: skip subtests if no variable is ...

Nagios Plugin Development nagios-plugins at users.sourceforge.net
Mon Sep 16 09:00:11 CEST 2013


 Module: nagiosplug
 Branch: master
 Commit: 095e2e5db52ff5ff60eb319099d047c7c060d800
 Author: Sven Nierlein <sven at nierlein.de>
   Date: Mon Sep 16 08:51:04 2013 +0200
    URL: http://nagiosplug.git.sf.net/git/gitweb.cgi?p=nagiosplug/nagiosplug;a=commit;h=095e2e5

check_dhcp test: skip subtests if no variable is set

---

 plugins-root/t/check_dhcp.t |   55 +++++++++++++++++++++++++++---------------
 1 files changed, 35 insertions(+), 20 deletions(-)

diff --git a/plugins-root/t/check_dhcp.t b/plugins-root/t/check_dhcp.t
index 1f7c518..a7ce1e2 100644
--- a/plugins-root/t/check_dhcp.t
+++ b/plugins-root/t/check_dhcp.t
@@ -8,42 +8,57 @@ use Test::More;
 use NPTest;
 
 my $allow_sudo = getTestParameter( "NP_ALLOW_SUDO",
-	"If sudo is setup for this user to run any command as root ('yes' to allow)",
-	"no" );
+                                   "If sudo is setup for this user to run any command as root ('yes' to allow)",
+                                   "no" );
 
 if ($allow_sudo eq "yes" or $> == 0) {
-	plan tests => 4;
+    plan tests => 6;
 } else {
-	plan skip_all => "Need sudo to test check_dhcp";
+    plan skip_all => "Need sudo to test check_dhcp";
 }
 my $sudo = $> == 0 ? '' : 'sudo';
 
 my $successOutput = '/OK: Received \d+ DHCPOFFER\(s\), \d+ of 1 requested servers responded, max lease time = \d+ sec\./';
 my $failureOutput = '/CRITICAL: Received \d+ DHCPOFFER\(s\), 0 of \d+ requested servers responded/';
+my $invalidOutput = '/Invalid hostname/';
 
 my $host_responsive    = getTestParameter( "NP_HOST_DHCP_RESPONSIVE",
-				"The hostname of system responsive to dhcp requests",
-				"localhost" );
+                                           "The hostname of system responsive to dhcp requests",
+                                           "localhost" );
 
 my $host_nonresponsive = getTestParameter( "NP_HOST_NONRESPONSIVE",
-				"The hostname of system not responsive to dhcp requests",
-				"10.0.0.1" );
+                                           "The hostname of system not responsive to dhcp requests",
+                                           "10.0.0.1" );
 
 my $hostname_invalid   = getTestParameter( "NP_HOSTNAME_INVALID",
-                                "An invalid (not known to DNS) hostname",
-				"nosuchhost" );
+                                           "An invalid (not known to DNS) hostname",
+                                           "nosuchhost" );
 
 my $res;
 
-$res = NPTest->testCmd(
-	"$sudo ./check_dhcp -s $host_responsive"
-	);
-is( $res->return_code, 0, "Syntax ok" );
-like( $res->output, $successOutput, "Output OK" );
+SKIP: {
+    skip('need responsive test host', 2) unless $host_responsive;
+    $res = NPTest->testCmd(
+        "$sudo ./check_dhcp -s $host_responsive"
+    );
+    is( $res->return_code, 0, "Syntax ok" );
+    like( $res->output, $successOutput, "Output OK" );
+};
 
-$res = NPTest->testCmd(
-	"$sudo ./check_dhcp -s $host_nonresponsive"
-	);
-is( $res->return_code, 2, "Timeout - host nonresponsive" );
-like( $res->output, $failureOutput, "Output OK" );
+SKIP: {
+    skip('need nonresponsive test host', 2) unless $host_nonresponsive;
+    $res = NPTest->testCmd(
+        "$sudo ./check_dhcp -s $host_nonresponsive"
+    );
+    is( $res->return_code, 2, "Exit code - host nonresponsive" );
+    like( $res->output, $failureOutput, "Output OK" );
+};
 
+SKIP: {
+    skip('need invalid test host', 2) unless $hostname_invalid;
+    $res = NPTest->testCmd(
+        "$sudo ./check_dhcp -s $hostname_invalid"
+    );
+    is( $res->return_code, 3, "Exit code - host invalid" );
+    like( $res->output, $invalidOutput, "Output OK" );
+};





More information about the Commits mailing list