package Dancer::Logger::Capture;
BEGIN {
$Dancer::Logger::Capture::AUTHORITY = 'cpan:SUKRIA';
}
# ABSTRACT: Capture dancer logs
$Dancer::Logger::Capture::VERSION = '1.3132';
use strict;
use warnings;
use base "Dancer::Logger::Abstract";
use Dancer::Logger::Capture::Trap;
my $Trap = Dancer::Logger::Capture::Trap->new;
sub _log {
my($self, $level, $message) = @_;
$Trap->store( $level => $message );
return;
}
sub trap {
return $Trap;
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Dancer::Logger::Capture - Capture dancer logs
=head1 VERSION
version 1.3132
=head1 SYNOPSIS
set logger => "capture";
my $trap = Dancer::Logger::Capture->trap;
my $logs = $trap->read;
=head1 DESCRIPTION
This is a logger class for L<Dancer> which captures all logs to an object.
It's primary purpose is for testing.
=head2 Methods
=head3 trap
Returns the L<Dancer::Logger::Capture::Trap> object used to capture
and read logs.
=head1 EXAMPLE
use Test::More import => ['!pass'], tests => 2;
use Dancer;
set logger => 'capture';
warning "Danger! Warning!";
debug "I like pie.";
my $trap = Dancer::Logger::Capture->trap;
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, [];
=head1 SEE ALSO
L<Dancer::Logger>, L<Dancer::Logger::Capture::Trap>
=head1 AUTHOR
Dancer Core Developers
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2010 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.
=cut