NAME

Test::Stream::Stack - Object to manage a stack of Test::Stream::Hub instances.

EXPERIMENTAL CODE WARNING

This is an experimental release! Test-Stream, and all its components are still in an experimental phase. This dist has been released to cpan in order to allow testers and early adopters the chance to write experimental new tools with it, or to add experimental support for it into old tools.

PLEASE DO NOT COMPLETELY CONVERT OLD TOOLS YET. This experimental release is very likely to see a lot of code churn. API's may break at any time. Test-Stream should NOT be depended on by any toolchain level tools until the experimental phase is over.

DESCRIPTION

This module is used to represent and manage a stack of Test::Stream::Hub objects. Hubs are usually in a stack so that you can push a new hub into place that can intercept and handle events differently than the primary hub.

SYNOPSIS

my $stack = Test::Stream::Stack->new;
my $hub = $stack->top;

METHODS

$stack = Test::Stream::Stack->new()

This will create a new empty stack instance. All arguments are ignored.

$hub = $stack->new_hub()
$hub = $stack->new_hub(%params)
$hub = $stack->new_hub(%params, class => $class)

This will generate a new hub and push it to the top of the stack. Optionally you can provide arguments that will be passed into the constructor for the Test::Stream::Hub object.

If you specify the 'class' => $class argument, the new hub will be an instance of the specified class.

Unless your parameters specify 'formatter' or 'ipc' arguments, the formatter and ipc instance will be inherited from the current top hub. You can set the parameters to undef to avoid having a formatter or ipc instance.

If there is no top hub, and you do not ask to leave ipc and formatter undef, then a new Test::Stream::TAP formatter will be used, and the IPC instance from Test::Stream::Sync will be used.

$hub = $stack->top()

This will return the top hub from the stack. If there is no top hub yet this will create it.

$hub = $stack->peek()

This will return the top hub from the stack. If there is no top hub yet this will return undef.

$stack->cull

This will call $hub->cull on all hubs in the stack.

@hubs = $stack->all

This will return all the hubs in the stack as a list.

$stack->clear

This will completely remove all hubs from the stack. Normally you do not want to do this, but there are a few valid reasons for it.

$stack->push($hub)

This will push the new hub onto the stack.

$stack->pop($hub)

This will pop a hub from the stack, if the hub at the top of the stack does not match the hub you expect (passed in as an argument) it will throw an exception.

SOURCE

The source code repository for Test::Stream can be found at http://github.com/Test-More/Test-Stream/.

MAINTAINERS

Chad Granum <exodist@cpan.org>

AUTHORS

Chad Granum <exodist@cpan.org>

COPYRIGHT

Copyright 2015 Chad Granum <exodist7@gmail.com>.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

See http://www.perl.com/perl/misc/Artistic.html