regurgitator-extensions-mq-xml

regurgitator is a lightweight, modular, extendable java framework that you configure to ‘regurgitate’ canned or clever responses to incoming requests; useful for quickly mocking or prototyping services without writing any code. simply configure, deploy and run.

start your reading here: regurgitator-all

read more about regurgitator in xml here: regurgitator-core-xml

extension mq steps in xml

jms-call

a jms-call step make an outward jms call

<rgm:jms-call id="jms-call-1" destination="queue://queue-name"/>

while destination is specified in the xml, all other attributes of the call are set from parameters within the message object, as listed below:

context parameter call attribute default (if not specified)
request-metadata jms-message-id jms message id not set
request-metadata jms-type jms type not set
request-metadata jms-destination jms destination not set
request-metadata jms-correlation-id jms correlation id not set
request-metadata jms-delivery-mode jms delivery mode not set
request-metadata jms-expiration expiration not set
request-metadata jms-priority jms priority not set
request-metadata jms-redelivered jms redelivered not set
request-metadata jms-reply-to jms reply to not set
request-metadata jms-timestamp jms timestamp not set
request-properties [property name] object property not set
request-payload text payload not set

jms proxy

if using the MqMessageBridge to mock over jms, a jms-call step not placed within an isolated sequence will, upon execution, be given a message object that already contains the request-metadata context from the incoming jms message, and will therefore act as a jms proxy, creating an outgoing jms message identical to the one received by the MqMessageListener, except ‘redirected’ to a new destination. this is useful for forwarding on any jms messages you wish not to act upon.

If instead you wish the jms-call step to create an independent jms message, then the step should be placed within an isolated sequence, and should be proceeded by create-parameter steps to set the necessary jms message attributes.

<rg:sequence isolate="true">
    <rg:create-parameter name="request-payload:text" value="<message>this is my message content</message>"/>
    <rg:create-parameter name="request-metadata:jms-reply-to" value="queue://other-queue-name"/>
    <rg:create-parameter name="request-metadata:jms-expiration" value="360000" type="NUMBER"/>
    <rgm:jms-call destination="queue://queue-name"/>
</rg:sequence>

create-jms-response

a create-jms-response step returns a response from regurgitator, allowing response-metadata parameters to be set, e.g. jms-destination, jms-correlation-id and jms-type:

<rgm:create-jms-response source="response" jms-message-id="message-id" jms-type="my-jms-type" jms-destination="queue://my-destination" correlation-id="52908d79-b7c6-4e18-ab13-e991d1b67d8b" jms-priority="4" jms-delivery-mode="1" jms-expiration="1506253192636" jms-redelivered="true" jms-reply-to="queue://other-destination" jms-timestamp="1506253192636" />

api docs: 0.1.4 0.1.3 0.1.2