DOKK / manpages / debian 12 / libdancer2-perl / Dancer2::Logger::Capture.3pm.en
Dancer2::Logger::Capture(3pm) User Contributed Perl Documentation Dancer2::Logger::Capture(3pm)

Dancer2::Logger::Capture - Capture dancer logs

version 0.400001

The basics:

    set logger => "capture";
    my $trap = dancer_app->logger_engine->trapper;
    my $logs = $trap->read;

A worked-out real-world example:

    use Test::More tests => 2;
    use Dancer2;
    set logger => 'capture';
    warning "Danger!  Warning!";
    debug   "I like pie.";
    my $trap = dancer_app->logger_engine->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, [];

This is a logger class for Dancer2 which captures all logs to an object.

Its primary purpose is for testing. Here is an example of a test:

    use strict;
    use warnings;
    use Test::More;
    use Plack::Test;
    use HTTP::Request::Common;
    use Ref::Util qw<is_coderef>;
    {
        package App;
        use Dancer2;
        set log       => 'debug';
        set logger    => 'capture';
        get '/' => sub {
            log(debug => 'this is my debug message');
            log(core  => 'this should not be logged');
            log(info  => 'this is my info message');
        };
    }
    my $app = Dancer2->psgi_app;
    ok( is_coderef($app), 'Got app' );
    test_psgi $app, sub {
        my $cb = shift;
        my $res = $cb->( GET '/' );
        my $trap = App->dancer_app->logger_engine->trapper;
        is_deeply $trap->read, [
            { level => 'debug', message => 'this is my debug message' },
            { level => 'info',  message => 'this is my info message' },
        ];
        is_deeply $trap->read, [];
    };
    done_testing;

Returns the Dancer2::Logger::Capture::Trap object used to capture and read logs.

Dancer2::Core::Role::Logger, Dancer2::Logger::Capture::Trap

Dancer Core Developers

This software is copyright (c) 2023 by Alexis Sukrieh.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.

2023-02-10 perl v5.36.0