Fix for macsuck in Cisco classes introduced in 3.55 caused by inheritance issue in CiscoStack
This commit is contained in:
2
Changes
2
Changes
@@ -10,6 +10,8 @@ Version 3.57
|
|||||||
|
|
||||||
* IEEE802dot3ad portlist is indexed with a dot1dBasePort, cross reference
|
* IEEE802dot3ad portlist is indexed with a dot1dBasePort, cross reference
|
||||||
with dot1dBasePortIfIndex
|
with dot1dBasePortIfIndex
|
||||||
|
* Fix for macsuck in Cisco classes introduced in 3.55 caused by inheritance
|
||||||
|
issue in CiscoStack
|
||||||
|
|
||||||
Version 3.56 (2018-04-22)
|
Version 3.56 (2018-04-22)
|
||||||
|
|
||||||
|
|||||||
1
MANIFEST
1
MANIFEST
@@ -163,7 +163,6 @@ xt/lib/Test/SNMP/Info/CiscoPortSecurity.pm
|
|||||||
xt/lib/Test/SNMP/Info/CiscoPower.pm
|
xt/lib/Test/SNMP/Info/CiscoPower.pm
|
||||||
xt/lib/Test/SNMP/Info/CiscoQOS.pm
|
xt/lib/Test/SNMP/Info/CiscoQOS.pm
|
||||||
xt/lib/Test/SNMP/Info/CiscoRTT.pm
|
xt/lib/Test/SNMP/Info/CiscoRTT.pm
|
||||||
xt/lib/Test/SNMP/Info/CiscoStack.pm
|
|
||||||
xt/lib/Test/SNMP/Info/CiscoStats.pm
|
xt/lib/Test/SNMP/Info/CiscoStats.pm
|
||||||
xt/lib/Test/SNMP/Info/CiscoStpExtensions.pm
|
xt/lib/Test/SNMP/Info/CiscoStpExtensions.pm
|
||||||
xt/lib/Test/SNMP/Info/CiscoVTP.pm
|
xt/lib/Test/SNMP/Info/CiscoVTP.pm
|
||||||
|
|||||||
@@ -32,9 +32,8 @@ package SNMP::Info::CiscoStack;
|
|||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use Exporter;
|
use Exporter;
|
||||||
use SNMP::Info;
|
|
||||||
|
|
||||||
@SNMP::Info::CiscoStack::ISA = qw/SNMP::Info Exporter/;
|
@SNMP::Info::CiscoStack::ISA = qw/Exporter/;
|
||||||
@SNMP::Info::CiscoStack::EXPORT_OK = qw//;
|
@SNMP::Info::CiscoStack::EXPORT_OK = qw//;
|
||||||
|
|
||||||
use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE %PORTSTAT/;
|
use vars qw/$VERSION %MIBS %FUNCS %GLOBALS %MUNGE %PORTSTAT/;
|
||||||
|
|||||||
@@ -1,182 +0,0 @@
|
|||||||
# Test::SNMP::Info::CiscoStack
|
|
||||||
#
|
|
||||||
# Copyright (c) 2018 Eric Miller
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# Redistribution and use in source and binary forms, with or without
|
|
||||||
# modification, are permitted provided that the following conditions are met:
|
|
||||||
#
|
|
||||||
# * Redistributions of source code must retain the above copyright notice,
|
|
||||||
# this list of conditions and the following disclaimer.
|
|
||||||
# * Redistributions in binary form must reproduce the above copyright
|
|
||||||
# notice, this list of conditions and the following disclaimer in the
|
|
||||||
# documentation and/or other materials provided with the distribution.
|
|
||||||
# * Neither the name of the University of California, Santa Cruz nor the
|
|
||||||
# names of its contributors may be used to endorse or promote products
|
|
||||||
# derived from this software without specific prior written permission.
|
|
||||||
#
|
|
||||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
||||||
# LIABLE FOR # ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
||||||
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
||||||
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
||||||
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
||||||
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
||||||
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
||||||
# POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
package Test::SNMP::Info::CiscoStack;
|
|
||||||
|
|
||||||
use Test::Class::Most parent => 'My::Test::Class';
|
|
||||||
|
|
||||||
use SNMP::Info::CiscoStack;
|
|
||||||
|
|
||||||
sub setup : Tests(setup) {
|
|
||||||
my $test = shift;
|
|
||||||
$test->SUPER::setup;
|
|
||||||
|
|
||||||
# Start with a common cache that will serve most tests
|
|
||||||
my $cache_data = {
|
|
||||||
# Doesn't matter to our code, but serial1 defined as and integer in MIB,
|
|
||||||
# while serial2 is a string. Formatting from snmp walks although
|
|
||||||
# actual value modified to not use real serial #'s
|
|
||||||
'_serial1' => '12345678',
|
|
||||||
'_serial2' => 'ABC1234D56E',
|
|
||||||
'_p_port' => 1,
|
|
||||||
'_p_duplex' => 1,
|
|
||||||
'_p_duplex_admin' => 1,
|
|
||||||
'_p_speed' => 1,
|
|
||||||
'store' => {
|
|
||||||
'p_port' => {'0.1' => 2, '0.2' => 3, '0.3' => 4, '2.1' => 26},
|
|
||||||
'p_duplex' =>
|
|
||||||
{'0.1' => 'auto', '0.2' => 'half', '0.3' => 'full', '2.1' => 'auto'},
|
|
||||||
'p_duplex_admin' => {
|
|
||||||
'0.1' => pack("H*", 'E0'),
|
|
||||||
'0.2' => pack("H*", 'E0'),
|
|
||||||
'0.3' => pack("H*", 'E0'),
|
|
||||||
'2.1' => pack("H*", '00'),
|
|
||||||
},
|
|
||||||
'p_speed' => {
|
|
||||||
'0.1' => 'autoDetect',
|
|
||||||
'0.2' => 's100000000',
|
|
||||||
'0.3' => 's100000000',
|
|
||||||
'2.1' => 'autoDetect',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
$test->{info}->cache($cache_data);
|
|
||||||
}
|
|
||||||
|
|
||||||
sub munge_port_status : Tests(4) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'munge_port_status');
|
|
||||||
|
|
||||||
my $expected = 'other ok minorFault majorFault';
|
|
||||||
is(SNMP::Info::CiscoStack::munge_port_status(pack("H*", '01020304')),
|
|
||||||
$expected, q(Munges statuses to aggregate string));
|
|
||||||
|
|
||||||
# Not sure this is what we really want, but this is how code is
|
|
||||||
# written
|
|
||||||
is(SNMP::Info::CiscoStack::munge_port_status(pack("H*", '0506')),
|
|
||||||
' ', q(Unknown statuses returns space));
|
|
||||||
is(SNMP::Info::CiscoStack::munge_port_status(),
|
|
||||||
'', q(Empty arg returns empty string));
|
|
||||||
}
|
|
||||||
|
|
||||||
sub serial : Tests(4) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'serial');
|
|
||||||
is($test->{info}->serial(), '12345678', q(Serial returns 'serial1' first));
|
|
||||||
|
|
||||||
delete $test->{info}{_serial1};
|
|
||||||
is($test->{info}->serial(), 'ABC1234D56E', q(Serial returns 'serial2' next));
|
|
||||||
|
|
||||||
delete $test->{info}{_serial2};
|
|
||||||
is($test->{info}->serial(), undef, q(Serial returns undef with no data));
|
|
||||||
}
|
|
||||||
|
|
||||||
sub i_duplex : Tests(3) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'i_duplex');
|
|
||||||
|
|
||||||
my $expected = {3 => 'half', 4 => 'full', 26 => 'full'};
|
|
||||||
cmp_deeply($test->{info}->i_duplex(),
|
|
||||||
$expected, q(Interfaces have expected duplex values));
|
|
||||||
|
|
||||||
$test->{info}->clear_cache();
|
|
||||||
cmp_deeply($test->{info}->i_duplex(),
|
|
||||||
{}, q(No duplex data returns empty hash));
|
|
||||||
}
|
|
||||||
|
|
||||||
sub i_duplex_admin : Tests(3) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'i_duplex_admin');
|
|
||||||
|
|
||||||
my $expected = {2 => 'auto', 3 => 'half', 4 => 'full', 26 => 'full'};
|
|
||||||
cmp_deeply($test->{info}->i_duplex_admin(),
|
|
||||||
$expected,
|
|
||||||
q(Interfaces have expected duplex admin values));
|
|
||||||
|
|
||||||
$test->{info}->clear_cache();
|
|
||||||
cmp_deeply($test->{info}->i_duplex_admin(),
|
|
||||||
{}, q(No duplex admin data returns empty hash));
|
|
||||||
}
|
|
||||||
|
|
||||||
sub i_speed_admin : Tests(3) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'i_speed_admin');
|
|
||||||
|
|
||||||
my $expected = {2 => 'auto', 3 => '100 Mbps', 4 => '100 Mbps', 26 => 'auto'};
|
|
||||||
|
|
||||||
cmp_deeply($test->{info}->i_speed_admin(),
|
|
||||||
$expected, q(Interfaces have expected speed admin values));
|
|
||||||
|
|
||||||
$test->{info}->clear_cache();
|
|
||||||
cmp_deeply($test->{info}->i_speed_admin(),
|
|
||||||
{}, q(No speed admin data returns empty hash));
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_i_speed_admin : Tests(3) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'set_i_speed_admin');
|
|
||||||
|
|
||||||
is($test->{info}->set_i_speed_admin('100', 2),
|
|
||||||
1, q(Mock set speed call succeeded));
|
|
||||||
|
|
||||||
is($test->{info}->set_i_speed_admin('auto-x', 2),
|
|
||||||
0, q(Mock set speed call to bad speed 'auto-x' fails));
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_i_duplex_admin : Tests(3) {
|
|
||||||
my $test = shift;
|
|
||||||
|
|
||||||
# Set method uses a partial fetch which ignores the cache and reloads data
|
|
||||||
# therefore we must use the mocked session.
|
|
||||||
my $data = {
|
|
||||||
'EtherLike-MIB::dot3StatsDuplexStatus' => {
|
|
||||||
'1' => 'fullDuplex',
|
|
||||||
'2' => 'halfDuplex',
|
|
||||||
'3' => 'fullDuplex',
|
|
||||||
'26' => 'fullDuplex'
|
|
||||||
},
|
|
||||||
};
|
|
||||||
$test->{info}{sess}{Data} = $data;
|
|
||||||
|
|
||||||
can_ok($test->{info}, 'set_i_duplex_admin');
|
|
||||||
|
|
||||||
is($test->{info}->set_i_duplex_admin('full', 2),
|
|
||||||
1, q(Mock set duplex call succeeded));
|
|
||||||
|
|
||||||
is($test->{info}->set_i_duplex_admin('full-x', 2),
|
|
||||||
0, q(Mock set duplex call to bad duplex type 'full-x' fails));
|
|
||||||
}
|
|
||||||
|
|
||||||
1;
|
|
||||||
Reference in New Issue
Block a user