From 8761aaac596dfd3fe595584aa44720084ccec2eb Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Fri, 28 Dec 2012 18:05:46 -0600 Subject: implement arrays of strings for dependencies --- lib/Bread/Board.pm | 22 ++++++++++-- t/029_sugar_auto_wire_names.t | 79 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 99 insertions(+), 2 deletions(-) create mode 100644 t/029_sugar_auto_wire_names.t diff --git a/lib/Bread/Board.pm b/lib/Bread/Board.pm index 8ee05e7..82b886c 100644 --- a/lib/Bread/Board.pm +++ b/lib/Bread/Board.pm @@ -170,7 +170,16 @@ class ConstructorInjection does Service does HasParameters does HasDependencies if %params. { if %params. ~~ Array { %params. = %params..map(-> $dep { - $dep.service_path.split('/').[*-1] => $dep + my ($name, $obj); + if ($dep ~~ Dependency) { + $name = $dep.service_path.split('/').[*-1]; + $obj = $dep; + } + else { + $name = $dep.split('/').[*-1]; + $obj = Dependency.new(service_path => $dep); + } + $name => $obj }).hash; } @@ -235,7 +244,16 @@ class BlockInjection does Service does HasParameters does HasDependencies { if %params. { if %params. ~~ Array { %params. = %params..map(-> $dep { - $dep.service_path.split('/').[*-1] => $dep + my ($name, $obj); + if ($dep ~~ Dependency) { + $name = $dep.service_path.split('/').[*-1]; + $obj = $dep; + } + else { + $name = $dep.split('/').[*-1]; + $obj = Dependency.new(service_path => $dep); + } + $name => $obj }).hash; } diff --git a/t/029_sugar_auto_wire_names.t b/t/029_sugar_auto_wire_names.t new file mode 100644 index 0000000..79aa431 --- /dev/null +++ b/t/029_sugar_auto_wire_names.t @@ -0,0 +1,79 @@ +use v6; +use Test; + +use Bread::Board; + +class FileLogger { + has $.log_file; +} + +class DBI { + has Str ($.dsn, $.username, $.password); + + method connect (Str $dsn, Str $username, Str $password) { + self.new(dsn => $dsn, username => $username, password => $password); + } +} + +class MyApplication { + has FileLogger $.logger; + has DBI $.dbh; +} + +my $c = container 'MyApp', { + service 'log_file', 'logfile.log'; + service 'logger', ( + class => FileLogger, + lifecycle => Singleton, + dependencies => ['log_file'], + ); + + container 'Database', { + service 'dsn', 'dbi:sqlite:dbname=my-app.db'; + service 'username', 'user'; + service 'password', 'pass'; + + service 'dbh', ( + block => -> $s { + DBI.connect( + $s.param('dsn'), + $s.param('username'), + $s.param('password'), + ) || die "Could not connect"; + }, + dependencies => [qw[dsn username password]], + ); + }; + + service 'application', ( + class => MyApplication, + dependencies => ['logger', 'Database/dbh'], + ); +}; + +my $logger = $c.resolve(service => 'logger'); +isa_ok($logger, FileLogger); +is($logger.log_file, 'logfile.log'); + +is($c.fetch('logger/log_file').service, $c.fetch('log_file')); +is($c.fetch('logger/log_file').get, 'logfile.log'); + +my $dbh = $c.resolve(service => 'Database/dbh'); +isa_ok($dbh, DBI); + +is($dbh.dsn, 'dbi:sqlite:dbname=my-app.db'); +is($dbh.username, 'user'); +is($dbh.password, 'pass'); + +my $app = $c.resolve(service => 'application'); +isa_ok($app, MyApplication); + +isa_ok($app.logger, FileLogger); +is($app.logger, $logger); + +isa_ok($app.dbh, DBI); +isnt($app.dbh, $dbh); + +done; + +# vim:ft=perl6:foldmethod=manual -- cgit v1.2.3