From 6b305ba49873fdf7fe782ab1bba42c3838cfe746 Mon Sep 17 00:00:00 2001 From: "Hiram R. Chirino" Date: Thu, 26 Jul 2012 03:11:45 +0000 Subject: [PATCH] Fixes AMQ-3945: QueueBrowser missing messages on first browse. git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@1365871 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/activemq/ActiveMQQueueBrowser.java | 28 +++++++++---------- .../activemq/joramtests/JoramJmsTest.java | 3 +- 2 files changed, 15 insertions(+), 16 deletions(-) diff --git a/activemq-core/src/main/java/org/apache/activemq/ActiveMQQueueBrowser.java b/activemq-core/src/main/java/org/apache/activemq/ActiveMQQueueBrowser.java index 50aa67a057..d2a0a5821d 100755 --- a/activemq-core/src/main/java/org/apache/activemq/ActiveMQQueueBrowser.java +++ b/activemq-core/src/main/java/org/apache/activemq/ActiveMQQueueBrowser.java @@ -19,15 +19,13 @@ package org.apache.activemq; import java.util.Enumeration; import java.util.concurrent.atomic.AtomicBoolean; +import javax.jms.*; import javax.jms.IllegalStateException; -import javax.jms.JMSException; -import javax.jms.Message; -import javax.jms.Queue; -import javax.jms.QueueBrowser; import org.apache.activemq.command.ActiveMQDestination; import org.apache.activemq.command.ConsumerId; import org.apache.activemq.command.MessageDispatch; +import org.apache.activemq.selector.SelectorParser; /** * A client uses a QueueBrowser object to look at messages on a @@ -69,27 +67,27 @@ public class ActiveMQQueueBrowser implements QueueBrowser, Enumeration { /** * Constructor for an ActiveMQQueueBrowser - used internally - * - * @param theSession - * @param dest - * @param selector * @throws JMSException */ protected ActiveMQQueueBrowser(ActiveMQSession session, ConsumerId consumerId, ActiveMQDestination destination, String selector, boolean dispatchAsync) throws JMSException { + if (destination == null) { + throw new InvalidDestinationException("Don't understand null destinations"); + } else if (destination.getPhysicalName() == null) { + throw new InvalidDestinationException("The destination object was not given a physical name."); + } + if (selector != null && selector.trim().length() != 0) { + // Validate the selector + SelectorParser.parse(selector); + } + this.session = session; this.consumerId = consumerId; this.destination = destination; this.selector = selector; this.dispatchAsync = dispatchAsync; - this.consumer = createConsumer(); } /** - * @param session - * @param originalDestination - * @param selectorExpression - * @param cnum - * @return * @throws JMSException */ private ActiveMQMessageConsumer createConsumer() throws JMSException { @@ -185,7 +183,7 @@ public class ActiveMQQueueBrowser implements QueueBrowser, Enumeration { } try { - Message answer = consumer.receiveNoWait(); + javax.jms.Message answer = consumer.receiveNoWait(); if (answer != null) { return answer; } diff --git a/activemq-core/src/test/java/org/apache/activemq/joramtests/JoramJmsTest.java b/activemq-core/src/test/java/org/apache/activemq/joramtests/JoramJmsTest.java index efc5708de4..d01ec721c2 100644 --- a/activemq-core/src/test/java/org/apache/activemq/joramtests/JoramJmsTest.java +++ b/activemq-core/src/test/java/org/apache/activemq/joramtests/JoramJmsTest.java @@ -28,6 +28,7 @@ import org.objectweb.jtests.jms.conform.message.MessageTypeTest; import org.objectweb.jtests.jms.conform.message.headers.MessageHeaderTest; import org.objectweb.jtests.jms.conform.message.properties.JMSXPropertyTest; import org.objectweb.jtests.jms.conform.message.properties.MessagePropertyConversionTest; +import org.objectweb.jtests.jms.conform.queue.QueueBrowserTest; import org.objectweb.jtests.jms.conform.queue.TemporaryQueueTest; import org.objectweb.jtests.jms.conform.selector.SelectorSyntaxTest; import org.objectweb.jtests.jms.conform.session.QueueSessionTest; @@ -58,9 +59,9 @@ public class JoramJmsTest extends TestCase { suite.addTestSuite(TopicSessionTest.class); suite.addTestSuite(TemporaryTopicTest.class); suite.addTestSuite(UnifiedSessionTest.class); + suite.addTestSuite(QueueBrowserTest.class); // TODO: figure out why the following tests are failing.. // suite.addTestSuite(MessagePropertyTest.class); -// suite.addTestSuite(QueueBrowserTest.class); // suite.addTestSuite(SelectorTest.class); return suite; }