From a312bd580644ed213fd34f70b80cca2fffa9c83c Mon Sep 17 00:00:00 2001 From: Kristofer Hallin Date: Fri, 20 May 2022 15:59:56 +0200 Subject: [PATCH] Test all fields in an ifTable with only single entry, disabled for now. --- test/test_snmp_ifmib.sh | 174 +++++++++++++++++++++++++++++++++------- 1 file changed, 143 insertions(+), 31 deletions(-) diff --git a/test/test_snmp_ifmib.sh b/test/test_snmp_ifmib.sh index b12b4e65..0d24b7ec 100755 --- a/test/test_snmp_ifmib.sh +++ b/test/test_snmp_ifmib.sh @@ -54,42 +54,103 @@ EOF # This is state data written to file that backend reads from (on request) # integer and string have values, sleeper does not and uses default (=1) -cat < $fstate - - - 42 - - This is not default - - + +if false; then + cat < $fstate + + 1 + + 0 + 0 + + + + 1 + Test + softwareLoopback + 1500 + 10000000 + aa:bb:cc:dd:ee:ff + 1 + 1 + 1:0:00:00.00 + 123 + 123 + 123 + 123 + 123 + 123 + 123 + 123 + 123 + 0 + SNMPv2-SMI::zeroDotZero + + + EOF +else + cat < $fstate + + + 42 + + This is not default + + +EOF +fi +# This is the expected result from snmpwalk: +# $ snmpwalk -cpublic -v2c localhost IF-MIB::ifTable +# IF-MIB::ifIndex.1 = INTEGER: 1 +# IF-MIB::ifDescr.1 = STRING: Test +# IF-MIB::ifType.1 = INTEGER: ethernetCsmacd(6) +# IF-MIB::ifMtu.1 = INTEGER: 1500 +# IF-MIB::ifSpeed.1 = Gauge32: 10000000 +# IF-MIB::ifPhysAddress.1 = STRING: aa:bb:cc:dd:ee:ff +# IF-MIB::ifAdminStatus.1 = INTEGER: up(1) +# IF-MIB::ifOperStatus.1 = INTEGER: up(1) +# IF-MIB::ifLastChange.1 = Timeticks: (0) 0:00:00.00 +# IF-MIB::ifInOctets.1 = Counter32: 123 +# IF-MIB::ifInUcastPkts.1 = Counter32: 123 +# IF-MIB::ifInNUcastPkts.1 = Counter32: 123 +# IF-MIB::ifInDiscards.1 = Counter32: 123 +# IF-MIB::ifInErrors.1 = Counter32: 123 +# IF-MIB::ifInUnknownProtos.1 = Counter32: 123 +# IF-MIB::ifOutOctets.1 = Counter32: 123 +# IF-MIB::ifOutUcastPkts.1 = Counter32: 123 +# IF-MIB::ifOutNUcastPkts.1 = Counter32: 123 +# IF-MIB::ifOutDiscards.1 = Counter32: 123 +# IF-MIB::ifOutErrors.1 = Counter32: 123 +# IF-MIB::ifOutQLen.1 = Gauge32: 123 +# IF-MIB::ifSpecific.1 = OID: SNMPv2-SMI::zeroDotZero function testinit(){ new "test params: -f $cfg -- -sS $fstate" if [ $BE -ne 0 ]; then - # Kill old backend and start a new one - new "kill old backend" - sudo clixon_backend -zf $cfg - if [ $? -ne 0 ]; then - err "Failed to start backend" - fi + # Kill old backend and start a new one + new "kill old backend" + sudo clixon_backend -zf $cfg + if [ $? -ne 0 ]; then + err "Failed to start backend" + fi - sudo pkill -f clixon_backend + sudo pkill -f clixon_backend - new "Starting backend" - start_backend -s init -f $cfg -- -sS $fstate + new "Starting backend" + start_backend -s init -f $cfg -- -sS $fstate fi new "wait backend" wait_backend - - if [ $CS -ne 0 ]; then - # Kill old clixon_snmp, if any - new "Terminating any old clixon_snmp processes" - sudo killall -q clixon_snmp - new "Starting clixon_snmp" - start_snmp $cfg & + if [ $CS -ne 0 ]; then + # Kill old clixon_snmp, if any + new "Terminating any old clixon_snmp processes" + sudo killall -q clixon_snmp + + new "Starting clixon_snmp" + start_snmp $cfg & fi new "wait snmp" @@ -103,15 +164,66 @@ function testexit(){ new "SNMP tests" testinit -# IF-MIB::interfaces -MIB=".1.3.6.1.2.1" -OID1="${MIB}.2.1.0" # XXX interfaces -OID2="${MIB}.31" # ifMIB +if false; then + # IF-MIB::interfaces + MIB=".1.3.6.1.2.1" + OID1="${MIB}.2.2.1.1.1" + OID2="${MIB}.2.2.1.2.1" + OID3="${MIB}.2.2.1.3.1" + OID4="${MIB}.2.2.1.4.1" + OID5="${MIB}.2.2.1.5.1" + OID6="${MIB}.2.2.1.6.1" + OID7="${MIB}.2.2.1.7.1" + OID8="${MIB}.2.2.1.8.1" + OID9="${MIB}.2.2.1.9.1" + OID10="${MIB}.2.2.1.10.1" + OID11="${MIB}.2.2.1.11.1" + OID12="${MIB}.2.2.1.12.1" + OID13="${MIB}.2.2.1.13.1" + OID14="${MIB}.2.2.1.14.1" + OID15="${MIB}.2.2.1.15.1" + OID16="${MIB}.2.2.1.16.1" + OID17="${MIB}.2.2.1.17.1" + OID18="${MIB}.2.2.1.18.1" + OID19="${MIB}.2.2.1.19.1" + OID20="${MIB}.2.2.1.20.1" + OID21="${MIB}.2.2.1.21.1" + OID22="${MIB}.2.2.1.22.1" -new "$snmpget" + new "$snmpget" -new "Test SNMP get int" -expectpart "$($snmpget $OID1)" 0 "$OID1 = INTEGER: " # XXX Just to get it thru the test + new "Test SNMP get on all entries in ifTable" + expectpart "$($snmpget $OID1)" 0 "$OID1 = INTEGER: 1" + expectpart "$($snmpget $OID2)" 0 "$OID2 = STRING: Test" + expectpart "$($snmpget $OID3)" 0 "$OID3 = INTEGER: ethernetCsmacd(6)" + expectpart "$($snmpget $OID4)" 0 "$OID4 = INTEGER: 1500" + expectpart "$($snmpget $OID5)" 0 "$OID5 = Gauge32: 10000000" + expectpart "$($snmpget $OID6)" 0 "$OID6 = STRING: aa.bb:cc:dd:ee:ff" + expectpart "$($snmpget $OID7)" 0 "$OID7 = INTEGER: up(1)" + expectpart "$($snmpget $OID8)" 0 "$OID8 = INTEGER: up(1)" + expectpart "$($snmpget $OID9)" 0 "$OID9 = Timeticks: (0) 0:00:00.00" + expectpart "$($snmpget $OID10)" 0 "$OID10 = Counter32: 123" + expectpart "$($snmpget $OID11)" 0 "$OID11 = Counter32: 123" + expectpart "$($snmpget $OID12)" 0 "$OID12 = Counter32: 123" + expectpart "$($snmpget $OID13)" 0 "$OID13 = Counter32: 123" + expectpart "$($snmpget $OID14)" 0 "$OID14 = Counter32: 123" + expectpart "$($snmpget $OID15)" 0 "$OID15 = Counter32: 123" + expectpart "$($snmpget $OID16)" 0 "$OID16 = Counter32: 123" + expectpart "$($snmpget $OID17)" 0 "$OID17 = Counter32: 123" + expectpart "$($snmpget $OID18)" 0 "$OID18 = Counter32: 123" + expectpart "$($snmpget $OID19)" 0 "$OID19 = Counter32: 123" + expectpart "$($snmpget $OID20)" 0 "$OID20 = Counter32: 123" + expectpart "$($snmpget $OID21)" 0 "$OID21 = Gauge32: 123" + expectpart "$($snmpget $OID22)" 0 "$OID22 = OID: SNMPv2-SMI::zeroDotZero" +else + MIB=".1.3.6.1.2.1" + OID1="${MIB}.2.1.0" # XXX interfaces + + new "$snmpget" + + new "Test SNMP get int" + expectpart "$($snmpget $OID1)" 0 "$OID1 = INTEGER: " # XXX Just to get it thru the test +fi new "Cleaning up" testexit