Correct regex validator in mau_set_i_speed_admin() and mau_set_i_duplex_admin()
Correct IID/key used in mau_set_i_speed_admin() and mau_set_i_duplex_admin() Add MAU test class
This commit is contained in:
@@ -277,7 +277,7 @@ sub mau_set_i_speed_admin {
|
||||
my $rv;
|
||||
|
||||
$speed = lc($speed);
|
||||
if ( !( $speed =~ /(10|100|1000|auto)/io and $iid =~ /\d+/o ) ) {
|
||||
if ( !( $speed =~ /^(10|100|1000|auto)$/i and $iid =~ /\d+/ ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -298,7 +298,7 @@ sub mau_set_i_speed_admin {
|
||||
my $myduplex;
|
||||
|
||||
my $i_mau_def_type
|
||||
= &SNMP::translateObj( $mau->mau_type_admin($iid)->{ $iid . '.1' } );
|
||||
= &SNMP::translateObj( $mau->mau_type_admin($key)->{ $key } );
|
||||
|
||||
if ( $i_mau_def_type =~ /^dot3MauType.*Base.*(..)$/
|
||||
&& ( $1 eq "HD" or $1 eq "FD" ) )
|
||||
@@ -315,17 +315,17 @@ sub mau_set_i_speed_admin {
|
||||
return (1);
|
||||
}
|
||||
elsif ( $speed eq "auto" ) {
|
||||
$rv = $mau->set_mau_autostat( 'enabled', $iid . '.1' );
|
||||
$rv = $mau->set_mau_autostat( 'enabled', $key );
|
||||
return ($rv);
|
||||
}
|
||||
else {
|
||||
if ( $i_autoneg eq "enabled" ) {
|
||||
$mau->set_mau_autostat( 'disabled', $iid . '.1' );
|
||||
$mau->set_mau_autostat( 'disabled', $key );
|
||||
}
|
||||
$rv
|
||||
= $mau->set_mau_type_admin(
|
||||
'.1.3.6.1.2.1.26.4.' . $speeds{$myduplex}{$speed},
|
||||
$iid . '.1' );
|
||||
$key );
|
||||
|
||||
return ($rv);
|
||||
}
|
||||
@@ -340,7 +340,7 @@ sub mau_set_i_duplex_admin {
|
||||
|
||||
$duplex = lc($duplex);
|
||||
|
||||
if ( !( $duplex =~ /(full|half|auto)/i and $iid =~ /\d+/ ) ) {
|
||||
if ( !( $duplex =~ /^(full|half|auto)$/i and $iid =~ /\d+/ ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -356,7 +356,7 @@ sub mau_set_i_duplex_admin {
|
||||
my $i_autoneg = $myhash->{$key};
|
||||
|
||||
my $i_speed
|
||||
= &SNMP::translateObj( $mau->mau_type_admin($iid)->{ $iid . '.1' } );
|
||||
= SNMP::translateObj( $mau->mau_type_admin($key)->{ $key } );
|
||||
|
||||
if ( $i_speed =~ /^dot3MauType(.*)Base/ && $_mau_i_speed_map{$1} ) {
|
||||
$i_speed = $1;
|
||||
@@ -371,7 +371,7 @@ sub mau_set_i_duplex_admin {
|
||||
return (1);
|
||||
}
|
||||
elsif ( $duplex eq "auto" ) {
|
||||
$rv = $mau->set_mau_autostat( 'enabled', $iid . '.1' );
|
||||
$rv = $mau->set_mau_autostat( 'enabled', $key );
|
||||
return ($rv);
|
||||
}
|
||||
else {
|
||||
@@ -380,12 +380,12 @@ sub mau_set_i_duplex_admin {
|
||||
if ( $i_autoneg eq "enabled"
|
||||
&& defined( $duplexes{$i_speed}{$duplex} ) )
|
||||
{
|
||||
$mau->set_mau_autostat( 'disabled', $iid . '.1' );
|
||||
$mau->set_mau_autostat( 'disabled', $key );
|
||||
}
|
||||
$rv
|
||||
= $mau->set_mau_type_admin(
|
||||
'.1.3.6.1.2.1.26.4.' . $duplexes{$i_speed}{$duplex},
|
||||
$iid . '.1' );
|
||||
$key );
|
||||
return ($rv);
|
||||
}
|
||||
}
|
||||
|
||||
176
xt/lib/Test/SNMP/Info/MAU.pm
Normal file
176
xt/lib/Test/SNMP/Info/MAU.pm
Normal file
@@ -0,0 +1,176 @@
|
||||
# Test::SNMP::Info::MAU
|
||||
#
|
||||
# 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::MAU;
|
||||
|
||||
use Test::Class::Most parent => 'My::Test::Class';
|
||||
|
||||
use SNMP::Info::MAU;
|
||||
|
||||
# Remove this startup override once we have full method coverage
|
||||
sub startup : Tests(startup => 1) {
|
||||
my $test = shift;
|
||||
$test->SUPER::startup();
|
||||
|
||||
$test->todo_methods(1);
|
||||
}
|
||||
|
||||
sub setup : Tests(setup) {
|
||||
my $test = shift;
|
||||
$test->SUPER::setup;
|
||||
|
||||
# Start with a common cache that will serve most tests
|
||||
my $cache_data = {
|
||||
'_mau_index' => 1,
|
||||
'_mau_autostat' => 1,
|
||||
'_mau_type_admin' => 1,
|
||||
'store' => {
|
||||
'fan_state' => {
|
||||
101 => 'normal',
|
||||
102 => 'warning',
|
||||
103 => 'notPresent',
|
||||
201 => 'shutdown',
|
||||
202 => 'critical',
|
||||
203 => 'notFunctioning'
|
||||
},
|
||||
'fan_descr' => {
|
||||
101 => 'chassis-1 Chassis Fan Tray 1',
|
||||
102 => 'chassis-1 Power Supply 1 Fan',
|
||||
103 => 'chassis-1 Power Supply 2 Fan',
|
||||
201 => 'chassis-2 Chassis Fan Tray 1',
|
||||
202 => 'chassis-2 Power Supply 1 Fan',
|
||||
203 => 'chassis-2 Power Supply 2 Fan'
|
||||
},
|
||||
'mau_index' => {1.1 => 1, 2.1 => 2, 3.1 => 3, 4.1 => 4, 5.1 => 5},
|
||||
'mau_autostat' => {
|
||||
1.1 => 'enabled',
|
||||
2.1 => 'disabled',
|
||||
3.1 => 'disabled',
|
||||
4.1 => 'disabled',
|
||||
5.1 => 'disabled'
|
||||
},
|
||||
|
||||
# .1.3.6.1.2.1.26.4.15 = IANA-MAU-MIB::dot3MauType100BaseTXHD
|
||||
# .1.3.6.1.2.1.26.4.16 = IANA-MAU-MIB::dot3MauType100BaseTXFD
|
||||
# .1.3.6.1.2.1.26.4.35 = IANA-MAU-MIB::dot3MauType10GigBaseLR
|
||||
'mau_type_admin' => {
|
||||
1.1 => '.0.0',
|
||||
2.1 => '.0.0',
|
||||
3.1 => '.1.3.6.1.2.1.26.4.15',
|
||||
4.1 => '.1.3.6.1.2.1.26.4.16',
|
||||
5.1 => '.1.3.6.1.2.1.26.4.35',
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
$test->{info}->cache($cache_data);
|
||||
}
|
||||
|
||||
|
||||
sub mau_i_duplex_admin : Tests(3) {
|
||||
my $test = shift;
|
||||
|
||||
can_ok($test->{info}, 'mau_i_duplex_admin');
|
||||
|
||||
my $expected
|
||||
= {1 => 'auto', 2 => 'auto', 3 => 'half', 4 => 'full'};
|
||||
|
||||
cmp_deeply($test->{info}->mau_i_duplex_admin(),
|
||||
$expected, q(Interfaces have expected duplex admin values));
|
||||
|
||||
$test->{info}->clear_cache();
|
||||
cmp_deeply($test->{info}->mau_i_duplex_admin(),
|
||||
{}, q(No duplex admin data returns empty hash));
|
||||
}
|
||||
|
||||
sub mau_i_speed_admin : Tests(3) {
|
||||
my $test = shift;
|
||||
|
||||
can_ok($test->{info}, 'mau_i_speed_admin');
|
||||
|
||||
my $expected = {1 => 'auto', 2 => 'auto', 3 => '100 Mbps', 4 => '100 Mbps', 5 => '10 Gbps'};
|
||||
|
||||
cmp_deeply($test->{info}->mau_i_speed_admin(),
|
||||
$expected, q(Interfaces have expected speed admin values));
|
||||
|
||||
$test->{info}->clear_cache();
|
||||
cmp_deeply($test->{info}->mau_i_speed_admin(),
|
||||
{}, q(No speed admin data returns empty hash));
|
||||
}
|
||||
|
||||
sub mau_set_i_speed_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 = {
|
||||
'MAU-MIB::ifMauDefaultType' => {
|
||||
1.1 => '.0.0',
|
||||
2.1 => '.0.0',
|
||||
3.1 => '.1.3.6.1.2.1.26.4.15',
|
||||
4.1 => '.1.3.6.1.2.1.26.4.16',
|
||||
5.1 => '.1.3.6.1.2.1.26.4.35',
|
||||
},
|
||||
};
|
||||
$test->{info}{sess}{Data} = $data;
|
||||
can_ok($test->{info}, 'mau_set_i_speed_admin');
|
||||
|
||||
is($test->{info}->mau_set_i_speed_admin('100', 3),
|
||||
1, q(Mock set speed call succeeded));
|
||||
|
||||
is($test->{info}->mau_set_i_speed_admin('auto-x', 2),
|
||||
undef, q(Mock set speed call to bad speed 'auto-x' fails));
|
||||
}
|
||||
|
||||
sub mau_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 = {
|
||||
'MAU-MIB::ifMauDefaultType' => {
|
||||
1.1 => '.0.0',
|
||||
2.1 => '.0.0',
|
||||
3.1 => '.1.3.6.1.2.1.26.4.15',
|
||||
4.1 => '.1.3.6.1.2.1.26.4.16',
|
||||
5.1 => '.1.3.6.1.2.1.26.4.35',
|
||||
},
|
||||
};
|
||||
$test->{info}{sess}{Data} = $data;
|
||||
|
||||
can_ok($test->{info}, 'mau_set_i_duplex_admin');
|
||||
|
||||
is($test->{info}->mau_set_i_duplex_admin('full', 3),
|
||||
1, q(Mock set duplex call succeeded));
|
||||
|
||||
is($test->{info}->mau_set_i_duplex_admin('full-x', 2),
|
||||
undef, q(Mock set duplex call to bad duplex type 'full-x' fails));
|
||||
}
|
||||
|
||||
1;
|
||||
Reference in New Issue
Block a user