#!/usr/bin/perl
use strict;
use warnings;
use FindBin;
use Test::More;
use Test::Fatal;
use Bread::Board;
like(exception { local $SIG{__WARN__} = sub { }; include "$FindBin::Bin/lib/bad.bb" },
qr/Couldn't compile.*bad\.bb.*syntax error.*function_doesnt_exist/,
"we get appropriate errors for invalid files");
like(exception { include "$FindBin::Bin/lib/doesnt_exist.bb" },
qr/Couldn't open.*doesnt_exist\.bb.*for reading/,
"we get appropriate errors for files that don't exist");
like(exception { include "$FindBin::Bin/lib/false.bb" },
qr/false\.bb.*doesn't return a true value/,
"we get appropriate errors for files that evaluate to false");
{
package FileLogger;
use Moose;
has 'log_file' => (is => 'ro', required => 1);
package MyApplication;
use Moose;
has 'logger' => (is => 'ro', isa => 'FileLogger', required => 1);
}
my $c = container 'MyApp' => as {
service 'log_file' => "logfile.log";
include "$FindBin::Bin/lib/logger.bb";
service 'application' => (
class => 'MyApplication',
dependencies => {
logger => depends_on('logger'),
}
);
};
my $logger = $c->resolve( service => 'logger' );
isa_ok($logger, 'FileLogger');
is($logger->log_file, 'logfile.log', '... got the right logfile dep');
is($c->fetch('logger/log_file')->service, $c->fetch('log_file'), '... got the right value');
is($c->fetch('logger/log_file')->get, 'logfile.log', '... got the right value');
my $app = $c->resolve( service => 'application' );
isa_ok($app, 'MyApplication');
isa_ok($app->logger, 'FileLogger');
is($app->logger, $logger, '... got the right logger (singleton)');
done_testing;