mirror of https://github.com/apache/activemq.git
AMQ-7065 Update to Qpid JMS v0.37.0
Update to latest client release, adds some tests for split framed
message send / receive
(cherry picked from commit ac1e709dc4
)
This commit is contained in:
parent
7d2ba5741b
commit
4e627d28fe
|
@ -16,6 +16,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.activemq.transport.amqp;
|
package org.apache.activemq.transport.amqp;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertArrayEquals;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
|
@ -23,6 +24,7 @@ import static org.junit.Assert.assertTrue;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
|
||||||
|
import javax.jms.BytesMessage;
|
||||||
import javax.jms.Connection;
|
import javax.jms.Connection;
|
||||||
import javax.jms.JMSException;
|
import javax.jms.JMSException;
|
||||||
import javax.jms.Message;
|
import javax.jms.Message;
|
||||||
|
@ -45,6 +47,8 @@ import org.slf4j.LoggerFactory;
|
||||||
@RunWith(Parameterized.class)
|
@RunWith(Parameterized.class)
|
||||||
public class JMSLargeMessageSendRecvTest extends AmqpClientTestSupport {
|
public class JMSLargeMessageSendRecvTest extends AmqpClientTestSupport {
|
||||||
|
|
||||||
|
protected static final Logger LOG = LoggerFactory.getLogger(JMSLargeMessageSendRecvTest.class);
|
||||||
|
|
||||||
@Parameters(name="{0}")
|
@Parameters(name="{0}")
|
||||||
public static Collection<Object[]> data() {
|
public static Collection<Object[]> data() {
|
||||||
return Arrays.asList(new Object[][] {
|
return Arrays.asList(new Object[][] {
|
||||||
|
@ -55,46 +59,38 @@ public class JMSLargeMessageSendRecvTest extends AmqpClientTestSupport {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public TestName testName = new TestName();
|
||||||
|
|
||||||
public JMSLargeMessageSendRecvTest(String connectorScheme, boolean secure) {
|
public JMSLargeMessageSendRecvTest(String connectorScheme, boolean secure) {
|
||||||
super(connectorScheme, secure);
|
super(connectorScheme, secure);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Rule
|
@Test(timeout = 60 * 1000)
|
||||||
public TestName testName = new TestName();
|
public void testSendSmallerTextMessage() throws JMSException {
|
||||||
|
doTestSendTextMessageOfGivenSize(1024);
|
||||||
protected static final Logger LOG = LoggerFactory.getLogger(JMSLargeMessageSendRecvTest.class);
|
|
||||||
|
|
||||||
private String createLargeString(int sizeInBytes) {
|
|
||||||
byte[] base = {1, 2, 3, 4, 5, 6, 7, 8, 9, 0};
|
|
||||||
StringBuilder builder = new StringBuilder();
|
|
||||||
for (int i = 0; i < sizeInBytes; i++) {
|
|
||||||
builder.append(base[i % base.length]);
|
|
||||||
}
|
|
||||||
|
|
||||||
LOG.debug("Created string with size : " + builder.toString().getBytes().length + " bytes");
|
|
||||||
return builder.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 60 * 1000)
|
@Test(timeout = 60 * 1000)
|
||||||
public void testSendSmallerMessages() throws JMSException {
|
public void testSendSeriesOfSmallerTextMessages() throws JMSException {
|
||||||
for (int i = 512; i <= (8 * 1024); i += 512) {
|
for (int i = 512; i <= (8 * 1024); i += 512) {
|
||||||
doTestSendLargeMessage(i);
|
doTestSendTextMessageOfGivenSize(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 60 * 1000)
|
@Test(timeout = 60 * 1000)
|
||||||
public void testSendFixedSizedMessages() throws JMSException {
|
public void testSendFixedSizedTextMessages() throws JMSException {
|
||||||
doTestSendLargeMessage(65536);
|
doTestSendTextMessageOfGivenSize(65536);
|
||||||
doTestSendLargeMessage(65536 * 2);
|
doTestSendTextMessageOfGivenSize(65536 * 2);
|
||||||
doTestSendLargeMessage(65536 * 4);
|
doTestSendTextMessageOfGivenSize(65536 * 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(timeout = 60 * 1000)
|
@Test(timeout = 60 * 1000)
|
||||||
public void testSendHugeMessage() throws JMSException {
|
public void testSendHugeTextMessage() throws JMSException {
|
||||||
doTestSendLargeMessage(1024 * 1024 * 10);
|
doTestSendTextMessageOfGivenSize(1024 * 1024 * 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void doTestSendLargeMessage(int expectedSize) throws JMSException{
|
public void doTestSendTextMessageOfGivenSize(int expectedSize) throws JMSException{
|
||||||
LOG.info("doTestSendLargeMessage called with expectedSize " + expectedSize);
|
LOG.info("doTestSendLargeMessage called with expectedSize " + expectedSize);
|
||||||
String payload = createLargeString(expectedSize);
|
String payload = createLargeString(expectedSize);
|
||||||
assertEquals(expectedSize, payload.getBytes().length);
|
assertEquals(expectedSize, payload.getBytes().length);
|
||||||
|
@ -126,4 +122,86 @@ public class JMSLargeMessageSendRecvTest extends AmqpClientTestSupport {
|
||||||
assertEquals(payload, receivedText);
|
assertEquals(payload, receivedText);
|
||||||
connection.close();
|
connection.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 60 * 1000)
|
||||||
|
public void testSendSmallerBytesMessage() throws JMSException {
|
||||||
|
doTestSendBytesMessageOfGivenSize(1024);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 60 * 1000)
|
||||||
|
public void testSendSeriesOfSmallerBytesMessages() throws JMSException {
|
||||||
|
for (int i = 512; i <= (8 * 1024); i += 512) {
|
||||||
|
doTestSendBytesMessageOfGivenSize(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 60 * 1000)
|
||||||
|
public void testSendFixedSizedBytesMessages() throws JMSException {
|
||||||
|
doTestSendBytesMessageOfGivenSize(65536);
|
||||||
|
doTestSendBytesMessageOfGivenSize(65536 * 2);
|
||||||
|
doTestSendBytesMessageOfGivenSize(65536 * 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 60 * 1000)
|
||||||
|
public void testSendHugeBytesMessage() throws JMSException {
|
||||||
|
doTestSendBytesMessageOfGivenSize(1024 * 1024 * 5);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void doTestSendBytesMessageOfGivenSize(int expectedSize) throws JMSException{
|
||||||
|
LOG.info("doTestSendLargeMessage called with expectedSize " + expectedSize);
|
||||||
|
byte[] payload = createLargeByteArray(expectedSize);
|
||||||
|
assertEquals(expectedSize, payload.length);
|
||||||
|
|
||||||
|
Connection connection = JMSClientContext.INSTANCE.createConnection(getBrokerAmqpConnectionURI());
|
||||||
|
long startTime = System.currentTimeMillis();
|
||||||
|
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
|
||||||
|
Queue queue = session.createQueue(testName.getMethodName());
|
||||||
|
MessageProducer producer = session.createProducer(queue);
|
||||||
|
BytesMessage message = session.createBytesMessage();
|
||||||
|
message.writeBytes(payload);
|
||||||
|
producer.send(message);
|
||||||
|
long endTime = System.currentTimeMillis();
|
||||||
|
LOG.info("Returned from send after {} ms", endTime - startTime);
|
||||||
|
|
||||||
|
startTime = System.currentTimeMillis();
|
||||||
|
|
||||||
|
MessageConsumer consumer = session.createConsumer(queue);
|
||||||
|
connection.start();
|
||||||
|
LOG.info("Calling receive");
|
||||||
|
Message receivedMessage = consumer.receive();
|
||||||
|
assertNotNull(receivedMessage);
|
||||||
|
assertTrue(receivedMessage instanceof BytesMessage);
|
||||||
|
BytesMessage receivedBytesMessage = (BytesMessage) receivedMessage;
|
||||||
|
assertNotNull(receivedMessage);
|
||||||
|
endTime = System.currentTimeMillis();
|
||||||
|
LOG.info("Returned from receive after {} ms", endTime - startTime);
|
||||||
|
byte[] receivedBytes = new byte[(int) receivedBytesMessage.getBodyLength()];
|
||||||
|
receivedBytesMessage.readBytes(receivedBytes);
|
||||||
|
assertEquals(expectedSize, receivedBytes.length);
|
||||||
|
assertArrayEquals(payload, receivedBytes);
|
||||||
|
connection.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
private String createLargeString(int sizeInBytes) {
|
||||||
|
byte[] base = {1, 2, 3, 4, 5, 6, 7, 8, 9, 0};
|
||||||
|
StringBuilder builder = new StringBuilder();
|
||||||
|
for (int i = 0; i < sizeInBytes; i++) {
|
||||||
|
builder.append(base[i % base.length]);
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.debug("Created string with size : " + builder.toString().getBytes().length + " bytes");
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
private byte[] createLargeByteArray(int sizeInBytes) {
|
||||||
|
byte[] base = {1, 2, 3, 4, 5, 6, 7, 8, 9, 0};
|
||||||
|
|
||||||
|
byte[] payload = new byte[sizeInBytes];
|
||||||
|
for (int i = 0; i < sizeInBytes; i++) {
|
||||||
|
payload[i] = (base[i % base.length]);
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.debug("Created byte array with size : " + payload.length + " bytes");
|
||||||
|
return payload;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.apache.activemq.transport.amqp.client;
|
package org.apache.activemq.transport.amqp.client;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.nio.BufferOverflowException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -457,7 +458,7 @@ public class AmqpSender extends AmqpAbstractResource<Sender> {
|
||||||
try {
|
try {
|
||||||
encodedSize = message.encode(encodeBuffer, 0, encodeBuffer.length);
|
encodedSize = message.encode(encodeBuffer, 0, encodeBuffer.length);
|
||||||
break;
|
break;
|
||||||
} catch (java.nio.BufferOverflowException e) {
|
} catch (BufferOverflowException | IndexOutOfBoundsException e) {
|
||||||
encodeBuffer = new byte[encodeBuffer.length * 2];
|
encodeBuffer = new byte[encodeBuffer.length * 2];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -105,7 +105,7 @@
|
||||||
<linkedin-zookeeper-version>1.4.0</linkedin-zookeeper-version>
|
<linkedin-zookeeper-version>1.4.0</linkedin-zookeeper-version>
|
||||||
<zookeeper-version>3.4.6</zookeeper-version>
|
<zookeeper-version>3.4.6</zookeeper-version>
|
||||||
<qpid-proton-version>0.29.0</qpid-proton-version>
|
<qpid-proton-version>0.29.0</qpid-proton-version>
|
||||||
<qpid-jms-version>0.36.0</qpid-jms-version>
|
<qpid-jms-version>0.37.0</qpid-jms-version>
|
||||||
<qpid-jms-netty-version>4.1.28.Final</qpid-jms-netty-version>
|
<qpid-jms-netty-version>4.1.28.Final</qpid-jms-netty-version>
|
||||||
<qpid-jms-proton-version>0.29.0</qpid-jms-proton-version>
|
<qpid-jms-proton-version>0.29.0</qpid-jms-proton-version>
|
||||||
<netty-all-version>4.1.28.Final</netty-all-version>
|
<netty-all-version>4.1.28.Final</netty-all-version>
|
||||||
|
|
Loading…
Reference in New Issue