require 'snmpjr' require 'snmpjr/response' require 'snmpjr/session_v3' describe "snmpjr for snmp v3" do describe 'GET' do subject { Snmpjr.new(Snmpjr::Version::V3) } context 'when the host is reachable' do before do subject.configure do |config| config.host = 'demo.snmplabs.com' config.user = 'usr-sha-aes128' config.authentication 'SHA', 'authkey1' config.privacy 'AES128', 'privkey1' end end it 'can perform a simple synchronous get request on an snmp agent' do expect(subject.get '1.3.6.1.2.1.1.1.0').to eq Snmpjr::Response.new(oid: '1.3.6.1.2.1.1.1.0', value: 'SunOS zeus.snmplabs.com 4.1.3_U1 1 sun4m', type: 'OCTET STRING') end let(:expected) { [Snmpjr::Response.new(oid: '1.3.6.1.2.1.1.1.0', value: 'SunOS zeus.snmplabs.com 4.1.3_U1 1 sun4m', type: 'OCTET STRING'), Snmpjr::Response.new(oid: '1.3.6.1.2.1.1.5.0', value: 'zeus.snmplabs.com', type: 'OCTET STRING'), Snmpjr::Response.new(oid: '1.3.6.1.2.1.1.7.0', value: '72', type: 'Integer32')] } it 'can perform a series of gets if passed an array of oids' do expect(subject.get ['1.3.6.1.2.1.1.1.0', '1.3.6.1.2.1.1.5.0', '1.3.6.1.2.1.1.7.0']).to eq expected end context "when an invalid oid is requested" do before do subject.configure do |config| config.host = 'demo.snmplabs.com' config.user = 'usr-sha-des' config.authentication 'SHA', 'authkey1' config.privacy 'DES', 'privkey1' end end let(:expected) { [Snmpjr::Response.new(oid: '1.3.6.1.2.1.1.5', error: 'noSuchInstance'), Snmpjr::Response.new(oid: '1.3.6.1.2.1.1.5.0', value: 'zeus.snmplabs.com', type: 'OCTET STRING')] } it 'returns an error' do expect(subject.get ['1.3.6.1.2.1.1.5', '1.3.6.1.2.1.1.5.0']).to eq expected end end end context 'when the host is unreachable' do before do subject.configure do |config| config.host = 'demo.snmplabs.com' config.port = 161 config.user = 'usr-sha-des' config.authentication 'SHA', 'authkey1' config.timeout = 50 end end it 'the request times out after 5 seconds' do expect{ subject.get '1.3.6.1.2.1.1.1.0' }.to raise_error(Snmpjr::TargetTimeoutError) end end end end