[ 
https://issues.apache.org/jira/browse/AMQNET-424?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Timothy Bish resolved AMQNET-424.
---------------------------------

       Resolution: Fixed
    Fix Version/s: 1.6.0

Test added on trunk, works as expected using that codebase. 
                
> Creating consumer with invalid selector closes connection and other listeners.
> ------------------------------------------------------------------------------
>
>                 Key: AMQNET-424
>                 URL: https://issues.apache.org/jira/browse/AMQNET-424
>             Project: ActiveMQ .Net
>          Issue Type: Bug
>          Components: NMS
>    Affects Versions: 1.5.5
>         Environment: .NET 2.0
>            Reporter: Matthew Good
>            Assignee: Jim Gomes
>             Fix For: 1.6.0
>
>
> The following test illustrates the problem.  After the exception trying to 
> create a consumer, the connection is closed which affects other unrelated 
> consumers and senders.  The connection should not close and other consumers 
> should not be closed.
> {noformat}
>         [Test]
>         public void TestBadSelector()
>         {
>             ConnectionFactory factory = new 
> ConnectionFactory("tcp://activemqhost:61616");
>             IConnection conn = factory.CreateConnection();
>             ISession listenerSession = 
> conn.CreateSession(AcknowledgementMode.AutoAcknowledge);
>             string listenerQueueName = "ListenerTest";
>             IDestination listenerdestination = 
> listenerSession.GetQueue(listenerQueueName);
>             IMessageConsumer listenerconsumer = 
> listenerSession.CreateConsumer(listenerdestination);
>             listenerconsumer.Listener += new 
> MessageListener(consumer_Listener);
>             conn.Start();
>             ISession senderSession = 
> conn.CreateSession(AcknowledgementMode.AutoAcknowledge);
>             IDestination destination = 
> senderSession.GetQueue(listenerQueueName);
>             IMessageProducer producer = 
> senderSession.CreateProducer(destination);
>             ITextMessage goodMsg = 
> senderSession.CreateTextMessage("testGood");
>             producer.Send(goodMsg);
>             Thread.Sleep(1000);
>             Assert.AreEqual(1, _gotMessage);
>             try
>             {
>                 ISession badListenerSession = 
> conn.CreateSession(AcknowledgementMode.AutoAcknowledge);
>                 IMessageConsumer consumer2 = 
> badListenerSession.CreateConsumer(destination, "badSelector;too");
>                 Assert.Fail("Exception expected.");
>             }
>             catch(BrokerException   e)
>             {
>                 Console.WriteLine(e);
>             }
>             ITextMessage failMsg = 
> senderSession.CreateTextMessage("testFail");
>             producer.Send(failMsg);
>             Thread.Sleep(1000);
>             Assert.AreEqual(2, _gotMessage);
>             conn.Close();
>         }
>         private int _gotMessage = 0;
>         void consumer_Listener(IMessage message)
>         {
>             _gotMessage++;
>         }
> {noformat}

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to