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.
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.
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.
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.
23
package org.jboss.test.remoting.performance.raw.rmi;
25
import EDU.oswego.cs.dl.util.concurrent.Latch;
26
import junit.framework.Test;
27
import org.jboss.jrunit.decorators.ThreadLocalDecorator;
28
import org.jboss.logging.Logger;
29
import org.jboss.remoting.InvokerLocator;
30
import org.jboss.test.remoting.performance.synchronous.MultiThreadedPerformanceClientTest;
31
import org.jboss.test.remoting.performance.synchronous.PerformanceCallbackKeeper;
33
import java.rmi.Remote;
34
import java.rmi.registry.LocateRegistry;
35
import java.rmi.registry.Registry;
36
import java.rmi.server.UID;
40
* @author <a href="mailto:tom.elrod@jboss.com">Tom Elrod</a>
42
public class MultiThreadedRMIPerformanceClient extends MultiThreadedPerformanceClientTest
44
private int rmiPort = 1099;
45
private RMIServerRemote rmiServer;
46
private String clientSessionId = new UID().toString();
48
protected static final Logger log = Logger.getLogger(MultiThreadedRMIPerformanceClient.class);
50
public static Test suite()
52
return new ThreadLocalDecorator(MultiThreadedRMIPerformanceClient.class, 1);
59
String name = "//" + host+ "/RMIServer";
60
// RMIServer svr = (RMIServer) Naming.lookup(name);
64
//Registry regsitry = LocateRegistry.getRegistry("localhost", rmiPort);
65
Registry regsitry = LocateRegistry.getRegistry(rmiPort);
66
Remote remoteObj = regsitry.lookup(name);
67
rmiServer = (RMIServerRemote) remoteObj;
71
log.error("Error initializating rmi client.", e);
76
* This will be used to create callback server
82
protected InvokerLocator initServer(int port) throws Exception
87
protected PerformanceCallbackKeeper addCallbackListener(String sessionId, Latch serverDoneLock)
90
RMICallbackServer callbackServer = new RMICallbackServer(clientSessionId, serverDoneLock);
91
callbackServer.start();
92
return callbackServer;
95
protected void populateMetadata(Map metadata)
97
super.populateMetadata(metadata);
98
metadata.put("transport", "raw_rmi");
99
metadata.put("serialization", "java");
102
protected Object getBenchmarkAlias()
104
String config = System.getProperty("alias");
105
if(config == null || config.length() == 0)
107
config = System.getProperty("jboss-junit-configuration");
108
if(config == null || config.length() == 0)
110
config = "raw_rmi" + "_" + getNumberOfCalls() + "_" + getPayloadSize() + "_" + "java";
117
protected Object makeInvocation(String method, Object param) throws Throwable
119
if(method.equals(NUM_OF_CALLS))
121
return rmiServer.sendNumberOfCalls(clientSessionId, param);
123
else if(method.equals(TEST_INVOCATION))
125
return rmiServer.makeCall(clientSessionId, param);
129
throw new Exception("Was not able to find remote method call for " + method);
b'\\ No newline at end of file'