Files
librenms-librenms/tests/Feature/SnmpTraps/VeeamTrapTest.php
Wheel 42fdbea126 Veeam SNMP traps fix and extend (#13549)
* Veeam fix and extend part 1

* Veeam SNMP traps

* StyleCI

* StyleCI

* Fix typo

* Lint

* Fix tests

* Fix tests :fingerscrossed:

* Think i get it now

* This is it?

* gotta be it

* Final

* Again
2021-11-24 18:20:56 +01:00

144 lines
5.0 KiB
PHP

<?php
namespace LibreNMS\Tests\Feature\SnmpTraps;
use App\Models\Device;
use LibreNMS\Snmptrap\Dispatcher;
use LibreNMS\Snmptrap\Trap;
use Log;
class VeeamTrapTest extends SnmpTrapTestCase
{
public function testVeeamBackupJobCompleted(): void
{
$device = Device::factory()->create();
$trapText = "$device->hostname
UDP: [$device->ip]:46024->[1.1.1.1]:162
DISMAN-EVENT-MIB::sysUpTimeInstance 4:13:08:37.60
SNMPv2-MIB::snmpTrapOID.0 VEEAM-MIB::onBackupJobCompleted
VEEAM-MIB::backupJobId 7a1b3549-c4c7-4629-84d6-74e24fee8011
VEEAM-MIB::backupJobName SureBackup Job 1
VEEAM-MIB::sourceHostName hostname
VEEAM-MIB::backupJobComment comment
VEEAM-MIB::backupJobResult Success";
$trap = new Trap($trapText);
$message = 'SNMP Trap: Backup Job Success - SureBackup Job 1 - comment';
Log::shouldReceive('event')->once()->with($message, $device->device_id, 'backup', 1);
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle VEEAM-MIB::traps');
}
public function testVeeamBackupJobCompletedWarning(): void
{
$device = Device::factory()->create();
$trapText = "$device->hostname
UDP: [$device->ip]:46024->[1.1.1.1]:162
DISMAN-EVENT-MIB::sysUpTimeInstance 4:13:08:37.60
SNMPv2-MIB::snmpTrapOID.0 VEEAM-MIB::onBackupJobCompleted
VEEAM-MIB::backupJobId 7a1b3549-c4c7-4629-84d6-74e24fee8011
VEEAM-MIB::backupJobName SureBackup Job 1
VEEAM-MIB::sourceHostName hostname
VEEAM-MIB::backupJobComment comment
VEEAM-MIB::backupJobResult Warning";
$trap = new Trap($trapText);
$message = 'SNMP Trap: Backup Job Warning - SureBackup Job 1 - comment';
Log::shouldReceive('event')->once()->with($message, $device->device_id, 'backup', 4);
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle VEEAM-MIB::traps');
}
public function testVeeamBackupJobCompletedFailed(): void
{
$device = Device::factory()->create();
$trapText = "$device->hostname
UDP: [$device->ip]:46024->[1.1.1.1]:162
DISMAN-EVENT-MIB::sysUpTimeInstance 4:13:08:37.60
SNMPv2-MIB::snmpTrapOID.0 VEEAM-MIB::onBackupJobCompleted
VEEAM-MIB::backupJobId 7a1b3549-c4c7-4629-84d6-74e24fee8011
VEEAM-MIB::backupJobName SureBackup Job 1
VEEAM-MIB::sourceHostName hostname
VEEAM-MIB::backupJobComment comment
VEEAM-MIB::backupJobResult Failed";
$trap = new Trap($trapText);
$message = 'SNMP Trap: Backup Job Failed - SureBackup Job 1 - comment';
Log::shouldReceive('event')->once()->with($message, $device->device_id, 'backup', 5);
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle VEEAM-MIB::traps');
}
public function testVeeamVmBackupCompleted(): void
{
$device = Device::factory()->create();
$trapText = "$device->hostname
UDP: [$device->ip]:46024->[1.1.1.1]:162
DISMAN-EVENT-MIB::sysUpTimeInstance 4:13:08:37.60
SNMPv2-MIB::snmpTrapOID.0 VEEAM-MIB::onVmBackupCompleted
VEEAM-MIB::backupJobName Linux taeglich low
VEEAM-MIB::vmName vmname1
VEEAM-MIB::sourceHostName hostname
VEEAM-MIB::vmBackupComment comment
VEEAM-MIB::vmBackupResult Success";
$trap = new Trap($trapText);
$message = 'SNMP Trap: VM backup Success - vmname1 Job: Linux taeglich low - comment';
Log::shouldReceive('event')->once()->with($message, $device->device_id, 'backup', 1);
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle VEEAM-MIB::traps');
}
public function testVeeamVmBackupCompletedWarning(): void
{
$device = Device::factory()->create();
$trapText = "$device->hostname
UDP: [$device->ip]:46024->[1.1.1.1]:162
DISMAN-EVENT-MIB::sysUpTimeInstance 4:13:08:37.60
SNMPv2-MIB::snmpTrapOID.0 VEEAM-MIB::onVmBackupCompleted
VEEAM-MIB::backupJobName Linux taeglich low
VEEAM-MIB::vmName vmname1
VEEAM-MIB::sourceHostName hostname
VEEAM-MIB::vmBackupComment comment
VEEAM-MIB::vmBackupResult Warning";
$trap = new Trap($trapText);
$message = 'SNMP Trap: VM backup Warning - vmname1 Job: Linux taeglich low - comment';
Log::shouldReceive('event')->once()->with($message, $device->device_id, 'backup', 4);
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle VEEAM-MIB::traps');
}
public function testVeeamVmBackupCompletedFailed(): void
{
$device = Device::factory()->create();
$trapText = "$device->hostname
UDP: [$device->ip]:46024->[1.1.1.1]:162
DISMAN-EVENT-MIB::sysUpTimeInstance 4:13:08:37.60
SNMPv2-MIB::snmpTrapOID.0 VEEAM-MIB::onVmBackupCompleted
VEEAM-MIB::backupJobName Linux taeglich low
VEEAM-MIB::vmName vmname1
VEEAM-MIB::sourceHostName hostname
VEEAM-MIB::vmBackupComment comment
VEEAM-MIB::vmBackupResult Failed";
$trap = new Trap($trapText);
$message = 'SNMP Trap: VM backup Failed - vmname1 Job: Linux taeglich low - comment';
Log::shouldReceive('event')->once()->with($message, $device->device_id, 'backup', 5);
$this->assertTrue(Dispatcher::handle($trap), 'Could not handle VEEAM-MIB::traps');
}
}