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
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 |
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>
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" />