summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/Bread/Board.pm12
-rw-r--r--t/023_sugar.t47
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