summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2012-12-28 14:00:33 -0600
committerJesse Luehrs <doy@tozt.net>2012-12-28 14:00:33 -0600
commitaa83df0cf585876df5901d15ae959fe319ee2dfe (patch)
tree4e40984839f6504a47160285a0ed33961df62cdd
parent0dca94214cbf0cd77a75d1ddb285ada5306be67e (diff)
downloadp6-bread-board-aa83df0cf585876df5901d15ae959fe319ee2dfe.tar.gz
p6-bread-board-aa83df0cf585876df5901d15ae959fe319ee2dfe.zip
more tests
-rw-r--r--t/021_sugar.t50
1 files changed, 50 insertions, 0 deletions
diff --git a/t/021_sugar.t b/t/021_sugar.t
new file mode 100644
index 0000000..e643b82
--- /dev/null
+++ b/t/021_sugar.t
@@ -0,0 +1,50 @@
+use v6;
+use Test;
+
+use Bread::Board;
+
+class FileLogger {
+ has $.log_file;
+}
+
+class MyApplication {
+ has FileLogger $.logger;
+}
+
+sub loggers {
+ service 'log_file', 'logfile.log';
+ service 'logger', (
+ class => FileLogger,
+ lifecycle => Singleton,
+ dependencies => {
+ log_file => depends_on('log_file'),
+ },
+ );
+}
+
+my $c = container 'MyApp', {
+ loggers(); # reuse baby !!!
+
+ 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');
+
+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