Audit-Log

 view release on metacpan or  search on metacpan

t/Audit-Log.t  view on Meta::CPAN

use strict;
use warnings;

use lib 'lib';

use Test::More;
use Test::Deep;
use Audit::Log;
use List::Util 1.45 qw{uniq};

my $parser = Audit::Log->new('t/audit.log','name','type','nametype','line','timestamp', 'cwd', 'exe', 'comm', 'res');
my $rows = $parser->search( type => qr/path/i, nametype => qr/create|delete/i, name => qr/^backups\/[^\.]/, key => qr/backupwatch/, older => 1642448670, newer => 1642441403 );

my $expected = [
  {
    'line' => 3,
    'timestamp' => '1642441406.575',
    'type' => 'PATH',
    'nametype' => 'CREATE',
    'name' => 'backups/test.txt',
    'cwd'  => '/testpath',
    'exe'  => '/usr/bin/touch',
    'comm' => 'touch',
    'res'  => 1,
  },
  {
    'type' => 'PATH',
    'timestamp' => '1642441412.975',
    'line' => 8,
    'name' => 'backups/testme.txt',
    'nametype' => 'DELETE',
    'cwd'      => '/testpath',
    'exe'      => '/usr/bin/rm',
    'comm'     => 'rm',
    res        => 1,
  }
];

is_deeply($rows,$expected,"Parser works as expected");
done_testing();



( run in 0.992 second using v1.01-cache-2.11-cpan-5837b0d9d2c )