org.jboss.jca.test.eis.impl.EISServer Maven / Gradle / Ivy
/*
* IronJacamar, a Java EE Connector Architecture implementation
* Copyright 2012, Red Hat Inc, and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.jca.test.eis.impl;
import org.jboss.jca.test.eis.Handler;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
/**
* @author Jesper Pedersen
*/
public class EISServer
{
/** The handler server */
private static Map handlerServers =
Collections.synchronizedMap(new HashMap());
/* The handler class name */
private String handlerClassName;
/* The class loader */
private ClassLoader classLoader;
/* The host */
private String host;
/* The port */
private int port;
/* The control port */
private int controlPort;
/**
* Constructor
*/
public EISServer()
{
this.handlerClassName = null;
this.classLoader = null;
this.host = "localhost";
this.port = 1400;
this.controlPort = 1401;
}
/**
* Set the handler class name
* @param v The name
*/
public void setHandlerClassName(String v)
{
this.handlerClassName = v;
}
/**
* Set class loader
* @param v The value
*/
public void setClassLoader(ClassLoader v)
{
this.classLoader = v;
}
/**
* Set the host name
* @param v The name
*/
public void setHost(String v)
{
this.host = v;
}
/**
* Set the port
* @param v The value
*/
public void setPort(int v)
{
this.port = v;
}
/**
* Startup
* @exception Throwable Thrown if an error occurs
*/
public void startup() throws Throwable
{
if (handlerClassName == null || handlerClassName.trim().equals(""))
throw new IllegalStateException("HandlerClassName isn't defined");
shutdown();
ClassLoader cl = classLoader;
if (cl == null)
cl = EISServer.class.getClassLoader();
Class handler = Class.forName(handlerClassName, true, cl);
if (!Handler.class.isAssignableFrom(handler))
throw new IllegalArgumentException("The specified handler class doesn't implement the interface");
HandlerServer handlerServer = new HandlerServer(host, port, handler);
handlerServer.start();
handlerServers.put(getKey(), handlerServer);
}
/**
* Shutdown
* @exception Throwable Thrown if an error occurs
*/
public void shutdown() throws Throwable
{
HandlerServer handlerServer = handlerServers.remove(getKey());
if (handlerServer != null)
handlerServer.stop();
}
/**
* Get the key
* @return The value
*/
private String getKey()
{
return host + ":" + port;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy