The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use Test::More;
use strict;
use warnings;

BEGIN {
    # Freeze time at Tue, 15-Jun-2010 00:00:00 GMT
    *CORE::GLOBAL::time = sub { return 1276560000 }
}

my $_logs = [];

{

    package Dancer::Logger::Test;
    use Moo;
    with 'Dancer::Core::Role::Logger';

    sub log {
        my ($self, $level, $message) = @_;
        push @$_logs, $self->format_message($level, $message);
    }
}

my $logger = Dancer::Logger::Test->new(app_name => 'test');

is $logger->log_level, 'debug';
$logger->debug("foo");
like $_logs->[0], qr{debug \@2010-06-1\d \d\d:00:00> foo in t/logger.t};

subtest 'logger capture' => sub {
    use Dancer::Logger::Capture;
    use Dancer;

    set logger => 'capture';

    warning "Danger!  Warning!";
    debug "I like pie.";

    my $app  = dancer_app;
    my $trap = $app->setting('logger')->trapper;
    is_deeply $trap->read,
      [ {level => "warning", message => "Danger!  Warning!"},
        {level => "debug",   message => "I like pie.",}
      ];

    # each call to read cleans the trap
    is_deeply $trap->read, [];
};

done_testing;