1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
use strict;
use warnings;
use Test::More;
use Message::Passing::DSL;
my $c = message_chain {
output test => (
class => 'Test',
);
filter t => (
class => 'T',
output_to => ['test'],
);
filter null => (
class => 'Null',
output_to => 't',
);
input stdin => (
class => 'STDIN',
output_to => 'null',
);
};
isa_ok $c->[0], 'Message::Passing::Input::STDIN';
isa_ok $c->[0]->output_to, 'Message::Passing::Filter::Null';
isa_ok $c->[0]->output_to->output_to, 'Message::Passing::Filter::T';
isa_ok $c->[0]->output_to->output_to->output_to->[0], 'Message::Passing::Output::Test';
$c->[0]->output_to->consume({foo => 'bar'});
my $test = $c->[0]->output_to->output_to->output_to->[0];
is $test->message_count, 1;
is_deeply [$test->messages], [{foo => 'bar'}];
$c = message_chain {
output logcollector_central => (
class => 'STDOUT',
);
input null_in => (
class => 'Null',
output_to => 'logcollector_central',
);
input test_in => (
class => 'STDIN',
output_to => 'logcollector_central',
);
};
is ref($c), 'ARRAY';
is scalar(@$c), 2;
my @chain = sort @$c;
isa_ok $chain[0], 'Message::Passing::Input::Null';
isa_ok $chain[1], 'Message::Passing::Input::STDIN';
isa_ok $chain[0]->output_to, 'Message::Passing::Output::STDOUT';
isa_ok $chain[1]->output_to, 'Message::Passing::Output::STDOUT';
is $chain[0]->output_to, $chain[1]->output_to;
done_testing;
|