~ubuntu-branches/ubuntu/oneiric/libjboss-remoting-java/oneiric

« back to all changes in this revision

Viewing changes to tests/org/jboss/test/remoting/callback/push/disconnect/CallbackTestServer.java

  • Committer: Package Import Robot
  • Author(s): Torsten Werner
  • Date: 2011-09-09 14:01:03 UTC
  • mfrom: (1.1.6 upstream)
  • Revision ID: package-import@ubuntu.com-20110909140103-hqokx61534tas9rg
Tags: 2.5.3.SP1-1
* Newer but not newest upstream release. Do not build samples.
* Change debian/watch to upstream's svn repo.
* Add patch to fix compile error caused by tomcat update.
  (Closes: #628303)
* Switch to source format 3.0.
* Switch to debhelper level 7.
* Remove useless Depends.
* Update Standards-Version: 3.9.2.
* Update README.source.

Show diffs side-by-side

added added

removed removed

Lines of Context:
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
 
 
23
 
package org.jboss.test.remoting.callback.push.disconnect;
24
 
 
25
 
import java.util.ArrayList;
26
 
import java.util.Iterator;
27
 
import java.util.List;
28
 
import javax.management.MBeanServer;
29
 
import org.jboss.jrunit.extensions.ServerTestCase;
30
 
import org.jboss.remoting.InvocationRequest;
31
 
import org.jboss.remoting.InvokerLocator;
32
 
import org.jboss.remoting.ServerInvocationHandler;
33
 
import org.jboss.remoting.ServerInvoker;
34
 
import org.jboss.remoting.callback.Callback;
35
 
import org.jboss.remoting.callback.InvokerCallbackHandler;
36
 
import org.jboss.remoting.callback.HandleCallbackException;
37
 
import org.jboss.remoting.transport.Connector;
38
 
 
39
 
/**
40
 
 * Simple remoting server.  Uses inner class SampleInvocationHandler
41
 
 * as the invocation target handler class.
42
 
 *
43
 
 * @author <a href="mailto:telrod@e2technologies.net">Tom Elrod</a>
44
 
 */
45
 
public class CallbackTestServer extends ServerTestCase
46
 
{
47
 
   // Default locator values
48
 
   private static String transport = "socket";
49
 
   private static String host = "localhost";
50
 
   private static int port = 5500;
51
 
 
52
 
   private String locatorURI = transport + "://" + host + ":" + port;
53
 
   private Connector connector;
54
 
 
55
 
   // String to be returned from invocation handler upon client invocation calls.
56
 
   public static final String RESPONSE_VALUE = "This is the return to SampleInvocationHandler invocation";
57
 
   public static final String CALLBACK_VALUE = "This is the payload of callback invocation.";
58
 
 
59
 
 
60
 
   public void setupServer() throws Exception
61
 
   {
62
 
      InvokerLocator locator = new InvokerLocator(locatorURI);
63
 
      System.out.println("Starting remoting server with locator uri of: " + locatorURI);
64
 
      connector = new Connector();
65
 
      connector.setInvokerLocator(locator.getLocatorURI());
66
 
      connector.start();
67
 
 
68
 
      SampleInvocationHandler invocationHandler = new SampleInvocationHandler();
69
 
      // first parameter is sub-system name.  can be any String value.
70
 
      connector.addInvocationHandler("test", invocationHandler);
71
 
   }
72
 
 
73
 
   protected void setUp() throws Exception
74
 
   {
75
 
      setupServer();
76
 
   }
77
 
 
78
 
   protected void tearDown() throws Exception
79
 
   {
80
 
      if(connector != null)
81
 
      {
82
 
         connector.stop();
83
 
         connector.destroy();
84
 
      }
85
 
   }
86
 
 
87
 
   public static void main(String[] args)
88
 
   {
89
 
      CallbackTestServer server = new CallbackTestServer();
90
 
      try
91
 
      {
92
 
         server.setUp();
93
 
 
94
 
         while(true)
95
 
         {
96
 
            Thread.currentThread().sleep(5000);
97
 
         }
98
 
      }
99
 
      catch(Exception e)
100
 
      {
101
 
         e.printStackTrace();
102
 
      }
103
 
 
104
 
   }
105
 
 
106
 
   /**
107
 
    * Simple invocation handler implementation.
108
 
    */
109
 
   public static class SampleInvocationHandler implements ServerInvocationHandler
110
 
   {
111
 
 
112
 
      private List listeners = new ArrayList();
113
 
      private boolean sendCallbacks = false;
114
 
      private int callbackCounter = 1;
115
 
 
116
 
      public SampleInvocationHandler()
117
 
      {
118
 
         sendCallbacks();
119
 
      }
120
 
 
121
 
      /**
122
 
       * called to handle a specific invocation
123
 
       *
124
 
       * @param invocation
125
 
       * @return
126
 
       * @throws Throwable
127
 
       */
128
 
      public Object invoke(InvocationRequest invocation) throws Throwable
129
 
      {
130
 
         // Just going to return static string as this is just simple example code.
131
 
 
132
 
         sendCallbacks = true;
133
 
         return RESPONSE_VALUE;
134
 
 
135
 
      }
136
 
 
137
 
      private void sendCallbacks()
138
 
      {
139
 
         new Thread(new Runnable()
140
 
         {
141
 
            public void run()
142
 
            {
143
 
               while(true)
144
 
               {
145
 
 
146
 
                  try
147
 
                  {
148
 
                     Thread.currentThread().sleep(1000);
149
 
                  }
150
 
                  catch(InterruptedException e)
151
 
                  {
152
 
                     e.printStackTrace();
153
 
                  }
154
 
 
155
 
                  while(sendCallbacks)
156
 
                  {
157
 
 
158
 
                     // Will also fire callback to listeners if they were to exist using
159
 
                     // simple invocation request.
160
 
                     Callback callback = new Callback(new Integer(callbackCounter++));
161
 
                     Iterator itr = listeners.iterator();
162
 
                     while(itr.hasNext())
163
 
                     {
164
 
                        InvokerCallbackHandler callbackHandler = (InvokerCallbackHandler) itr.next();
165
 
                        try
166
 
                        {
167
 
                           callbackHandler.handleCallback(callback);
168
 
                        }
169
 
                        catch(HandleCallbackException e)
170
 
                        {
171
 
                           e.printStackTrace();
172
 
                        }
173
 
                     }
174
 
                     try
175
 
                     {
176
 
                        Thread.currentThread().sleep(1000);
177
 
                     }
178
 
                     catch(InterruptedException e)
179
 
                     {
180
 
                        e.printStackTrace();
181
 
                     }
182
 
                     
183
 
                  }
184
 
               }
185
 
 
186
 
            }
187
 
         }).start();
188
 
      }
189
 
 
190
 
      /**
191
 
       * Adds a callback handler that will listen for callbacks from
192
 
       * the server invoker handler.
193
 
       *
194
 
       * @param callbackHandler
195
 
       */
196
 
      public void addListener(InvokerCallbackHandler callbackHandler)
197
 
      {
198
 
         listeners.add(callbackHandler);
199
 
      }
200
 
 
201
 
      /**
202
 
       * Removes the callback handler that was listening for callbacks
203
 
       * from the server invoker handler.
204
 
       *
205
 
       * @param callbackHandler
206
 
       */
207
 
      public void removeListener(InvokerCallbackHandler callbackHandler)
208
 
      {
209
 
         listeners.remove(callbackHandler);
210
 
      }
211
 
 
212
 
      /**
213
 
       * set the mbean server that the handler can reference
214
 
       *
215
 
       * @param server
216
 
       */
217
 
      public void setMBeanServer(MBeanServer server)
218
 
      {
219
 
         // NO OP as do not need reference to MBeanServer for this handler
220
 
      }
221
 
 
222
 
      /**
223
 
       * set the invoker that owns this handler
224
 
       *
225
 
       * @param invoker
226
 
       */
227
 
      public void setInvoker(ServerInvoker invoker)
228
 
      {
229
 
         // NO OP as do not need reference back to the server invoker
230
 
      }
231
 
 
232
 
   }
233
 
}
 
 
b'\\ No newline at end of file'