Code

Test for new functionality in negate (not automatically run in make test)
authorTon Voon <tonvoon@users.sourceforge.net>
Thu, 24 May 2007 08:53:50 +0000 (08:53 +0000)
committerTon Voon <tonvoon@users.sourceforge.net>
Thu, 24 May 2007 08:53:50 +0000 (08:53 +0000)
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1717 f882894a-f735-0410-b71e-b25c423dba1c

plugins/t/negate.pl [new file with mode: 0644]

diff --git a/plugins/t/negate.pl b/plugins/t/negate.pl
new file mode 100644 (file)
index 0000000..6c56d4f
--- /dev/null
@@ -0,0 +1,48 @@
+#! /usr/bin/perl -w -I ..
+#
+# negate checks
+# Need check_dummy to work for testing
+#
+# $Id$
+#
+
+use strict;
+use Test::More;
+use NPTest;
+
+plan tests => 40;
+
+my $res;
+
+$res = NPTest->testCmd( "./negate" );
+is( $res->return_code, 3, "Not enough parameters");
+like( $res->output, "/Could not parse arguments/", "Could not parse arguments");
+
+$res = NPTest->testCmd( "./negate ./check_dummy 0 'a dummy okay'" );
+is( $res->return_code, 2, "OK changed to CRITICAL" );
+is( $res->output, "OK: a dummy okay" );
+
+$res = NPTest->testCmd( "./negate './check_dummy 0 redsweaterblog'");
+is( $res->return_code, 2, "OK => CRIT with a single quote for command to run" );
+is( $res->output, "OK: redsweaterblog" );
+
+$res = NPTest->testCmd( "./negate ./check_dummy 1 'a warn a day keeps the managers at bay'" );
+is( $res->return_code, 2, "WARN stays same" );
+
+$res = NPTest->testCmd( "./negate ./check_dummy 3 mysterious");
+is( $res->return_code, 3, "UNKNOWN stays same" );
+
+my %state = (
+       ok => 0,
+       warning => 1,
+       critical => 2,
+       unknown => 3,
+       );
+foreach my $current_state (qw(ok warning critical unknown)) {
+       foreach my $new_state (qw(ok warning critical unknown)) {
+               $res = NPTest->testCmd( "./negate --$current_state=$new_state ./check_dummy ".$state{$current_state}." 'Fake $new_state'" );
+               is( $res->return_code, $state{$new_state}, "Got fake $new_state" );
+               is( $res->output, uc($current_state).": Fake $new_state" );
+       }
+}
+