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.connection;
25
import java.util.HashMap;
27
import junit.framework.TestCase;
29
import org.apache.log4j.ConsoleAppender;
30
import org.apache.log4j.Level;
31
import org.apache.log4j.Logger;
32
import org.apache.log4j.PatternLayout;
33
import org.jboss.logging.XLevel;
34
import org.jboss.remoting.Client;
35
import org.jboss.remoting.ConnectionListener;
36
import org.jboss.remoting.ConnectionValidator;
37
import org.jboss.remoting.InvokerLocator;
40
* @author <a href="mailto:tom.elrod@jboss.com">Tom Elrod</a>
42
public class ConnectionValidatorRemoteClient extends TestCase implements ConnectionListener
44
private static Logger log = Logger.getLogger(ConnectionValidatorRemoteClient.class);
46
// Default locator values
47
private static String transport = "socket";
48
private static String host = "localhost";
49
private static int port = 5400;
50
String locatorURI = transport + "://" + host + ":" + port;
51
private Throwable validatorResp = null;
52
private int counter = 0;
54
private Client remotingClient = null;
56
public void testValidator() throws Throwable
59
HashMap config = new HashMap();
60
config.put(ConnectionValidator.VALIDATOR_PING_TIMEOUT, "1000");
61
config.put("timeout", "20000");
62
remotingClient.addConnectionListener(this, config);
64
Object response = remotingClient.invoke("Do something");
66
log.info("Invocation response: " + response);
68
assertNull(validatorResp);
70
Thread.currentThread().sleep(30000);
72
log.info("validatorResp = " + validatorResp);
73
assertNotNull("Connection listener was not called as expected.", validatorResp);
74
assertEquals(1, counter);
77
public void setUp() throws Exception
79
Logger.getLogger("org.jboss.remoting").setLevel(XLevel.INFO);
80
Logger.getLogger("org.jboss.test.remoting").setLevel(Level.INFO);
81
String pattern = "[%d{ABSOLUTE}] [%t] %5p (%F:%L) - %m%n";
82
PatternLayout layout = new PatternLayout(pattern);
83
ConsoleAppender consoleAppender = new ConsoleAppender(layout);
84
Logger.getRootLogger().addAppender(consoleAppender);
86
InvokerLocator locator = new InvokerLocator(locatorURI);
87
log.info("Calling remoting server with locator uri of: " + locatorURI);
89
remotingClient = new Client(locator);
90
remotingClient.connect();
93
public void tearDown() throws Exception
95
if(remotingClient != null)
97
remotingClient.disconnect();
102
* Can pass transport and port to be used as parameters.
103
* Valid transports are 'rmi' and 'socket'.
107
public static void main(String[] args)
109
if(args != null && args.length == 3)
113
port = Integer.parseInt(args[2]);
116
ConnectionValidatorRemoteClient client = new ConnectionValidatorRemoteClient();
120
client.testValidator();
129
public void handleConnectionException(Throwable throwable, Client client)
131
log.info("Got connection exception.");
132
validatorResp = throwable;
b'\\ No newline at end of file'