ARTEMIS-3313 add export/import test

This commit is contained in:
Justin Bertram 2021-10-08 10:31:47 -05:00
parent 452d3dfc15
commit 7e7f7496c1
1 changed files with 75 additions and 0 deletions
tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/integration/persistence

View File

@ -1128,4 +1128,79 @@ public class XmlImportExportTest extends ActiveMQTestBase {
assertTrue(server.getAddressInfo(myAddress).getRoutingTypes().contains(RoutingType.ANYCAST));
assertTrue(server.getAddressInfo(myAddress).getRoutingTypes().contains(RoutingType.MULTICAST));
}
@Test
public void testImportWrongRoutingType() throws Exception {
SimpleString myAddress = SimpleString.toSimpleString("myAddress");
SimpleString myQueue = SimpleString.toSimpleString("myQueue");
SimpleString dla = SimpleString.toSimpleString("DLA");
SimpleString dlaPrefix = SimpleString.toSimpleString("DLA.");
String payload = "myMessagePayload";
server = createServer(true);
server.start();
ServerLocator locator = createInVMNonHALocator();
ClientSessionFactory factory = locator.createSessionFactory();
ClientSession session = factory.createSession(false, true, false);
//Create ANYCAST queue and set "AutoCreateDeadLetterResources"
//Send message with ANYCAST RoutingType
server.getAddressSettingsRepository().addMatch(myAddress.toString(), new AddressSettings().setMaxDeliveryAttempts(1).setDeadLetterAddress(dla).setAutoCreateDeadLetterResources(true).setDeadLetterQueuePrefix(dlaPrefix));
session.createQueue(new QueueConfiguration(myQueue).setAddress(myAddress).setDurable(true).setRoutingType(RoutingType.ANYCAST));
ClientProducer producer = session.createProducer(myAddress);
producer.send(createTextMessage(session, payload).putByteProperty(Message.HDR_ROUTING_TYPE, (byte) 1));
session.start();
ClientConsumer consumer = session.createConsumer(myQueue);
ClientMessage m = consumer.receive(500);
m.acknowledge();
assertNotNull(m);
assertEquals(m.getBodyBuffer().readString(), payload);
assertEquals(m.getRoutingType(), RoutingType.ANYCAST);
// Rollback to place ANYCAST message on DLA (MULTICAST)
session.rollback();
m = consumer.receiveImmediate();
assertNull(m);
consumer.close();
session.close();
locator.close();
server.stop();
ByteArrayOutputStream xmlOutputStream = new ByteArrayOutputStream();
XmlDataExporter xmlDataExporter = new XmlDataExporter();
xmlDataExporter.process(xmlOutputStream, server.getConfiguration().getBindingsDirectory(), server.getConfiguration().getJournalDirectory(), server.getConfiguration().getPagingDirectory(), server.getConfiguration().getLargeMessagesDirectory());
if (logger.isDebugEnabled()) logger.debug(new String(xmlOutputStream.toByteArray()));
clearDataRecreateServerDirs();
server.start();
checkForLongs();
locator = createInVMNonHALocator();
factory = locator.createSessionFactory();
session = factory.createSession(false, false, true);
ClientSession managementSession = factory.createSession(false, true, true);
ByteArrayInputStream xmlInputStream = new ByteArrayInputStream(xmlOutputStream.toByteArray());
XmlDataImporter xmlDataImporter = new XmlDataImporter();
xmlDataImporter.validate(xmlInputStream);
xmlInputStream.reset();
xmlDataImporter.process(xmlInputStream, session, managementSession);
//Check that message is imported with no "routingType" and is intact
assertTrue(server.getTotalMessageCount() == 1);
session.start();
consumer = session.createConsumer(dlaPrefix.concat(myAddress));
m = consumer.receive(500);
assertNotNull(m);
assertEquals(m.getBodyBuffer().readString(), payload);
assertEquals(m.getRoutingType(), null);
consumer.close();
session.close();
locator.close();
server.stop();
}
}