diff options
author | Jesse Luehrs <doy@tozt.net> | 2012-12-28 15:24:58 -0600 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2012-12-28 15:24:58 -0600 |
commit | e874254a4ecd136bb7f057c25556f2097cb9de32 (patch) | |
tree | cda1d2e8fffab7e40548069ec4a4b8fd58630037 | |
parent | cc3420e2fca2b250ff65805c83714312d0d4727d (diff) | |
download | p6-bread-board-e874254a4ecd136bb7f057c25556f2097cb9de32.tar.gz p6-bread-board-e874254a4ecd136bb7f057c25556f2097cb9de32.zip |
implement array dependency specifications
-rw-r--r-- | lib/Bread/Board.pm | 12 | ||||
-rw-r--r-- | t/023_sugar.t | 47 |
2 files changed, 59 insertions, 0 deletions
diff --git a/lib/Bread/Board.pm b/lib/Bread/Board.pm index eecec5c..4b788b7 100644 --- a/lib/Bread/Board.pm +++ b/lib/Bread/Board.pm @@ -168,6 +168,12 @@ class ConstructorInjection does Service does HasParameters does HasDependencies # PERL6: type coercions NYI method new (*%params is copy) { if %params.<dependencies> { + if %params.<dependencies> ~~ Array { + %params.<dependencies> = %params.<dependencies>.map(-> $dep { + $dep.service_path.split('/').[*-1] => $dep + }).hash; + } + my $deps = {}; for %params.<dependencies>.keys -> $name { my $dep = %params.<dependencies>.{$name}; @@ -227,6 +233,12 @@ class BlockInjection does Service does HasParameters does HasDependencies { # PERL6: type coercions NYI method new (*%params is copy) { if %params.<dependencies> { + if %params.<dependencies> ~~ Array { + %params.<dependencies> = %params.<dependencies>.map(-> $dep { + $dep.service_path.split('/').[*-1] => $dep + }).hash; + } + my $deps = {}; for %params.<dependencies>.keys -> $name { my $dep = %params.<dependencies>.{$name}; diff --git a/t/023_sugar.t b/t/023_sugar.t new file mode 100644 index 0000000..de5ecc2 --- /dev/null +++ b/t/023_sugar.t @@ -0,0 +1,47 @@ +use v6; +use Test; + +use Bread::Board; + +class FileLogger { + has $.log_file; +} + +class MyApplication { + has FileLogger $.logger; +} + +my $c = container 'MyApp', { + service 'log_file', 'logfile.log'; + + service 'logger', ( + class => FileLogger, + lifecycle => Singleton, + dependencies => [ + depends_on('log_file'), + ], + ); + + service 'application', ( + class => MyApplication, + dependencies => [ + depends_on('logger'), + ], + ); +}; + +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 $app = $c.resolve(service => 'application'); +isa_ok($app, MyApplication); +isa_ok($app.logger, FileLogger); +is($app.logger, $logger); + +done; + +# vim:ft=perl6:foldmethod=manual |