File: base.t

package info (click to toggle)
liblog-contextual-perl 0.009001-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 432 kB
  • sloc: perl: 889; makefile: 2
file content (49 lines) | stat: -rw-r--r-- 1,500 bytes parent folder | download
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
48
49
use strict;
use warnings;

use lib 't/lib';

use BaseLogger qw{:log with_logger set_logger};
use Test::More;

my @levels = qw(lol wut zomg);

VANILLA: {
  for (@levels) {
    main->can("log_$_")->(sub { 'fiSMBoC' });
    is($DumbLogger2::var, "[$_] fiSMBoC\n", "$_ works");

    main->can("slog_$_")->('fiSMBoC');
    is($DumbLogger2::var, "[$_] fiSMBoC\n", "string $_ works");

    main->can("slog_$_")->('0');
    is($DumbLogger2::var, "[$_] 0\n", "false string $_ works");

    my @vars =
      main->can("log_$_")->(sub { 'fiSMBoC: ' . $_[1] }, qw{foo bar baz});
    is($DumbLogger2::var, "[$_] fiSMBoC: bar\n", "log_$_ works with input");
    ok(
      eq_array(\@vars, [qw{foo bar baz}]),
      "log_$_ passes data through correctly"
    );

    my @svars = main->can("slog_$_")->('fiSMBoC', qw{foo bar baz});
    is($DumbLogger2::var, "[$_] fiSMBoC\n", "slog_$_ ignores input");
    ok(
      eq_array(\@svars, [qw{foo bar baz}]),
      "slog_$_ passes data through correctly"
    );

    my $val = main->can("logS_$_")->(sub { 'fiSMBoC: ' . $_[0] }, 'foo');
    is($DumbLogger2::var, "[$_] fiSMBoC: foo\n", "logS_$_ works with input");
    is($val, 'foo', "logS_$_ passes data through correctly");

    my $sval = main->can("slogS_$_")->('fiSMBoC', 'foo');
    is($DumbLogger2::var, "[$_] fiSMBoC\n", "slogS_$_ ignores input");
    is($val, 'foo', "slogS_$_ passes data through correctly");
  }
}

ok(!eval { Log::Contextual->import; 1 }, 'Blank Log::Contextual import dies');

done_testing;