org.tentackle.test.pdo.TestServer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tentackle-test-pdo Show documentation
Show all versions of tentackle-test-pdo Show documentation
Test depdendency to support writing PDO-based tests.
Also generates the SQL-scripts for the TT tables and
contains some PDO tests.
This artifact must be included in test-scope only!
/*
* Tentackle - a framework for java desktop applications
* http://www.tentackle.org
*
* This library 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 library 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 library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.tentackle.test.pdo;
import java.rmi.RemoteException;
import java.rmi.server.RMIClientSocketFactory;
import java.rmi.server.RMIServerSocketFactory;
import org.tentackle.dbms.rmi.DbServer;
import org.tentackle.dbms.rmi.RemoteDbConnectionImpl;
import org.tentackle.dbms.rmi.RemoteDbSession;
import org.tentackle.dbms.rmi.RemoteDbSessionImpl;
import org.tentackle.log.Logger;
import org.tentackle.log.LoggerFactory;
import org.tentackle.pdo.DomainContext;
import org.tentackle.pdo.PersistentDomainObject;
import org.tentackle.persist.app.ServerApplication;
import org.tentackle.session.LoginFailedException;
import org.tentackle.session.SessionInfo;
/**
* Server to run client transactions.
*
* @author harald
*/
public class TestServer extends ServerApplication {
/**
* the logger for this class.
*/
private static final Logger LOGGER = LoggerFactory.getLogger(TestServer.class);
/**
* The remote connection.
*/
public static class ConnectionImpl extends RemoteDbConnectionImpl {
private static final long serialVersionUID = 1L;
public ConnectionImpl(DbServer server, int port, RMIClientSocketFactory csf, RMIServerSocketFactory ssf)
throws RemoteException {
super(server, port, csf, ssf);
}
@Override
public RemoteDbSession createSession(SessionInfo clientInfo) throws RemoteException {
return new SessionImpl(this, clientInfo, getServer().getSessionInfo().clone());
}
}
/**
* The remote session.
*/
public static class SessionImpl extends RemoteDbSessionImpl {
public SessionImpl(RemoteDbConnectionImpl con, SessionInfo clientInfo, SessionInfo serverInfo)
throws RemoteException {
super(con, clientInfo, serverInfo);
}
@Override
public void verifySessionInfo(SessionInfo sessionInfo) throws LoginFailedException {
}
}
/**
* The server.
*/
public TestServer() {
super("TestServer", ConnectionImpl.class);
}
@Override
public > U getUser(DomainContext context, long userId) {
return null; // not used
}
private void sleep(long millis) {
try {
Thread.sleep(millis);
}
catch (InterruptedException ix) {
}
}
private static final String DURATION = "duration=";
/**
* Starts the server.
*
* Usage: <classname> [duration=<ms>]
*
* where:
* duration = optional time in ms the server will be running.
* Default is 10000ms (10s).
*
* @param args command line arguments
*/
public static void main(final String[] args) {
long duration = 10000; // default uptime in ms
for (String arg: args) {
if (arg.startsWith(DURATION)) {
duration = Long.valueOf(arg.substring(DURATION.length()));
}
}
try {
TestServer server = new TestServer();
server.start(args);
server.sleep(duration);
server.stop();
}
catch (Exception ex) {
LOGGER.severe("test server failed", ex);
System.exit(1);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy