NAME

Test::Plack::Handler::Stomp - testing library for Plack::Handler::Stomp

VERSION

version 1.07

SYNOPSIS

my $t = Test::Plack::Handler::Stomp->new();
$t->set_arg(
  subscriptions => [
    { destination => '/queue/input_queue',
      path_info => '/input_queue', },
  ],
);
$t->clear_frames_to_receive;

$t->queue_frame_to_receive(Net::Stomp::Frame->new({
      command => 'MESSAGE',
      headers => {
          destination => '/queue/input_queue',
          subscription => 0,
          type => 'my_type',
          'message-id' => 356,
      },
      body => '{"foo":"bar"}',
  }));

  $t->handler->run($app);

  check($t->frames_sent);

DESCRIPTION

Testing a PSGI application that expects JMS/STOMP messages can be a pain. This library helps reduce that pain.

It wraps a Plack::Handler::Stomp, connecting it to a Test::Plack::Handler::Stomp::FakeStomp instead of a real STOMP connection, and allows you to inspect everything that happens to the connection.

ATTRIBUTES

handler_args

Hashref, arguments to pass to Plack::Handler::Stomp's constructor. You can add to this via the "set_arg" method. Defaults to { one_shot => 1 }, to avoid having Plack::Handler::Stomp loop forever.

handler

A Plack::Handler::Stomp instance. It's built on-demand via "setup_handler". You can clear it with "clear_handler" to have it rebuilt (for example, if you have changed "handler_args")

frames_sent

Arrayref of Net::Stomp::Frame objects that Plack::Handler::Stomp sent. Can be edited via "queue_sent_frame", "sent_frames_count", "clear_sent_frames". Defaults to the empty array.

frames_to_receive

Arrayref of Net::Stomp::Frame objects that Plack::Handler::Stomp will consume. Can be edited via "queue_frame_to_receive", "next_frame_to_receive", "frames_left_to_receive", "clear_frames_to_receive".

Defaults to an array with a single ERROR frame.

constructor_calls

Arrayref of whatever was passed to the Test::Plack::Handler::Stomp::FakeStomp constructor. Can be edited via "queue_constructor_call", "constructor_calls_count", "clear_constructor_calls".

connection_calls

Arrayref of whatever was passed to the Test::Plack::Handler::Stomp::FakeStomp connect method. Can be edited via "queue_connection_call", "connection_calls_count", "clear_connection_calls".

disconnection_calls

Arrayref of whatever was passed to the Test::Plack::Handler::Stomp::FakeStomp disconnect method. Can be edited via "queue_disconnection_call", "disconnection_calls_count", "clear_disconnection_calls".

subscription_calls

Arrayref of whatever was passed to the Test::Plack::Handler::Stomp::FakeStomp subscribe method. Can be edited via "queue_subscription_call", "subscription_calls_count", "clear_subscription_calls".

unsubscription_calls

Arrayref of whatever was passed to the Test::Plack::Handler::Stomp::FakeStomp unsubscribe method. Can be edited via "queue_unsubscription_call", "unsubscription_calls_count", "clear_unsubscription_calls".

log_messages

Arrayref of whatever Plack::Handler::Stomp logs. Each element is a pair [ $level, $message ]. Can be edited via "add_log_message", "log_messages_count", "clear_log_messages".

METHODS

set_arg

$handler->set_arg(foo=>'bar',some=>'thing');

Sets arguments for Plack::Handler::Stomp's constructor, see /handler_args.

clear_handler

Destroys the "handler", forcing it to be rebuilt next time it's needed.

queue_sent_frame

Adds a frame to the end of "frames_sent".

sent_frames_count

Returns the number of elements in "frames_sent".

clear_sent_frames

Removes all elements from "frames_sent".

queue_frame_to_receive

Adds a frame to the end of "frames_to_receive".

next_frame_to_receive

Removes a frame from the beginning of "frames_to_receive" and returns it.

frames_left_to_receive

Returns the number of elements in "frames_to_receive".

clear_frames_to_receive

Removes all elements from "frames_to_receive".

queue_constructor_call

Adds a hashref to the end of "constructor_calls".

constructor_calls_count

Returns the number of elements in "constructor_calls".

clear_constructor_calls

Removes all elements from "constructor_calls".

queue_connection_call

Adds a hashref to the end of "connection_calls".

connection_calls_count

Returns the number of elements in "connection_calls".

clear_connection_calls

Removes all elements from "connection_calls".

queue_disconnection_call

Adds a hashref to the end of "disconnection_calls".

disconnection_calls_count

Returns the number of elements in "disconnection_calls".

clear_disconnection_calls

Removes all elements from "disconnection_calls".

queue_subscription_call

Adds a hashref to the end of "subscription_calls".

subscription_calls_count

Returns the number of elements in "subscription_calls".

clear_subscription_calls

Removes all elements from "subscription_calls".

queue_unsubscription_call

Adds a hashref to the end of "unsubscription_calls".

unsubscription_calls_count

Returns the number of elements in "unsubscription_calls".

clear_unsubscription_calls

Removes all elements from "unsubscription_calls".

add_log_message

Adds a pair to the end of "log_messages".

log_messages_count

Returns the number of elements in "log_messages".

clear_log_messages

Removes all elements from "log_messages".

setup_handler

Constructs a Plack::Handler::Stomp, setting it up to capture logging, passing "handler_args", and setting a connection_builder that returns a Test::Plack::Handler::Stomp::FakeStomp with all the callbacks set to accumulate calls in this object.

debug

info

warn

error

Logger delegate methods, the handler returned by "setup_handler" uses these to log. These methods accumulate log messages by calling "add_log_message".

clear_calls_and_queues

Calls the clearer for all the queue / accumulator attributes ("frames_sent", "frames_to_receive", "constructor_calls", "connection_calls", "disconnection_calls", "subscription_calls", "unsubscription_calls", "log_messages")

AUTHOR

Gianni Ceccarelli <gianni.ceccarelli@net-a-porter.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 by Net-a-porter.com.

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