summaryrefslogtreecommitdiffstats
path: root/plugins/tests/check_snmp.t
diff options
context:
space:
mode:
authornagios <nagios@opsviewdev32.(none)>2010-11-15 15:43:41 +0000
committernagios <nagios@opsviewdev32.(none)>2010-11-15 15:43:41 +0000
commit896962a1ad1b7d7c75d42c565b06cc799feb0a7c (patch)
tree12723ac6ebc1f99109a03a938602a4719a0622e5 /plugins/tests/check_snmp.t
parente7ac2e68c9524ffed4046559fef0b545785e64a0 (diff)
downloadmonitoring-plugins-896962a1ad1b7d7c75d42c565b06cc799feb0a7c.tar.gz
check_snmp now considers strings returned by SNMP that contain just
numbers (according to strtod) to be a numeric value for threshold and performance data
Diffstat (limited to 'plugins/tests/check_snmp.t')
-rwxr-xr-xplugins/tests/check_snmp.t17
1 files changed, 16 insertions, 1 deletions
diff --git a/plugins/tests/check_snmp.t b/plugins/tests/check_snmp.t
index e7ad1927..08348d23 100755
--- a/plugins/tests/check_snmp.t
+++ b/plugins/tests/check_snmp.t
@@ -51,7 +51,7 @@ if ($ARGV[0] && $ARGV[0] eq "-d") {
51 } 51 }
52} 52}
53 53
54my $tests = 33; 54my $tests = 41;
55if (-x "./check_snmp") { 55if (-x "./check_snmp") {
56 plan tests => $tests; 56 plan tests => $tests;
57} else { 57} else {
@@ -170,5 +170,20 @@ $res = NPTest->testCmd( "./check_snmp -H 127.0.0.1 -C public -p $port_snmp -o .1
170is($res->return_code, 0, "OK as string doesn't match but inverted" ); 170is($res->return_code, 0, "OK as string doesn't match but inverted" );
171is($res->output, 'SNMP OK - "stringtests" | ', "OK as inverted string no match" ); 171is($res->output, 'SNMP OK - "stringtests" | ', "OK as inverted string no match" );
172 172
173$res = NPTest->testCmd( "./check_snmp -H 127.0.0.1 -C public -p $port_snmp -o .1.3.6.1.4.1.8072.3.2.67.12" );
174is($res->return_code, 0, "Numeric in string test" );
175is($res->output, 'SNMP OK - 3.5 | iso.3.6.1.4.1.8072.3.2.67.12=3.5 ', "Check seen as numeric" );
176
177$res = NPTest->testCmd( "./check_snmp -H 127.0.0.1 -C public -p $port_snmp -o .1.3.6.1.4.1.8072.3.2.67.12 -w 4:5" );
178is($res->return_code, 1, "Numeric in string test" );
179is($res->output, 'SNMP WARNING - *3.5* | iso.3.6.1.4.1.8072.3.2.67.12=3.5 ', "WARNING threshold checks for string masquerading as number" );
180
181$res = NPTest->testCmd( "./check_snmp -H 127.0.0.1 -C public -p $port_snmp -o .1.3.6.1.4.1.8072.3.2.67.13" );
182is($res->return_code, 0, "Not really numeric test" );
183is($res->output, 'SNMP OK - "87.4startswithnumberbutshouldbestring" | ', "Check string with numeric start is still string" );
184
185$res = NPTest->testCmd( "./check_snmp -H 127.0.0.1 -C public -p $port_snmp -o .1.3.6.1.4.1.8072.3.2.67.14" );
186is($res->return_code, 0, "Not really numeric test (trying best to fool it)" );
187is($res->output, 'SNMP OK - "555\"I said\"" | ', "Check string with a double quote following is still a string (looks like the perl routine will always escape though)" );
173 188
174 189