mirror of https://github.com/apache/activemq.git
git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@906101 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9ef09dfcab
commit
24f73a53c1
|
@ -120,6 +120,9 @@ public interface FrameTranslator {
|
||||||
msg.setPersistent("true".equals(o));
|
msg.setPersistent("true".equals(o));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Stomp specific headers
|
||||||
|
o = headers.remove(Stomp.Headers.RECEIPT_REQUESTED);
|
||||||
|
|
||||||
// now the general headers
|
// now the general headers
|
||||||
msg.setProperties(headers);
|
msg.setProperties(headers);
|
||||||
}
|
}
|
||||||
|
|
|
@ -273,6 +273,57 @@ public class StompTest extends CombinationTestSupport {
|
||||||
assertEquals("GroupID", "abc", amqMessage.getGroupID());
|
assertEquals("GroupID", "abc", amqMessage.getGroupID());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testReceipts() throws Exception {
|
||||||
|
|
||||||
|
StompConnection receiver = new StompConnection();
|
||||||
|
URI connectUri = new URI(bindAddress);
|
||||||
|
receiver.open(createSocket(connectUri));
|
||||||
|
String frame = "CONNECT\n" + "login: system\n" + "passcode: manager\n\n" + Stomp.NULL;
|
||||||
|
receiver.sendFrame(frame);
|
||||||
|
|
||||||
|
frame = receiver.receiveFrame();
|
||||||
|
assertTrue(frame.startsWith("CONNECTED"));
|
||||||
|
|
||||||
|
frame = "SUBSCRIBE\n" + "destination:/queue/" + getQueueName() + "\n" + "ack:auto\n\n" + Stomp.NULL;
|
||||||
|
receiver.sendFrame(frame);
|
||||||
|
|
||||||
|
frame = "CONNECT\n" + "login: system\n" + "passcode: manager\n\n" + Stomp.NULL;
|
||||||
|
stompConnection.sendFrame(frame);
|
||||||
|
|
||||||
|
frame = stompConnection.receiveFrame();
|
||||||
|
assertTrue(frame.startsWith("CONNECTED"));
|
||||||
|
|
||||||
|
frame = "SEND\n" + "destination:/queue/" + getQueueName() + "\n" + "receipt: msg-1\n" + "\n\n" + "Hello World" + Stomp.NULL;
|
||||||
|
stompConnection.sendFrame(frame);
|
||||||
|
|
||||||
|
frame = receiver.receiveFrame();
|
||||||
|
assertTrue(frame.startsWith("MESSAGE"));
|
||||||
|
assertTrue("Stomp Message does not contain receipt request", frame.indexOf(Stomp.Headers.RECEIPT_REQUESTED) == -1);
|
||||||
|
|
||||||
|
frame = stompConnection.receiveFrame();
|
||||||
|
assertTrue(frame.startsWith("RECEIPT"));
|
||||||
|
assertTrue("Receipt contains correct receipt-id", frame.indexOf(Stomp.Headers.Response.RECEIPT_ID) >= 0);
|
||||||
|
|
||||||
|
receiver.disconnect();
|
||||||
|
|
||||||
|
|
||||||
|
MessageConsumer consumer = session.createConsumer(queue);
|
||||||
|
|
||||||
|
frame = "SEND\n" + "destination:/queue/" + getQueueName() + "\n" + "receipt: msg-1\n" + "\n\n" + "Hello World" + Stomp.NULL;
|
||||||
|
stompConnection.sendFrame(frame);
|
||||||
|
|
||||||
|
frame = stompConnection.receiveFrame();
|
||||||
|
assertTrue(frame.startsWith("RECEIPT"));
|
||||||
|
assertTrue("Receipt contains correct receipt-id", frame.indexOf(Stomp.Headers.Response.RECEIPT_ID) >= 0);
|
||||||
|
|
||||||
|
TextMessage message = (TextMessage)consumer.receive(2500);
|
||||||
|
assertNotNull(message);
|
||||||
|
assertNull("JMS Message does not contain receipt request", message.getStringProperty(Stomp.Headers.RECEIPT_REQUESTED));
|
||||||
|
|
||||||
|
stompConnection.disconnect();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public void testSubscribeWithAutoAck() throws Exception {
|
public void testSubscribeWithAutoAck() throws Exception {
|
||||||
|
|
||||||
String frame = "CONNECT\n" + "login: system\n" + "passcode: manager\n\n" + Stomp.NULL;
|
String frame = "CONNECT\n" + "login: system\n" + "passcode: manager\n\n" + Stomp.NULL;
|
||||||
|
|
Loading…
Reference in New Issue