mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
50c8033099
* Shift HTTP kernel and middleware * Shift service providers * Shift console routes * Shift to class based factories * Namespace seeders * Shift PSR-4 autoloading * Default config files In an effort to make upgrading the constantly changing config files easier, Shift defaulted them. This allows you to review the commit diff for once for customizations when you are done Shifting. Moving forward, consider using ENV variables or create a separate config file to allow the core config files to remain as default as possible. * Shift Laravel dependencies * Shift return type of base TestCase methods From the [PHPUnit 8 release notes][1], the `TestCase` methods below now declare a `void` return type: - `setUpBeforeClass()` - `setUp()` - `assertPreConditions()` - `assertPostConditions()` - `tearDown()` - `tearDownAfterClass()` - `onNotSuccessfulTest()` [1]: https://phpunit.de/announcements/phpunit-8.html * Shift cleanup * console routes * composer update * factories * phpunit * bootstrap pagination * model factory * wip * Apply fixes from StyleCI (#12236) * wip * Apply fixes from StyleCI (#12238) * wip * wip * wip * wip * Apply fixes from StyleCI (#12240) * wip * Apply fixes from StyleCI (#12242) * composer update * Bump to PHP 7.3 minimum Co-authored-by: Laravel Shift <shift@laravelshift.com>
270 lines
11 KiB
PHP
270 lines
11 KiB
PHP
<?php
|
|
/**
|
|
* OspfIfStateChangeTest.php
|
|
*
|
|
* -Description-
|
|
*
|
|
* Unit test for the OspfIfStateChange SNMP trap handler. Will verify
|
|
* trap is properly logged and ospf_ports.ospfIfState is updated in the
|
|
* database.
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @link http://librenms.org
|
|
* @copyright 2020 KanREN, Inc
|
|
* @author Heath Barnhart <hbarnhart@kanren.net>
|
|
*/
|
|
|
|
namespace LibreNMS\Tests\Feature\SnmpTraps;
|
|
|
|
use App\Models\Device;
|
|
use App\Models\OspfPort;
|
|
use App\Models\Port;
|
|
use LibreNMS\Snmptrap\Dispatcher;
|
|
use LibreNMS\Snmptrap\Trap;
|
|
|
|
class OspfIfStateChangeTest extends SnmpTrapTestCase
|
|
{
|
|
//Test OSPF interface state down
|
|
public function testOspfIfDown()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'designatedRouter']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 down
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is down";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 5);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange down');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'down');
|
|
}
|
|
|
|
//Test OSPF interface state DesignatedRouter
|
|
public function testOspfIfDr()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'down']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 designatedRouter
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is designatedRouter";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 1);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange designatedRouter');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'designatedRouter');
|
|
}
|
|
|
|
//Test OSPF interface state backupDesignatedRouter
|
|
public function testOspfIfBdr()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'down']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 backupDesignatedRouter
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is backupDesignatedRouter";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 1);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange backupDesignatedRouter');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'backupDesignatedRouter');
|
|
}
|
|
|
|
//Test OSPF interface state otherDesignatedRouter
|
|
public function testOspfIfOdr()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'down']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 otherDesignatedRouter
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is otherDesignatedRouter";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 1);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange otherDesignatedRouter');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'otherDesignatedRouter');
|
|
}
|
|
|
|
//Test OSPF interface state pointToPoint
|
|
public function testOspfIfPtp()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'down']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 pointToPoint
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is pointToPoint";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 1);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange pointToPoint');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'pointToPoint');
|
|
}
|
|
|
|
//Test OSPF interface state waiting
|
|
public function testOspfIfWait()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'designatedRouter']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 waiting
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is waiting";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 4);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange waiting');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'waiting');
|
|
}
|
|
|
|
//Test OSPF interface state loopback
|
|
public function testOspfIfLoop()
|
|
{
|
|
$device = Device::factory()->create();
|
|
$port = Port::factory()->make(['ifAdminStatus' => 'up', 'ifOperStatus' => 'up']);
|
|
|
|
$device->ports()->save($port);
|
|
|
|
$ospfIf = OspfPort::factory()->make(['port_id' => $port->port_id, 'ospfIfState' => 'designatedRouter']);
|
|
$device->ospfPorts()->save($ospfIf);
|
|
|
|
$trapText = "$device->hostname
|
|
UDP: [$device->ip]:57602->[192.168.5.5]:162
|
|
DISMAN-EVENT-MIB::sysUpTimeInstance 0:6:11:31.55
|
|
SNMPv2-MIB::snmpTrapOID.0 OSPF-TRAP-MIB::ospfIfStateChange
|
|
OSPF-MIB::ospfRouterId.0 $device->ip
|
|
OSPF-MIB::ospfIfIpAddress.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfIfIpAddress
|
|
OSPF-MIB::ospfAddressLessIf.$ospfIf->ospfIfIpAddress.0 $ospfIf->ospfAddressLessIf
|
|
OSPF-MIB::ospfIfState.$ospfIf->ospfIfIpAddress.0 loopback
|
|
SNMPv2-MIB::snmpTrapEnterprise.0 JUNIPER-CHASSIS-DEFINES-MIB::jnxProductNameSRX240";
|
|
|
|
$trap = new Trap($trapText);
|
|
|
|
$message = "OSPF interface $port->ifName is loopback";
|
|
|
|
\Log::shouldReceive('event')->once()->with($message, $device->device_id, 'trap', 4);
|
|
|
|
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle ospfIfStateChange loopback');
|
|
|
|
$ospfIf = $ospfIf->fresh();
|
|
$this->assertEquals($ospfIf->ospfIfState, 'loopback');
|
|
}
|
|
}
|