KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jboss > test > jbossmq > test > ConcurrentDeliveryUnitTestCase


1 /*
2   * JBoss, Home of Professional Open Source
3   * Copyright 2005, JBoss Inc., and individual contributors as indicated
4   * by the @authors tag. See the copyright.txt in the distribution for a
5   * full listing of individual contributors.
6   *
7   * This is free software; you can redistribute it and/or modify it
8   * under the terms of the GNU Lesser General Public License as
9   * published by the Free Software Foundation; either version 2.1 of
10   * the License, or (at your option) any later version.
11   *
12   * This software is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15   * Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public
18   * License along with this software; if not, write to the Free
19   * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20   * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21   */

22 package org.jboss.test.jbossmq.test;
23
24 import javax.jms.Message JavaDoc;
25 import javax.jms.MessageListener JavaDoc;
26 import javax.jms.QueueConnection JavaDoc;
27 import javax.jms.QueueConnectionFactory JavaDoc;
28 import javax.jms.QueueReceiver JavaDoc;
29 import javax.jms.QueueSender JavaDoc;
30 import javax.jms.QueueSession JavaDoc;
31 import javax.jms.Session JavaDoc;
32 import javax.jms.TemporaryQueue JavaDoc;
33 import javax.naming.Context JavaDoc;
34
35 import org.jboss.test.JBossTestCase;
36
37 /**
38  * Concurrent delivery tests
39  *
40  * @author <a HREF="mailto:adrian@jboss.org>Adrian Brock</a>
41  * @version <tt>$Revision: 37406 $</tt>
42  */

43 public class ConcurrentDeliveryUnitTestCase extends JBossTestCase
44 {
45    static String JavaDoc QUEUE_FACTORY = "ConnectionFactory";
46
47    QueueConnection JavaDoc queueConnection;
48
49    int completed = 0;
50    boolean inDelivery = false;
51    boolean concurrent = false;
52    
53    public ConcurrentDeliveryUnitTestCase(String JavaDoc name) throws Exception JavaDoc
54    {
55       super(name);
56    }
57
58    public void testConcurrentDelivery() throws Exception JavaDoc
59    {
60       connect();
61       try
62       {
63          MyMessageListener messageListener = new MyMessageListener();
64          
65          QueueSession JavaDoc session = queueConnection.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
66          TemporaryQueue JavaDoc queue1 = session.createTemporaryQueue();
67          QueueSender JavaDoc sender1 = session.createSender(queue1);
68          QueueReceiver JavaDoc receiver1 = session.createReceiver(queue1);
69          receiver1.setMessageListener(messageListener);
70          TemporaryQueue JavaDoc queue2 = session.createTemporaryQueue();
71          QueueSender JavaDoc sender2 = session.createSender(queue2);
72          QueueReceiver JavaDoc receiver2 = session.createReceiver(queue2);
73          receiver2.setMessageListener(messageListener);
74          Message JavaDoc message = session.createMessage();
75          queueConnection.start();
76
77          sender1.send(message);
78          sender2.send(message);
79
80          synchronized (messageListener)
81          {
82             while (completed < 2)
83             {
84                getLog().debug("Waiting for completion " + completed);
85                messageListener.wait();
86             }
87          }
88          getLog().debug("Completed");
89          
90          if (concurrent)
91             fail("Concurrent delivery");
92       }
93       finally
94       {
95          disconnect();
96       }
97    }
98
99    protected void connect() throws Exception JavaDoc
100    {
101       Context JavaDoc context = getInitialContext();
102       QueueConnectionFactory JavaDoc queueFactory = (QueueConnectionFactory JavaDoc) context.lookup(QUEUE_FACTORY);
103       queueConnection = queueFactory.createQueueConnection();
104
105       getLog().debug("Connection established.");
106    }
107
108    protected void disconnect()
109    {
110       try
111       {
112          if (queueConnection != null)
113             queueConnection.close();
114       }
115       catch (Throwable JavaDoc ignored)
116       {
117          getLog().warn("Ignored", ignored);
118       }
119
120       getLog().debug("Connection closed.");
121    }
122
123    public class MyMessageListener implements MessageListener JavaDoc
124    {
125       public void onMessage(Message JavaDoc message)
126       {
127          synchronized (this)
128          {
129             if (inDelivery)
130                concurrent = true;
131             inDelivery = true;
132             getLog().debug("In delivery " + message);
133          }
134          
135          try
136          {
137             Thread.sleep(10000);
138          }
139          catch (Throwable JavaDoc ignored)
140          {
141             getLog().warn("Ignored ", ignored);
142          }
143          
144          synchronized (this)
145          {
146             inDelivery = false;
147             ++completed;
148             notifyAll();
149             getLog().debug("Completed " + message);
150          }
151       }
152    }
153 }
154
155
Popular Tags