summaryrefslogtreecommitdiffstats
path: root/branches/sca-java-M2/sca/services/transports/http.jetty/src
diff options
context:
space:
mode:
authorlresende <lresende@13f79535-47bb-0310-9956-ffa450edef68>2009-11-11 23:13:23 +0000
committerlresende <lresende@13f79535-47bb-0310-9956-ffa450edef68>2009-11-11 23:13:23 +0000
commit6d0e93c68d3aeaeb4bb6d96ac0460eec40ef786e (patch)
treea956ed510e14a5509b8ef49fae42cfd439629825 /branches/sca-java-M2/sca/services/transports/http.jetty/src
parent3ac2d800d840f03618fc364090d786effde84b1f (diff)
Moving 1.x branches
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@835143 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'branches/sca-java-M2/sca/services/transports/http.jetty/src')
-rw-r--r--branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyLogger.java106
-rw-r--r--branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyService.java38
-rw-r--r--branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyServiceImpl.java314
-rw-r--r--branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/TransportMonitor.java42
-rw-r--r--branches/sca-java-M2/sca/services/transports/http.jetty/src/test/java/org/apache/tuscany/service/jetty/JettyServiceImplTestCase.java173
5 files changed, 0 insertions, 673 deletions
diff --git a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyLogger.java b/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyLogger.java
deleted file mode 100644
index d42b301fbb..0000000000
--- a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyLogger.java
+++ /dev/null
@@ -1,106 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-package org.apache.tuscany.service.jetty;
-
-import org.mortbay.log.Logger;
-
-/**
- * Serves as a wrapper for a {@link TransportMonitor} to replace Jetty's logging mechanism
- *
- * @version $Rev$ $Date$
- */
-public class JettyLogger implements Logger {
-
- private TransportMonitor monitor;
- private boolean debugEnabled;
-
- public void setMonitor(TransportMonitor monitor) {
- this.monitor = monitor;
- }
-
- public boolean isDebugEnabled() {
- return debugEnabled;
- }
-
- public void setDebugEnabled(boolean debugEnabled) {
- this.debugEnabled = debugEnabled;
- }
-
- public void info(String msg, Object arg0, Object arg1) {
- if (monitor != null) {
- monitor.debug(msg, arg0, arg1);
- } else if (debugEnabled) {
- System.err.println(":INFO: " + format(msg, arg0, arg1));
- }
- }
-
- public void debug(String msg, Throwable th) {
- if (debugEnabled) {
- if (monitor != null) {
- monitor.debug(msg, th);
- } else {
- System.err.println(":DEBUG: " + msg);
- th.printStackTrace();
- }
- }
- }
-
- public void debug(String msg, Object arg0, Object arg1) {
- if (debugEnabled) {
- if (monitor != null) {
- monitor.debug(msg, arg0, arg1);
- } else {
- System.err.println(":DEBUG: " + format(msg, arg0, arg1));
- }
- }
- }
-
- public void warn(String msg, Object arg0, Object arg1) {
- if (monitor != null) {
- monitor.warn(msg, arg0, arg1);
- } else if (debugEnabled) {
- System.err.println(":WARN: " + format(msg, arg0, arg1));
- }
- }
-
- public void warn(String msg, Throwable th) {
- if (monitor != null) {
- monitor.warn(msg, th);
- } else if (debugEnabled) {
- System.err.println(":WARN: " + msg);
- th.printStackTrace();
- }
- }
-
- public Logger getLogger(String name) {
- return this;
- }
-
- private String format(String msg, Object arg0, Object arg1) {
- int i0 = msg.indexOf("{}");
- int i1 = i0 < 0 ? -1 : msg.indexOf("{}", i0 + 2);
- if (arg1 != null && i1 >= 0) {
- msg = msg.substring(0, i1) + arg1 + msg.substring(i1 + 2);
- }
- if (arg0 != null && i0 >= 0) {
- msg = msg.substring(0, i0) + arg0 + msg.substring(i0 + 2);
- }
- return msg;
- }
-}
diff --git a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyService.java b/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyService.java
deleted file mode 100644
index 6fd68813df..0000000000
--- a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyService.java
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-package org.apache.tuscany.service.jetty;
-
-import org.apache.tuscany.spi.host.ServletHost;
-
-import org.mortbay.jetty.Server;
-
-/**
- * Implementations provide a Jetty transport service to the runtime
- *
- * @version $$Rev$$ $$Date$$
- */
-public interface JettyService extends ServletHost {
-
- /**
- * Returns the active Jetty server
- */
- Server getServer();
-
-
-}
diff --git a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyServiceImpl.java b/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyServiceImpl.java
deleted file mode 100644
index 01ad06fbe9..0000000000
--- a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/JettyServiceImpl.java
+++ /dev/null
@@ -1,314 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-package org.apache.tuscany.service.jetty;
-
-import java.io.File;
-import java.io.IOException;
-import javax.resource.spi.work.Work;
-import javax.servlet.Servlet;
-
-import org.osoa.sca.annotations.Destroy;
-import org.osoa.sca.annotations.Init;
-import org.osoa.sca.annotations.Property;
-import org.osoa.sca.annotations.Scope;
-import org.osoa.sca.annotations.Service;
-
-import org.apache.tuscany.spi.annotation.Autowire;
-import org.apache.tuscany.api.annotation.Monitor;
-import org.apache.tuscany.spi.host.ServletHost;
-import org.apache.tuscany.spi.services.work.WorkScheduler;
-
-import org.mortbay.jetty.Connector;
-import org.mortbay.jetty.Server;
-import org.mortbay.jetty.handler.ContextHandler;
-import org.mortbay.jetty.nio.SelectChannelConnector;
-import org.mortbay.jetty.security.SslSocketConnector;
-import org.mortbay.jetty.servlet.ServletHandler;
-import org.mortbay.jetty.servlet.ServletHolder;
-import org.mortbay.jetty.servlet.ServletMapping;
-import org.mortbay.log.Log;
-import org.mortbay.log.Logger;
-import org.mortbay.thread.BoundedThreadPool;
-import org.mortbay.thread.ThreadPool;
-
-/**
- * Implements an HTTP transport service using Jetty.
- *
- * @version $$Rev$$ $$Date$$
- */
-@Scope("MODULE")
-@Service(ServletHost.class)
-public class JettyServiceImpl implements JettyService {
-
- private static final String ROOT = "/";
- private static final int ERROR = 0;
- private static final int UNINITIALIZED = 0;
- private static final int STARTING = 1;
- private static final int STARTED = 2;
- private static final int STOPPING = 3;
- private static final int STOPPED = 4;
-
- private final Object joinLock = new Object();
- private int state = UNINITIALIZED;
- private int httpPort = 8080;
- private int httpsPort = 8484;
- private String keystore;
- private String certPassword;
- private String keyPassword;
- private boolean sendServerVersion;
- private boolean https;
- private TransportMonitor monitor;
- private WorkScheduler scheduler;
- private boolean debug;
- private Server server;
- private Connector connector;
- private ServletHandler servletHandler;
-
- static {
- // hack to replace the static Jetty logger
- System.setProperty("org.mortbay.log.class", JettyLogger.class.getName());
- }
-
- public JettyServiceImpl(@Monitor TransportMonitor monitor,
- @Autowire WorkScheduler scheduler) {
- this.monitor = monitor;
- this.scheduler = scheduler;
- // Jetty uses a static logger, so jam in the monitor into a static reference
- Logger logger = Log.getLogger(null);
- if (logger instanceof JettyLogger) {
- JettyLogger jettyLogger = (JettyLogger) logger;
- jettyLogger.setMonitor(monitor);
- if (debug) {
- jettyLogger.setDebugEnabled(true);
- }
- }
- }
-
- public JettyServiceImpl(TransportMonitor monitor) {
- this.monitor = monitor;
- }
-
- public JettyServiceImpl(TransportMonitor monitor,
- WorkScheduler scheduler,
- Connector connector) {
- this(monitor, scheduler);
- this.connector = connector;
- }
-
- @Property
- public void setHttpPort(int httpPort) {
- this.httpPort = httpPort;
- }
-
- @Property
- public void setHttpsPort(int httpsPort) {
- this.httpsPort = httpsPort;
- }
-
- @Property
- public void setSendServerVersion(boolean sendServerVersion) {
- this.sendServerVersion = sendServerVersion;
- }
-
- @Property
- public void setHttps(boolean https) {
- this.https = https;
- }
-
- @Property
- public void setKeystore(String keystore) {
- this.keystore = keystore;
- }
-
- @Property
- public void setCertPassword(String certPassword) {
- this.certPassword = certPassword;
- }
-
- @Property
- public void setKeyPassword(String keyPassword) {
- this.keyPassword = keyPassword;
- }
-
- @Property
- public void setDebug(boolean val) {
- debug = val;
- }
-
- @Init
- public void init() throws Exception {
- try {
- state = STARTING;
- server = new Server();
- if (scheduler == null) {
- BoundedThreadPool threadPool = new BoundedThreadPool();
- threadPool.setMaxThreads(100);
- server.setThreadPool(threadPool);
- } else {
- server.setThreadPool(new TuscanyThreadPool());
- }
- if (connector == null) {
- if (https) {
- Connector httpConnector = new SelectChannelConnector();
- httpConnector.setPort(httpPort);
- SslSocketConnector sslConnector = new SslSocketConnector();
- sslConnector.setPort(httpsPort);
- sslConnector.setKeystore(keystore);
- sslConnector.setPassword(certPassword);
- sslConnector.setKeyPassword(keyPassword);
- server.setConnectors(new Connector[]{httpConnector, sslConnector});
- } else {
- SelectChannelConnector selectConnector = new SelectChannelConnector();
- selectConnector.setPort(httpPort);
- server.setConnectors(new Connector[]{selectConnector});
- }
- } else {
- connector.setPort(httpPort);
- server.setConnectors(new Connector[]{connector});
- }
- ContextHandler contextHandler = new ContextHandler();
- contextHandler.setContextPath(ROOT);
- server.setHandler(contextHandler);
- servletHandler = new ServletHandler();
- contextHandler.setHandler(servletHandler);
- server.setStopAtShutdown(true);
- server.setSendServerVersion(sendServerVersion);
- monitor.started();
- server.start();
- state = STARTED;
- } catch (Exception e) {
- state = ERROR;
- throw e;
- }
- }
-
- @Destroy
- public void destroy() throws Exception {
- state = STOPPING;
- synchronized (joinLock) {
- joinLock.notifyAll();
- }
- server.stop();
- state = STOPPED;
- monitor.shutdown();
- }
-
- public void registerMapping(String path, Servlet servlet) {
- ServletHolder holder = new ServletHolder(servlet);
- servletHandler.addServlet(holder);
- ServletMapping mapping = new ServletMapping();
- mapping.setServletName(holder.getClassName());
- mapping.setPathSpec(path);
- servletHandler.addServletMapping(mapping);
- }
-
- public void unregisterMapping(String string) {
- throw new UnsupportedOperationException();
- }
-
- public void registerComposite(File compositeLocation) throws IOException {
- throw new UnsupportedOperationException();
- }
-
- public Server getServer() {
- return server;
- }
-
- public int getHttpPort() {
- return httpPort;
- }
-
- /**
- * An integration wrapper to enable use of a {@link WorkScheduler} with Jetty
- */
- private class TuscanyThreadPool implements ThreadPool {
-
- public boolean dispatch(Runnable job) {
- scheduler.scheduleWork(new TuscanyWork(job));
- return true;
- }
-
- public void join() throws InterruptedException {
- synchronized (joinLock) {
- joinLock.wait();
- }
- }
-
- public int getThreads() {
- throw new UnsupportedOperationException();
- }
-
- public int getIdleThreads() {
- throw new UnsupportedOperationException();
- }
-
- public boolean isLowOnThreads() {
- // TODO FIXME
- return false;
- }
-
- public void start() throws Exception {
-
- }
-
- public void stop() throws Exception {
-
- }
-
- public boolean isRunning() {
- return state == STARTING || state == STARTED;
- }
-
- public boolean isStarted() {
- return state == STARTED;
- }
-
- public boolean isStarting() {
- return state == STARTING;
- }
-
- public boolean isStopping() {
- return state == STOPPING;
- }
-
- public boolean isFailed() {
- return state == ERROR;
- }
- }
-
- /**
- * A unit of work dispatched to the runtime work scheduler
- */
- private class TuscanyWork implements Work {
-
- Runnable job;
-
- public TuscanyWork(Runnable job) {
- this.job = job;
- }
-
- public void release() {
- }
-
- public void run() {
- job.run();
- }
- }
-
-}
diff --git a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/TransportMonitor.java b/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/TransportMonitor.java
deleted file mode 100644
index c68eacd21c..0000000000
--- a/branches/sca-java-M2/sca/services/transports/http.jetty/src/main/java/org/apache/tuscany/service/jetty/TransportMonitor.java
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-package org.apache.tuscany.service.jetty;
-
-/**
- * The monitoring interfaces used by the Jetty system service
- *
- * @version $$Rev$$ $$Date$$
- */
-public interface TransportMonitor {
-
- /**
- * Called after the service is initialized
- */
- void started();
-
- /**
- * Called after the service is stopped
- */
- void shutdown();
-
- void warn(String msg, Object...args);
-
- void debug(String msg, Object...args);
-
-}
diff --git a/branches/sca-java-M2/sca/services/transports/http.jetty/src/test/java/org/apache/tuscany/service/jetty/JettyServiceImplTestCase.java b/branches/sca-java-M2/sca/services/transports/http.jetty/src/test/java/org/apache/tuscany/service/jetty/JettyServiceImplTestCase.java
deleted file mode 100644
index 987d7d9a16..0000000000
--- a/branches/sca-java-M2/sca/services/transports/http.jetty/src/test/java/org/apache/tuscany/service/jetty/JettyServiceImplTestCase.java
+++ /dev/null
@@ -1,173 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-package org.apache.tuscany.service.jetty;
-
-import java.io.BufferedReader;
-import java.io.IOException;
-import java.io.InputStreamReader;
-import java.io.OutputStream;
-import java.net.Socket;
-import java.util.concurrent.ExecutorService;
-import java.util.concurrent.Executors;
-import javax.servlet.ServletException;
-import javax.servlet.http.HttpServlet;
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-
-import org.apache.tuscany.spi.services.work.WorkScheduler;
-
-import junit.framework.TestCase;
-import static org.easymock.EasyMock.createMock;
-import static org.easymock.EasyMock.expectLastCall;
-import static org.easymock.EasyMock.getCurrentArguments;
-import static org.easymock.EasyMock.isA;
-import static org.easymock.EasyMock.replay;
-import org.easymock.IAnswer;
-
-/**
- * @version $Rev$ $Date$
- */
-public class JettyServiceImplTestCase extends TestCase {
-
- private static final String REQUEST1_HEADER =
- "GET / HTTP/1.0\n"
- + "Host: localhost\n"
- + "Content-Type: text/xml\n"
- + "Connection: close\n"
- + "Content-Length: ";
- private static final String REQUEST1_CONTENT =
- "";
- private static final String REQUEST1 =
- REQUEST1_HEADER + REQUEST1_CONTENT.getBytes().length + "\n\n" + REQUEST1_CONTENT;
-
- private static final int HTTP_PORT = 8585;
-
- private TransportMonitor monitor;
- private WorkScheduler scheduler;
- private ExecutorService executor = Executors.newCachedThreadPool();
-
- /**
- * Verifies requests are properly routed according to the servlet mapping
- */
- public void testRegisterServletMapping() throws Exception {
- JettyServiceImpl service = new JettyServiceImpl(monitor);
- service.setHttpPort(HTTP_PORT);
- service.init();
- TestServlet servlet = new TestServlet();
- service.registerMapping("/", servlet);
- Socket client = new Socket("127.0.0.1", HTTP_PORT);
- OutputStream os = client.getOutputStream();
- os.write(REQUEST1.getBytes());
- os.flush();
- read(client);
- service.destroy();
- assertTrue(servlet.invoked);
- }
-
- public void testUseWorkScheduler() throws Exception {
- JettyServiceImpl service = new JettyServiceImpl(monitor, scheduler);
- service.setDebug(true);
- service.setHttpPort(HTTP_PORT);
- service.init();
- TestServlet servlet = new TestServlet();
- service.registerMapping("/", servlet);
- Socket client = new Socket("127.0.0.1", HTTP_PORT);
- OutputStream os = client.getOutputStream();
- os.write(REQUEST1.getBytes());
- os.flush();
- read(client);
- service.destroy();
- assertTrue(servlet.invoked);
- }
-
- public void testRestart() throws Exception {
- JettyServiceImpl service = new JettyServiceImpl(monitor);
- service.setHttpPort(HTTP_PORT);
- service.init();
- service.destroy();
- service.init();
- service.destroy();
- }
-
- public void testNoMappings() throws Exception {
- JettyServiceImpl service = new JettyServiceImpl(monitor);
- service.setHttpPort(HTTP_PORT);
- service.init();
- Socket client = new Socket("127.0.0.1", HTTP_PORT);
- OutputStream os = client.getOutputStream();
- os.write(REQUEST1.getBytes());
- os.flush();
- read(client);
- service.destroy();
- }
-
- protected void tearDown() throws Exception {
- super.tearDown();
- //executor.submit();
- }
-
- protected void setUp() throws Exception {
- super.setUp();
- monitor = createMock(TransportMonitor.class);
- scheduler = createMock(WorkScheduler.class);
- scheduler.scheduleWork(isA(Runnable.class));
-
- expectLastCall().andStubAnswer(new IAnswer() {
- public Object answer() throws Throwable {
- Runnable runnable = (Runnable) getCurrentArguments()[0];
- executor.execute(runnable);
- return null;
- }
- });
- replay(scheduler);
- }
-
- private static String read(Socket socket) throws IOException {
- BufferedReader reader = null;
- try {
- reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
- StringBuffer sb = new StringBuffer();
- String str;
- while ((str = reader.readLine()) != null) {
- sb.append(str);
- }
- return sb.toString();
- } finally {
- if (reader != null) {
- reader.close();
- }
- }
- }
-
- private class TestServlet extends HttpServlet {
- boolean invoked;
-
- protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
- invoked = true;
- OutputStream writer = resp.getOutputStream();
- try {
- writer.write("result".getBytes());
- } finally {
- writer.close();
- }
- }
-
-
- }
-}