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

« back to all changes in this revision

Viewing changes to src/tests/org/jboss/test/remoting/performance/raw/rmi/RMICallbackServer.java

  • Committer: Package Import Robot
  • Author(s): Torsten Werner
  • Date: 2011-09-09 14:01:03 UTC
  • mto: This revision was merged to the branch mainline in revision 9.
  • Revision ID: package-import@ubuntu.com-20110909140103-o8ucrolqt5g25k57
Tags: upstream-2.5.3.SP1
ImportĀ upstreamĀ versionĀ 2.5.3.SP1

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.performance.raw.rmi;
 
24
 
 
25
import java.rmi.RemoteException;
 
26
import java.rmi.registry.LocateRegistry;
 
27
import java.rmi.registry.Registry;
 
28
import java.rmi.server.UnicastRemoteObject;
 
29
import org.jboss.remoting.callback.Callback;
 
30
import org.jboss.remoting.callback.HandleCallbackException;
 
31
import org.jboss.test.remoting.performance.synchronous.PerformanceCallbackKeeper;
 
32
 
 
33
import EDU.oswego.cs.dl.util.concurrent.Latch;
 
34
 
 
35
/**
 
36
 * @author <a href="mailto:tom.elrod@jboss.com">Tom Elrod</a>
 
37
 */
 
38
public class RMICallbackServer extends UnicastRemoteObject implements RMICallbackServerRemote, PerformanceCallbackKeeper
 
39
{
 
40
   private String sessionId;
 
41
   private Latch lock;
 
42
   private int numberOfCallsProcessed = 0;
 
43
   private int numberofDuplicates = 0;
 
44
 
 
45
   public RMICallbackServer(String sessionId, Latch lock) throws RemoteException
 
46
   {
 
47
      super();
 
48
 
 
49
      this.sessionId = sessionId;
 
50
      this.lock = lock;
 
51
   }
 
52
 
 
53
   public int getNumberOfCallsProcessed()
 
54
   {
 
55
      return numberOfCallsProcessed;
 
56
   }
 
57
 
 
58
   public int getNumberOfDuplicates()
 
59
   {
 
60
      return numberofDuplicates;
 
61
   }
 
62
 
 
63
   /**
 
64
    * Will take the callback message and send back to client.
 
65
    * If client locator is null, will store them till client polls to get them.
 
66
    *
 
67
    * @param callback
 
68
    * @throws org.jboss.remoting.callback.HandleCallbackException
 
69
    *
 
70
    */
 
71
   public void handleCallback(Callback callback) throws HandleCallbackException
 
72
   {
 
73
      Object ret = callback.getCallbackObject();
 
74
      Integer[] handledArray = (Integer[]) ret;
 
75
      Integer numOfCallsHandled = (Integer) handledArray[0];
 
76
      Integer numOfDuplicates = (Integer) handledArray[1];
 
77
      System.out.println("Server is done.  Number of calls handled: " + numOfCallsHandled);
 
78
      numberOfCallsProcessed = numOfCallsHandled.intValue();
 
79
      System.out.println("Number of duplicate calls: " + numOfDuplicates);
 
80
      numberofDuplicates = numOfDuplicates.intValue();
 
81
      Object obj = callback.getCallbackHandleObject();
 
82
      //String handbackObj = (String) obj;
 
83
      //System.out.println("Handback object should be " + sessionId + " and server called back with " + handbackObj);
 
84
      lock.release();
 
85
   }
 
86
 
 
87
 
 
88
   public void start()
 
89
   {
 
90
      try
 
91
      {
 
92
//      if(System.getSecurityManager() == null)
 
93
//      {
 
94
//         System.setSecurityManager(new RMISecurityManager());
 
95
//      }
 
96
 
 
97
         int port = 1099;
 
98
         Registry registry = LocateRegistry.getRegistry(port);
 
99
 
 
100
         String name = "//" + sessionId + "/RMICallbackServer";
 
101
 
 
102
         registry.rebind(name, this);
 
103
         System.out.println("RMICallbackServer bound");
 
104
      }
 
105
      catch(Exception e)
 
106
      {
 
107
         System.err.println("RMICallbackServer exception: " + e.getMessage());
 
108
         e.printStackTrace();
 
109
      }
 
110
   }
 
111
 
 
112
   public void finishedProcessing(Object obj) throws RemoteException
 
113
   {
 
114
      System.out.println("finishedProcessing called with " + obj);
 
115
      Callback callback = (Callback) obj;
 
116
      try
 
117
      {
 
118
         handleCallback(callback);
 
119
      }
 
120
      catch(HandleCallbackException e)
 
121
      {
 
122
         e.printStackTrace();
 
123
      }
 
124
   }
 
125
}
 
 
b'\\ No newline at end of file'