The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;
use lib qw(t/lib);
use Test::More;
use Log::Dispatch;
use Log::Dispatch::TestUtil qw(cmp_deeply);
use File::Temp qw( tempdir );

my $tempdir = tempdir( CLEANUP => 1 );

{
    my $emerg_log = File::Spec->catdir( $tempdir, 'emerg.log' );

    # Short syntax
    my $dispatch0 = Log::Dispatch->new(
        outputs => [
            [
                'File', name => 'file',
                min_level => 'emerg',
                filename  => $emerg_log,
            ],
            [
                '+Log::Dispatch::Null',
                name      => 'null',
                min_level => 'debug',
            ]
        ]
    );

    # Short syntax alternate (2.23)
    my $dispatch1 = Log::Dispatch->new(
        outputs => [
            'File' => {
                name => 'file', min_level => 'emerg', filename => $emerg_log
            },
            '+Log::Dispatch::Null' => { name => 'null', min_level => 'debug' }
        ]
    );

    # Long syntax
    my $dispatch2 = Log::Dispatch->new;
    $dispatch2->add(
        Log::Dispatch::File->new(
            name      => 'file',
            min_level => 'emerg',
            filename  => $emerg_log
        )
    );
    $dispatch2->add(
        Log::Dispatch::Null->new( name => 'null', min_level => 'debug' ) );

    cmp_deeply(
        $dispatch0, $dispatch2,
        "created equivalent dispatchers - 0"
    );
    cmp_deeply(
        $dispatch1, $dispatch2,
        "created equivalent dispatchers - 1"
    );
}

{
    eval { Log::Dispatch->new( outputs => ['File'] ) };
    like(
        $@, qr/expected arrayref/,
        "got error for expected inner arrayref"
    );
}
{
    eval { Log::Dispatch->new( outputs => 'File' ) };
    like(
        $@, qr/not one of the allowed types: arrayref/,
        "got error for expected outer arrayref"
    );
}

done_testing();