mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
* 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
144 lines
5.0 KiB
PHP
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');
|
|
}
|
|
}
|