NO-JIRA: add test of defaulted durable field

Verifies broker isnt affected by same behaviour from 5.x issue AMQ 7189
This commit is contained in:
Robbie Gemmell 2019-05-02 15:54:15 +01:00
parent 0dae70bc51
commit bfe0c5cc10
1 changed files with 34 additions and 16 deletions

View File

@ -45,7 +45,11 @@ import org.apache.activemq.transport.amqp.client.AmqpSender;
import org.apache.activemq.transport.amqp.client.AmqpSession; import org.apache.activemq.transport.amqp.client.AmqpSession;
import org.apache.activemq.transport.amqp.client.AmqpValidator; import org.apache.activemq.transport.amqp.client.AmqpValidator;
import org.apache.qpid.proton.amqp.Symbol; import org.apache.qpid.proton.amqp.Symbol;
import org.apache.qpid.proton.amqp.UnsignedByte;
import org.apache.qpid.proton.amqp.messaging.AmqpValue;
import org.apache.qpid.proton.amqp.messaging.Header;
import org.apache.qpid.proton.engine.Sender; import org.apache.qpid.proton.engine.Sender;
import org.apache.qpid.proton.message.Message;
import org.jgroups.util.UUID; import org.jgroups.util.UUID;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
@ -770,20 +774,25 @@ public class AmqpSendReceiveTest extends AmqpClientTestSupport {
@Test(timeout = 60000) @Test(timeout = 60000)
public void testMessageWithHeaderMarkedDurableIsPersisted() throws Exception { public void testMessageWithHeaderMarkedDurableIsPersisted() throws Exception {
doTestBrokerRestartAndDurability(true, true); doTestBrokerRestartAndDurability(true, true, false);
} }
@Test(timeout = 60000) @Test(timeout = 60000)
public void testMessageWithHeaderMarkedNonDurableIsNotPersisted() throws Exception { public void testMessageWithHeaderMarkedNonDurableIsNotPersisted() throws Exception {
doTestBrokerRestartAndDurability(false, true); doTestBrokerRestartAndDurability(false, true, true);
}
@Test(timeout = 60000)
public void testMessageWithHeaderDefaultedNonDurableIsNotPersisted() throws Exception {
doTestBrokerRestartAndDurability(false, true, false);
} }
@Test(timeout = 60000) @Test(timeout = 60000)
public void testMessageWithNoHeaderIsNotPersisted() throws Exception { public void testMessageWithNoHeaderIsNotPersisted() throws Exception {
doTestBrokerRestartAndDurability(false, false); doTestBrokerRestartAndDurability(false, false, false);
} }
private void doTestBrokerRestartAndDurability(boolean durable, boolean enforceHeader) throws Exception { private void doTestBrokerRestartAndDurability(boolean durable, boolean enforceHeader, boolean explicitSetNonDurable) throws Exception {
AmqpClient client = createAmqpClient(); AmqpClient client = createAmqpClient();
AmqpConnection connection = addConnection(client.connect()); AmqpConnection connection = addConnection(client.connect());
AmqpSession session = connection.createSession(); AmqpSession session = connection.createSession();
@ -792,28 +801,37 @@ public class AmqpSendReceiveTest extends AmqpClientTestSupport {
final Queue queueView1 = getProxyToQueue(getQueueName()); final Queue queueView1 = getProxyToQueue(getQueueName());
// Create default message that should be sent as non-durable Message protonMessage = Message.Factory.create();
AmqpMessage message = new AmqpMessage(); protonMessage.setMessageId("ID:Message:1");
message.setText("Test-Message -> non-durable"); protonMessage.setBody(new AmqpValue("Test-Message -> " + (durable ? "durable" : "non-durable")));
message.setMessageId("ID:Message:1"); if (durable || enforceHeader) {
Header header = new Header();
if (durable) { if (durable) {
message.setDurable(true); header.setDurable(true);
} else { } else {
if (enforceHeader) { if (explicitSetNonDurable) {
message.setDurable(false); header.setDurable(false);
assertNotNull(message.getWrappedMessage().getHeader());
} else { } else {
assertNull(message.getWrappedMessage().getHeader()); // Set priority so the durable field gets defaulted
header.setPriority(UnsignedByte.valueOf((byte) 5));
assertNull(header.getDurable());
} }
} }
protonMessage.setHeader(header);
} else {
assertNull("Should not have a header", protonMessage.getHeader());
}
AmqpMessage message = new AmqpMessage(protonMessage);
sender.send(message); sender.send(message);
connection.close(); connection.close();
Wait.assertEquals(1, queueView1::getMessageCount); Wait.assertEquals(1, queueView1::getMessageCount);
// Restart the server and the Queue should be empty // Restart the server and the Queue should be empty
// if the message was non-durable
server.stop(); server.stop();
server.start(); server.start();