mirror of https://github.com/apache/activemq.git
Fixed failing ChangeSessionDeliveryModeTest test in the assembly module.
git-svn-id: https://svn.apache.org/repos/asf/incubator/activemq/trunk@376766 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ffd4756740
commit
d86f77f462
|
@ -528,10 +528,8 @@ public class ActiveMQMessageConsumer implements MessageAvailableConsumer, StatsC
|
|||
}
|
||||
}
|
||||
|
||||
protected void checkMessageListener() throws IllegalStateException {
|
||||
if (messageListener != null) {
|
||||
throw new IllegalStateException("Cannot synchronously receive a message when a MessageListener is set");
|
||||
}
|
||||
protected void checkMessageListener() throws JMSException {
|
||||
session.checkMessageListener();
|
||||
}
|
||||
|
||||
private void beforeMessageIsConsumed(MessageDispatch md) {
|
||||
|
@ -713,8 +711,17 @@ public class ActiveMQMessageConsumer implements MessageAvailableConsumer, StatsC
|
|||
if (listener != null && started.get()) {
|
||||
ActiveMQMessage message = createActiveMQMessage(md);
|
||||
beforeMessageIsConsumed(md);
|
||||
try {
|
||||
listener.onMessage(message);
|
||||
afterMessageIsConsumed(md, false);
|
||||
} catch (RuntimeException e) {
|
||||
if ( session.isDupsOkAcknowledge() || session.isAutoAcknowledge() ) {
|
||||
// Redeliver the message
|
||||
} else {
|
||||
// Transacted or Client ack: Deliver the next message.
|
||||
afterMessageIsConsumed(md, false);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
unconsumedMessages.enqueue(md);
|
||||
if (availableListener != null) {
|
||||
|
|
|
@ -1666,5 +1666,16 @@ public class ActiveMQSession implements Session, QueueSession, TopicSession, Sta
|
|||
return "ActiveMQSession {id="+info.getSessionId()+",started="+started.get()+"}";
|
||||
}
|
||||
|
||||
public void checkMessageListener() throws JMSException {
|
||||
if (messageListener != null) {
|
||||
throw new IllegalStateException("Cannot synchronously receive a message when a MessageListener is set");
|
||||
}
|
||||
for (Iterator i = consumers.iterator(); i.hasNext();) {
|
||||
ActiveMQMessageConsumer consumer = (ActiveMQMessageConsumer) i.next();
|
||||
if( consumer.getMessageListener()!=null ) {
|
||||
throw new IllegalStateException("Cannot synchronously receive a message when a MessageListener is set");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue