exportedexecutionserver.java.svn-base

来自「cqME :java framework for TCK test.」· SVN-BASE 代码 · 共 104 行

SVN-BASE
104
字号
/* * $Id$ * * Copyright 1996-2007 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 only, as published by the Free Software Foundation. * * This program 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 * General Public License version 2 for more details (a copy is * included at /legal/license.txt). * * You should have received a copy of the GNU General Public License * version 2 along with this work; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 or visit www.sun.com if you need additional * information or have any questions. * */package com.sun.tck.j2me.export.javatest;import com.sun.cldc.communication.midp.BaseHttpServer;import com.sun.cldc.communication.midp.MIDHttpExecutionServer;import com.sun.tck.cldc.javatest.util.UTFConverter;import java.io.DataInputStream;import java.io.IOException;import java.net.URL;/** * <code>ExportedExecutionServer</code> is aware only about  * &quot;sendTestResult&quot; command. It  * should be used for running previously exported distributed tests. */public class ExportedExecutionServer extends MIDHttpExecutionServer {        /**     * Creates a new instance of <code>ExportedExecutionServer</code> with one     * running <code>RequestHandler</code>.     */    public ExportedExecutionServer() {        super();        handlerCount = 1;    }        /**     * Returns new <code>ExportedExecutionServer.RequestHandler</code> instance.     *     * @return new <code>ExportedExecutionServer.RequestHandler</code> instance.     */    protected BaseHttpServer createRequestHandler() {        return new ExportedExecutionServer.RequestHandler();    }    /**     * Simple RequestHandler for running exported tests. It only accepts      * sendTestResult POSTs from device and rejects getNextApp and getNextTest     * GETs as this mechanism is not used by exported tests.     */    class RequestHandler extends MIDHttpExecutionServer.RequestHandler {                /**         * When running exported tests, only POST sendTestResult is allowed.         * Sends HTTP_BAD_METHOD.         */        protected void handleGet(URL request, DataInputStream in)                throws IOException {            sendDiagnostics(HTTP_BAD_METHOD);        }                /**         * When running exported tests, only POST sendTestResult is allowed.         * Invokes super implementation if sendTestResult is received,         * sends HTTP_BAD_REQUEST otherwise.         */        protected void handlePost(URL request, DataInputStream in)                throws IOException {            String path = request.getFile();                        if (path.startsWith(testRoot + "sendTestResult")) {                if (postsHandled++ == 0) {                     String app = getTestProvider().getNextApp();                    if (!app.equals("")) {                        getTestProvider().getNextTest();                    }                }                super.handlePost(request, in);                getTestProvider().getNextTest();            } else {                sendDiagnostics(HTTP_BAD_REQUEST);            }        }                private int postsHandled = 0;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?