File: TestAdapters.pm

package info (click to toggle)
liblog-any-perl 1.717-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 448 kB
  • sloc: perl: 1,499; makefile: 11
file content (47 lines) | stat: -rw-r--r-- 1,060 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package TestAdapters;

use warnings;
use strict;

our @TEXT_LOG;
our @STRUCTURED_LOG;

package TestAdapters::Normal;
use base qw(Log::Any::Adapter::Base);
foreach my $method ( Log::Any->logging_methods() ) {
    no strict 'refs';
    *$method = sub { push @TestAdapters::TEXT_LOG, $_[1] };
}
foreach my $method ( Log::Any->detection_methods() ) {
    no strict 'refs';
    *$method = sub {1};
}

package TestAdapters::Structured;
use base qw(Log::Any::Adapter::Base);
use Storable 'dclone';

sub structured {
    my ( $self, $level, $category, @args ) = @_;

    my ( $messages, $data );
    for (@args) {
        if (ref) {
            push @$data, dclone($_);
        }
        else {
            push @$messages, $_;
        }
    }
    my $log_hash = { level => $level, category => $category };
    $log_hash->{messages} = $messages if $messages;
    $log_hash->{data}     = $data     if $data;
    push @TestAdapters::STRUCTURED_LOG, $log_hash;
}

foreach my $method ( Log::Any->detection_methods() ) {
    no strict 'refs';
    *$method = sub {1};
}

1;