/*
* JBoss, Home of Professional Open Source.
* Copyright 2011, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.as.test.integration.messaging.mgmt;
import static java.util.UUID.randomUUID;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.INCLUDE_RUNTIME;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.io.IOException;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Set;
import org.apache.activemq.artemis.api.core.TransportConfiguration;
import org.apache.activemq.artemis.api.core.client.ActiveMQClient;
import org.apache.activemq.artemis.api.core.client.ClientMessage;
import org.apache.activemq.artemis.api.core.client.ClientProducer;
import org.apache.activemq.artemis.api.core.client.ClientSession;
import org.apache.activemq.artemis.api.core.client.ClientSessionFactory;
import org.apache.activemq.artemis.api.core.client.ServerLocator;
import org.apache.activemq.artemis.core.remoting.impl.netty.NettyConnectorFactory;
import org.apache.activemq.artemis.core.remoting.impl.netty.TransportConstants;
import org.jboss.arquillian.container.test.api.RunAsClient;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.as.arquillian.api.ContainerResource;
import org.jboss.as.arquillian.container.ManagementClient;
import org.jboss.as.test.shared.TestSuiteEnvironment;
import org.jboss.dmr.ModelNode;
import org.jboss.dmr.ModelType;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
/**
* Tests the management API for Artemis core queues.
*
* @author Brian Stansberry (c) 2011 Red Hat Inc.
*/
@RunAsClient()
@RunWith(Arquillian.class)
public class CoreQueueManagementTestCase {
private static long count = System.currentTimeMillis();
@ContainerResource
private ManagementClient managementClient;
private ClientSessionFactory sessionFactory;
private ClientSession session;
private ClientSession consumerSession;
@Before
public void setup() throws Exception {
count++;
HashMap<String, Object> map = new HashMap<String, Object>();
map.put("host", TestSuiteEnvironment.getServerAddress());
map.put("port", 8080);
map.put(TransportConstants.HTTP_UPGRADE_ENABLED_PROP_NAME, true);
map.put(TransportConstants.HTTP_UPGRADE_ENDPOINT_PROP_NAME, "http-acceptor");
TransportConfiguration transportConfiguration =
new TransportConfiguration(NettyConnectorFactory.class.getName(), map);
ServerLocator locator = ActiveMQClient.createServerLocatorWithoutHA(transportConfiguration);
locator.setBlockOnDurableSend(true);
locator.setBlockOnNonDurableSend(true);
sessionFactory = locator.createSessionFactory();
session = sessionFactory.createSession("guest", "guest", false, true, true, false, 1);
session.createQueue(getQueueName(), getQueueName(), false);
session.createQueue(getOtherQueueName(), getOtherQueueName(), false);
consumerSession = sessionFactory.createSession("guest", "guest", false, false, false, false, 1);
}
@After
public void cleanup() throws Exception {
if (consumerSession != null) {
consumerSession.close();
}
if (session != null) {
session.deleteQueue(getQueueName());
session.deleteQueue(getOtherQueueName());
session.close();
}
if (sessionFactory != null) {
sessionFactory.cleanup();
sessionFactory.close();
}
}
@Test
public void testReadResource() throws Exception {
String address = randomUUID().toString();
String queueName = randomUUID().toString();
final ModelNode readQueueResourceOp = getQueueOperation("read-resource", queueName);
final ModelNode readRuntimeQueueResourceOp = getRuntimeQueueOperation("read-resource", queueName);
readRuntimeQueueResourceOp.get(INCLUDE_RUNTIME).set(true);
// resource does not exist
ModelNode result = execute(readQueueResourceOp, false);
assertTrue(result.toJSONString(false), result.asString().contains("WFLYCTL0216"));
result = execute(readRuntimeQueueResourceOp, false);
assertTrue(result.toJSONString(false), result.asString().contains("WFLYCTL0216"));
session.createQueue(address, queueName, false);
// resource does not exist for core queue...
result = execute(readQueueResourceOp, false);
assertTrue(result.toJSONString(false), result.asString().contains("WFLYCTL0216"));
// ... but it does for runtime-queue
result = execute(readRuntimeQueueResourceOp, true);
assertTrue(result.isDefined());
assertEquals(address, result.get("queue-address").asString());
session.deleteQueue(queueName);
// resource no longer exists
result = execute(readQueueResourceOp, false);
assertTrue(result.toJSONString(false), result.asString().contains("WFLYCTL0216"));
result = execute(readRuntimeQueueResourceOp, false);
assertTrue(result.toJSONString(false), result.asString().contains("WFLYCTL0216"));
}
@Test
public void testListAndCountMessages() throws Exception {
ClientProducer producer = session.createProducer(getQueueName());
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
ModelNode result = execute(getQueueOperation("list-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(2, result.asList().size());
result = execute(getQueueOperation("count-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(2, result.asInt());
}
@Test
public void testMessageCounters() throws Exception {
ClientProducer producer = session.createProducer(getQueueName());
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
ModelNode result = execute(getQueueOperation("list-message-counter-as-json"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(ModelType.STRING, result.getType());
result = execute(getQueueOperation("list-message-counter-as-html"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(ModelType.STRING, result.getType());
result = execute(getQueueOperation("list-message-counter-history-as-json"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(ModelType.STRING, result.getType());
result = execute(getQueueOperation("list-message-counter-history-as-html"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(ModelType.STRING, result.getType());
result = execute(getQueueOperation("reset-message-counter"), true);
Assert.assertFalse(result.isDefined());
result = execute(getQueueOperation("list-message-counter-history-as-json"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(ModelType.STRING, result.getType());
}
@Test
public void testPauseAndResume() throws Exception {
final ModelNode readAttr = getQueueOperation("read-attribute");
readAttr.get("name").set("paused");
ModelNode result = execute(readAttr, true);
Assert.assertTrue(result.isDefined());
Assert.assertFalse(result.asBoolean());
result = execute(getQueueOperation("pause"), true);
Assert.assertFalse(result.isDefined());
result = execute(readAttr, true);
Assert.assertTrue(result.isDefined());
Assert.assertTrue(result.asBoolean());
result = execute(getQueueOperation("resume"), true);
Assert.assertFalse(result.isDefined());
result = execute(readAttr, true);
Assert.assertTrue(result.isDefined());
Assert.assertFalse(result.asBoolean());
}
// @org.junit.Ignore("AS7-2480")
@Test
public void testMessageRemoval() throws Exception {
ClientProducer producer = session.createProducer(getQueueName());
ClientMessage msgA = session.createMessage(ClientMessage.TEXT_TYPE, false);
producer.send(msgA);
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
final ModelNode op = getQueueOperation("remove-message");
op.get("message-id").set(findMessageID());
ModelNode result = execute(op, true);
Assert.assertTrue(result.isDefined());
Assert.assertTrue(result.asBoolean());
result = execute(getQueueOperation("count-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(2, result.asInt());
result = execute(getQueueOperation("remove-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(2, result.asInt());
result = execute(getQueueOperation("count-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(0, result.asInt());
}
private long findMessageID() throws Exception {
final ModelNode result = execute(getQueueOperation("list-messages"), true);
return result.get(0).get("messageID").asLong();
}
// @org.junit.Ignore("AS7-2480")
@Test
public void testMessageMovement() throws Exception {
ClientProducer producer = session.createProducer(getQueueName());
ClientMessage msgA = session.createMessage(ClientMessage.TEXT_TYPE, false);
producer.send(msgA);
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
ModelNode op = getQueueOperation("move-message");
op.get("message-id").set(findMessageID());
op.get("other-queue-name").set(getOtherQueueName());
ModelNode result = execute(op, true);
Assert.assertTrue(result.isDefined());
Assert.assertTrue(result.asBoolean());
result = execute(getQueueOperation("count-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(2, result.asInt());
op = getQueueOperation("move-messages");
op.get("other-queue-name").set(getOtherQueueName());
result = execute(op, true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(2, result.asInt());
result = execute(getQueueOperation("count-messages"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(0, result.asInt());
}
// @org.junit.Ignore("AS7-2480")
@Test
public void testChangeMessagePriority() throws Exception {
ClientProducer producer = session.createProducer(getQueueName());
ClientMessage msgA = session.createMessage(ClientMessage.TEXT_TYPE, false);
producer.send(msgA);
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
producer.send(session.createMessage(ClientMessage.TEXT_TYPE, false));
Set<Integer> priorities = new HashSet<Integer>();
ModelNode result = execute(getQueueOperation("list-messages"), true);
Assert.assertEquals(3, result.asInt());
for (ModelNode node : result.asList()) {
priorities.add(node.get("priority").asInt());
}
int newPriority = -1;
for (int i = 0; i < 10; i++) {
if (!priorities.contains(i)) {
newPriority = i;
break;
}
}
long id = findMessageID();
ModelNode op = getQueueOperation("change-message-priority");
op.get("message-id").set(id);
op.get("new-priority").set(newPriority);
result = execute(op, true);
Assert.assertTrue(result.isDefined());
Assert.assertTrue(result.asBoolean());
result = execute(getQueueOperation("list-messages"), true);
boolean found = false;
for (ModelNode node : result.asList()) {
if (id == node.get("messageID").asLong()) {
Assert.assertEquals(newPriority, node.get("priority").asInt());
found = true;
break;
}
}
Assert.assertTrue(found);
op = getQueueOperation("change-messages-priority");
op.get("new-priority").set(newPriority);
result = execute(op, true);
Assert.assertTrue(result.isDefined());
Assert.assertTrue(result.asInt() > 1 && result.asInt() < 4);
result = execute(getQueueOperation("list-messages"), true);
for (ModelNode node : result.asList()) {
Assert.assertEquals(newPriority, node.get("priority").asInt());
}
}
@Test
public void testListConsumers() throws Exception {
consumerSession.createConsumer(getQueueName());
ModelNode result = execute(getQueueOperation("list-consumers-as-json"), true);
Assert.assertTrue(result.isDefined());
Assert.assertEquals(ModelType.STRING, result.getType());
}
private ModelNode getQueueOperation(String operationName, String queueName) {
final ModelNode address = new ModelNode();
address.add("subsystem", "messaging-activemq");
address.add("server", "default");
address.add("queue", queueName);
return org.jboss.as.controller.operations.common.Util.getEmptyOperation(operationName, address);
}
private ModelNode getRuntimeQueueOperation(String operationName, String queueName) {
final ModelNode address = new ModelNode();
address.add("subsystem", "messaging-activemq");
address.add("server", "default");
address.add("runtime-queue", queueName);
return org.jboss.as.controller.operations.common.Util.getEmptyOperation(operationName, address);
}
private ModelNode getQueueOperation(String operationName) {
return getQueueOperation(operationName, getQueueName());
}
private ModelNode execute(final ModelNode op, final boolean expectSuccess) throws IOException {
ModelNode response = managementClient.getControllerClient().execute(op);
final String outcome = response.get("outcome").asString();
if (expectSuccess) {
if (!"success".equals(outcome)) {
System.out.println(response);
}
Assert.assertEquals("success", outcome);
return response.get("result");
} else {
if ("success".equals(outcome)) {
System.out.println(response);
}
Assert.assertEquals("failed", outcome);
return response.get("failure-description");
}
}
private String getQueueName() {
return getClass().getSimpleName() + count;
}
private String getOtherQueueName() {
return getClass().getSimpleName() + "other" + count;
}
}