2
									
								
								Changes
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Changes
									
									
									
									
									
								
							| @@ -10,6 +10,8 @@ Version 3.61 | |||||||
|   [BUG FIXES] |   [BUG FIXES] | ||||||
|  |  | ||||||
|   * #261 EIGRP Peer Neighbor Formatting / Munge |   * #261 EIGRP Peer Neighbor Formatting / Munge | ||||||
|  |   * #252 Unpack binary MAC if present in cdp_port | ||||||
|  |   * Fix SNMPv1 cdp_run check | ||||||
|  |  | ||||||
| Version 3.60 (2018-05-06) | Version 3.60 (2018-05-06) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -62,7 +62,7 @@ $VERSION = '3.60'; | |||||||
|     'cdp_addr'         => 'cdpCacheAddress', |     'cdp_addr'         => 'cdpCacheAddress', | ||||||
|     'cdp_ver'          => 'cdpCacheVersion', |     'cdp_ver'          => 'cdpCacheVersion', | ||||||
|     'cdp_dev_id'       => 'cdpCacheDeviceId', |     'cdp_dev_id'       => 'cdpCacheDeviceId', | ||||||
|     'cdp_port'         => 'cdpCacheDevicePort', |     'cdp_dev_port'     => 'cdpCacheDevicePort', | ||||||
|     'cdp_platform'     => 'cdpCachePlatform', |     'cdp_platform'     => 'cdpCachePlatform', | ||||||
|     'cdp_capabilities' => 'cdpCacheCapabilities', |     'cdp_capabilities' => 'cdpCacheCapabilities', | ||||||
|     'cdp_domain'       => 'cdpCacheVTPMgmtDomain', |     'cdp_domain'       => 'cdpCacheVTPMgmtDomain', | ||||||
| @@ -79,7 +79,6 @@ $VERSION = '3.60'; | |||||||
|     'cdp_capabilities' => \&SNMP::Info::munge_bits, |     'cdp_capabilities' => \&SNMP::Info::munge_bits, | ||||||
|     'cdp_platform'     => \&SNMP::Info::munge_null, |     'cdp_platform'     => \&SNMP::Info::munge_null, | ||||||
|     'cdp_domain'       => \&SNMP::Info::munge_null, |     'cdp_domain'       => \&SNMP::Info::munge_null, | ||||||
|     'cdp_port'         => \&SNMP::Info::munge_null, |  | ||||||
|     'cdp_ver'          => \&SNMP::Info::munge_null, |     'cdp_ver'          => \&SNMP::Info::munge_null, | ||||||
|     'cdp_ip'           => \&SNMP::Info::munge_ip, |     'cdp_ip'           => \&SNMP::Info::munge_ip, | ||||||
|     'cdp_power'        => \&munge_power, |     'cdp_power'        => \&munge_power, | ||||||
| @@ -110,20 +109,18 @@ sub munge_power { | |||||||
| sub hasCDP { | sub hasCDP { | ||||||
|     my $cdp = shift; |     my $cdp = shift; | ||||||
|  |  | ||||||
|     my $ver = $cdp->{_version}; |     # Check the global that is supposed to indicate CDP is running | ||||||
|  |     my $cdp_run = $cdp->cdp_run(); | ||||||
|  |     return 1 if $cdp_run; | ||||||
|  |  | ||||||
|     # SNMP v1 clients dont have the globals |     # SNMP v1 clients don't have the globals, fallback | ||||||
|     if ( defined $ver and $ver == 1 ) { |     # by checking if it would report neighbors | ||||||
|         my $cdp_ip = $cdp->cdp_ip(); |     my $cdp_ip = $cdp->cdp_ip() || {}; | ||||||
|  |     return 1 if scalar keys %$cdp_ip; | ||||||
|  |  | ||||||
|         # See if anything in cdp cache, if so we have cdp |  | ||||||
|         return 1 if ( defined $cdp_ip and scalar( keys %$cdp_ip ) ); |  | ||||||
|     return; |     return; | ||||||
| } | } | ||||||
|  |  | ||||||
|     return $cdp->cdp_run(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| sub cdp_if { | sub cdp_if { | ||||||
|     my $cdp = shift; |     my $cdp = shift; | ||||||
|  |  | ||||||
| @@ -219,6 +216,22 @@ sub cdp_id { | |||||||
|     return \%cdp_id; |     return \%cdp_id; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | sub cdp_port { | ||||||
|  |     my $cdp    = shift; | ||||||
|  |     my $partial = shift; | ||||||
|  |  | ||||||
|  |     my $ch = $cdp->cdp_dev_port($partial) || {}; | ||||||
|  |  | ||||||
|  |     my %cdp_port; | ||||||
|  |     foreach my $key ( sort keys %$ch ) { | ||||||
|  |         my $port = $ch->{$key}; | ||||||
|  |         next unless $port; | ||||||
|  |         $port = SNMP::Info::munge_mac($port) || SNMP::Info::munge_null($port); | ||||||
|  |         $cdp_port{$key} = $port; | ||||||
|  |     } | ||||||
|  |     return \%cdp_port; | ||||||
|  | } | ||||||
|  |  | ||||||
| 1; | 1; | ||||||
| __END__ | __END__ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -33,23 +33,139 @@ use Test::Class::Most parent => 'My::Test::Class'; | |||||||
|  |  | ||||||
| use SNMP::Info::CDP; | use SNMP::Info::CDP; | ||||||
|  |  | ||||||
| # 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) { | sub setup : Tests(setup) { | ||||||
|   my $test = shift; |   my $test = shift; | ||||||
|   $test->SUPER::setup; |   $test->SUPER::setup; | ||||||
|  |  | ||||||
|   # Start with a common cache that will serve most tests |   # Start with a common cache that will serve most tests | ||||||
|   my $cache_data = { |   my $cache_data = { | ||||||
|     'store' => {}, |     '_cdp_run'          => 'true', | ||||||
|  |     '_cdp_ip'           => 1, | ||||||
|  |     '_cdp_addr'         => 1, | ||||||
|  |     '_cdp_proto'        => 1, | ||||||
|  |     '_cdp_capabilities' => 1, | ||||||
|  |     '_cdp_dev_id'       => 1, | ||||||
|  |     '_cdp_dev_port'     => 1, | ||||||
|  |     'store'             => { | ||||||
|  |       'cdp_addr'  => {'2.1' => pack("H*", '0A141E28'), '3.1' => 'xyz'}, | ||||||
|  |       'cdp_proto' => {'2.1' => 'ip',                   '3.1' => 'chaos'}, | ||||||
|  |       'cdp_capabilities' => {'2.1' => pack("H*", '00000228')}, | ||||||
|  |       'cdp_dev_id'       => {'2.1' => pack("H*", 'ABCD12345678')}, | ||||||
|  |       'cdp_dev_port'     => {'2.1' => pack("H*", 'ABCD12345678')}, | ||||||
|  |     } | ||||||
|   }; |   }; | ||||||
|   $test->{info}->cache($cache_data); |   $test->{info}->cache($cache_data); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | sub hasCDP : Tests(4) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'hasCDP'); | ||||||
|  |   is($test->{info}->hasCDP(), 1, q(Has 'cdpGlobalRun' has CDP)); | ||||||
|  |  | ||||||
|  |   delete $test->{info}{_cdp_run}; | ||||||
|  |   is($test->{info}->hasCDP(), | ||||||
|  |     1, q(No 'cdpGlobalRun', but has neighbors, has CDP)); | ||||||
|  |  | ||||||
|  |   $test->{info}->clear_cache(); | ||||||
|  |   is($test->{info}->hasCDP(), | ||||||
|  |     undef, q(No 'cdpGlobalRun' and no neighbors, no CDP)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub cdp_if : Tests(3) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'cdp_if'); | ||||||
|  |  | ||||||
|  |   my $expected = {'2.1' => 2}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_if(), | ||||||
|  |     $expected, q(Mapping of CDP interface has expected value)); | ||||||
|  |  | ||||||
|  |   $test->{info}->clear_cache(); | ||||||
|  |   cmp_deeply($test->{info}->cdp_if(), {}, q(No data returns empty hash)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub cdp_ip : Tests(3) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'cdp_ip'); | ||||||
|  |  | ||||||
|  |   my $expected = {'2.1' => '10.20.30.40'}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_ip(), | ||||||
|  |     $expected, q(Remote CDP IPv4 has expected value)); | ||||||
|  |  | ||||||
|  |   $test->{info}->clear_cache(); | ||||||
|  |   cmp_deeply($test->{info}->cdp_ip(), {}, q(No data returns empty hash)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub cdp_cap : Tests(4) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'cdp_cap'); | ||||||
|  |  | ||||||
|  |   my $expected = ['IGMP', 'Supports-STP-Dispute', 'Switch']; | ||||||
|  |  | ||||||
|  |   my $caps = $test->{info}->cdp_cap(); | ||||||
|  |  | ||||||
|  |   cmp_set($caps->{'2.1'}, $expected, q(Caps emumerated correctly)); | ||||||
|  |  | ||||||
|  |   $test->{info}{store}{cdp_capabilities} = {'2.1' => pack("H*", '00000000')}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_cap(), {}, q(Cap of zeros return empty hash)); | ||||||
|  |  | ||||||
|  |   $test->{info}->clear_cache(); | ||||||
|  |   cmp_deeply($test->{info}->cdp_cap(), {}, q(No data returns empty hash)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub cdp_id : Tests(4) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'cdp_id'); | ||||||
|  |  | ||||||
|  |   my $expected = {'2.1' => 'ab:cd:12:34:56:78'}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_id(), | ||||||
|  |     $expected, q(Remote ID packed MAC has expected value)); | ||||||
|  |  | ||||||
|  |   $test->{info}{store}{cdp_dev_id} = {'2.1' => 'My-Device-Name'}; | ||||||
|  |   $expected = {'2.1' => 'My-Device-Name'}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_id(), | ||||||
|  |     $expected, q(Remote ID text has expected value)); | ||||||
|  |  | ||||||
|  |   $test->{info}->clear_cache(); | ||||||
|  |   cmp_deeply($test->{info}->cdp_id(), {}, q(No data returns empty hash)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub cdp_port : Tests(4) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'cdp_port'); | ||||||
|  |  | ||||||
|  |   my $expected = {'2.1' => 'ab:cd:12:34:56:78'}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_port(), | ||||||
|  |     $expected, q(Remote ID packed MAC has expected value)); | ||||||
|  |  | ||||||
|  |   $test->{info}{store}{cdp_dev_port} = {'2.1' => 'My-Port-Name'}; | ||||||
|  |   $expected = {'2.1' => 'My-Port-Name'}; | ||||||
|  |  | ||||||
|  |   cmp_deeply($test->{info}->cdp_port(), | ||||||
|  |     $expected, q(Remote ID text has expected value)); | ||||||
|  |  | ||||||
|  |   $test->{info}->clear_cache(); | ||||||
|  |   cmp_deeply($test->{info}->cdp_port(), {}, q(No data returns empty hash)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | sub munge_power : Tests(2) { | ||||||
|  |   my $test = shift; | ||||||
|  |  | ||||||
|  |   can_ok($test->{info}, 'munge_power'); | ||||||
|  |  | ||||||
|  |   is(SNMP::Info::CDP::munge_power(123456), | ||||||
|  |     '123.456', q(... munges millwatts to watts)); | ||||||
|  | } | ||||||
|  |  | ||||||
| 1; | 1; | ||||||
		Reference in New Issue
	
	Block a user