diff options
author | Jesse Luehrs <doy@tozt.net> | 2012-12-28 14:00:33 -0600 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2012-12-28 14:00:33 -0600 |
commit | aa83df0cf585876df5901d15ae959fe319ee2dfe (patch) | |
tree | 4e40984839f6504a47160285a0ed33961df62cdd | |
parent | 0dca94214cbf0cd77a75d1ddb285ada5306be67e (diff) | |
download | p6-bread-board-aa83df0cf585876df5901d15ae959fe319ee2dfe.tar.gz p6-bread-board-aa83df0cf585876df5901d15ae959fe319ee2dfe.zip |
more tests
-rw-r--r-- | t/021_sugar.t | 50 |
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 |