mirror of https://github.com/apache/activemq.git
Added testcase by Rodrigo S de Castro. Thanks Rodrigo!
git-svn-id: https://svn.apache.org/repos/asf/incubator/activemq/trunk@397908 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
68b65fa340
commit
03de4c2d8b
|
@ -0,0 +1,173 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq;
|
||||
|
||||
import javax.jms.Connection;
|
||||
import javax.jms.DeliveryMode;
|
||||
import javax.jms.Destination;
|
||||
import javax.jms.JMSException;
|
||||
import javax.jms.Message;
|
||||
import javax.jms.MessageConsumer;
|
||||
import javax.jms.MessageListener;
|
||||
import javax.jms.MessageProducer;
|
||||
import javax.jms.Queue;
|
||||
import javax.jms.Session;
|
||||
import javax.jms.TextMessage;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
|
||||
public class MessageListenerRedeliveryTest extends TestCase {
|
||||
|
||||
private static final Log log = LogFactory.getLog(MessageListenerRedeliveryTest.class);
|
||||
private Connection connection;
|
||||
|
||||
protected void setUp() throws Exception {
|
||||
connection = createConnection();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see junit.framework.TestCase#tearDown()
|
||||
*/
|
||||
protected void tearDown() throws Exception {
|
||||
if (connection != null) {
|
||||
connection.close();
|
||||
connection = null;
|
||||
}
|
||||
}
|
||||
|
||||
protected RedeliveryPolicy getRedeliveryPolicy() {
|
||||
RedeliveryPolicy redeliveryPolicy = new RedeliveryPolicy();
|
||||
redeliveryPolicy.setInitialRedeliveryDelay(1000);
|
||||
redeliveryPolicy.setBackOffMultiplier((short) 5);
|
||||
redeliveryPolicy.setMaximumRedeliveries(10);
|
||||
redeliveryPolicy.setUseExponentialBackOff(true);
|
||||
return redeliveryPolicy;
|
||||
}
|
||||
|
||||
protected Connection createConnection() throws Exception {
|
||||
ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost?broker.persistent=false");
|
||||
factory.setRedeliveryPolicy(getRedeliveryPolicy());
|
||||
return factory.createConnection();
|
||||
}
|
||||
|
||||
private class ConsumerMessageListenerTest implements MessageListener {
|
||||
private ActiveMQMessageConsumer consumer;
|
||||
public int counter = 0;
|
||||
|
||||
public ConsumerMessageListenerTest(ActiveMQMessageConsumer consumer) {
|
||||
this.consumer = consumer;
|
||||
}
|
||||
|
||||
public void onMessage(Message message) {
|
||||
try {
|
||||
log.info("Message: " + message);
|
||||
counter++;
|
||||
if (counter <= 2) {
|
||||
log.info("ROLLBACK");
|
||||
consumer.rollback();
|
||||
} else {
|
||||
log.info("COMMIT");
|
||||
message.acknowledge();
|
||||
consumer.commit();
|
||||
}
|
||||
} catch (JMSException e) {
|
||||
System.err.println("Error when rolling back transaction");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private class SessionMessageListenerTest implements MessageListener {
|
||||
private Session session;
|
||||
public int counter = 0;
|
||||
|
||||
public SessionMessageListenerTest(Session session) {
|
||||
this.session = session;
|
||||
}
|
||||
|
||||
public void onMessage(Message message) {
|
||||
try {
|
||||
log.info("Message: " + message);
|
||||
counter++;
|
||||
if (counter < 2) {
|
||||
log.info("ROLLBACK");
|
||||
session.rollback();
|
||||
} else {
|
||||
log.info("COMMIT");
|
||||
message.acknowledge();
|
||||
session.commit();
|
||||
}
|
||||
} catch (JMSException e) {
|
||||
System.err.println("Error when rolling back transaction");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void testQueueRollbackMessageListener() throws JMSException {
|
||||
connection.start();
|
||||
|
||||
Session session = connection.createSession(true, Session.CLIENT_ACKNOWLEDGE);
|
||||
Queue queue = session.createQueue("queue-" + getName());
|
||||
MessageProducer producer = createProducer(session, queue);
|
||||
Message message = createTextMessage(session);
|
||||
producer.send(message);
|
||||
session.commit();
|
||||
|
||||
MessageConsumer consumer = session.createConsumer(queue);
|
||||
|
||||
ActiveMQMessageConsumer mc = (ActiveMQMessageConsumer) consumer;
|
||||
mc.setRedeliveryPolicy(getRedeliveryPolicy());
|
||||
|
||||
SessionMessageListenerTest listener = new SessionMessageListenerTest(session);
|
||||
consumer.setMessageListener(listener);
|
||||
|
||||
try {
|
||||
Thread.sleep(7000);
|
||||
} catch (InterruptedException e) {
|
||||
|
||||
}
|
||||
assertEquals(2, listener.counter);
|
||||
|
||||
producer.send(createTextMessage(session));
|
||||
session.commit();
|
||||
|
||||
try {
|
||||
Thread.sleep(2000);
|
||||
} catch (InterruptedException e) {
|
||||
// ignore
|
||||
}
|
||||
assertEquals(3, listener.counter);
|
||||
|
||||
session.close();
|
||||
}
|
||||
|
||||
private TextMessage createTextMessage(Session session) throws JMSException {
|
||||
return session.createTextMessage("Hello");
|
||||
}
|
||||
|
||||
private MessageProducer createProducer(Session session, Destination queue) throws JMSException {
|
||||
MessageProducer producer = session.createProducer(queue);
|
||||
producer.setDeliveryMode(getDeliveryMode());
|
||||
return producer;
|
||||
}
|
||||
|
||||
protected int getDeliveryMode() {
|
||||
return DeliveryMode.PERSISTENT;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue