rt/launcher/src/main/java/org/apidesign/bck2brwsr/launcher/Launcher.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Tue, 26 Feb 2013 16:54:16 +0100
changeset 772 d382dacfd73f
parent 622 launcher/src/main/java/org/apidesign/bck2brwsr/launcher/Launcher.java@a07253cf2ca4
child 794 b4284da2fb3b
permissions -rw-r--r--
Moving modules around so the runtime is under one master pom and can be built without building other modules that are in the repository
jaroslav@382
     1
/**
jaroslav@382
     2
 * Back 2 Browser Bytecode Translator
jaroslav@382
     3
 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
jaroslav@382
     4
 *
jaroslav@382
     5
 * This program is free software: you can redistribute it and/or modify
jaroslav@382
     6
 * it under the terms of the GNU General Public License as published by
jaroslav@382
     7
 * the Free Software Foundation, version 2 of the License.
jaroslav@382
     8
 *
jaroslav@382
     9
 * This program is distributed in the hope that it will be useful,
jaroslav@382
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
jaroslav@382
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
jaroslav@382
    12
 * GNU General Public License for more details.
jaroslav@382
    13
 *
jaroslav@382
    14
 * You should have received a copy of the GNU General Public License
jaroslav@382
    15
 * along with this program. Look for COPYING file in the top folder.
jaroslav@382
    16
 * If not, see http://opensource.org/licenses/GPL-2.0.
jaroslav@382
    17
 */
jaroslav@382
    18
package org.apidesign.bck2brwsr.launcher;
jaroslav@382
    19
jaroslav@382
    20
import java.io.Closeable;
jaroslav@613
    21
import java.io.File;
jaroslav@382
    22
import java.io.IOException;
jaroslav@382
    23
import java.net.URLClassLoader;
jaroslav@382
    24
import org.apidesign.vm4brwsr.Bck2Brwsr;
jaroslav@382
    25
jaroslav@382
    26
/** An abstraction for executing tests in a Bck2Brwsr virtual machine.
jaroslav@622
    27
 * Either in {@linkm Launcher#createJavaScript JavaScript engine}, 
jaroslav@622
    28
 * or in {@linkm Launcher#createBrowser external browser}.
jaroslav@382
    29
 *
jaroslav@382
    30
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@382
    31
 */
jaroslav@382
    32
public abstract class Launcher {
jaroslav@382
    33
jaroslav@382
    34
    Launcher() {
jaroslav@382
    35
    }
jaroslav@622
    36
jaroslav@622
    37
    /** Initializes the launcher. This may mean starting a web browser or
jaroslav@622
    38
     * initializing execution engine.
jaroslav@622
    39
     * @throws IOException if something goes wrong
jaroslav@622
    40
     */
jaroslav@622
    41
    public abstract void initialize() throws IOException;
jaroslav@382
    42
    
jaroslav@622
    43
    /** Shuts down the launcher.
jaroslav@622
    44
     * @throws IOException if something goes wrong
jaroslav@622
    45
     */
jaroslav@382
    46
    public abstract void shutdown() throws IOException;
jaroslav@622
    47
    
jaroslav@622
    48
    
jaroslav@622
    49
    /** Builds an invocation context. The context can later be customized
jaroslav@622
    50
     * and {@link InvocationContext#invoke() invoked}.
jaroslav@622
    51
     * 
jaroslav@622
    52
     * @param clazz the class to execute method from
jaroslav@622
    53
     * @param method the method to execute
jaroslav@622
    54
     * @return the context pointing to the selected method
jaroslav@622
    55
     */
jaroslav@622
    56
    public InvocationContext createInvocation(Class<?> clazz, String method) {
jaroslav@622
    57
        return new InvocationContext(this, clazz, method);
jaroslav@382
    58
    }
jaroslav@382
    59
    
jaroslav@382
    60
jaroslav@622
    61
    /** Creates launcher that uses internal JavaScript engine (Rhino).
jaroslav@622
    62
     * @return the launcher
jaroslav@622
    63
     */
jaroslav@382
    64
    public static Launcher createJavaScript() {
jaroslav@382
    65
        final JSLauncher l = new JSLauncher();
jaroslav@382
    66
        l.addClassLoader(Bck2Brwsr.class.getClassLoader());
jaroslav@382
    67
        return l;
jaroslav@382
    68
    }
jaroslav@382
    69
    
jaroslav@622
    70
    /** Creates launcher that is using external browser.
jaroslav@622
    71
     * 
jaroslav@622
    72
     * @param cmd <code>null</code> to use <code>java.awt.Desktop</code> to show the launcher
jaroslav@622
    73
     *    or a string to execute in an external process (with a parameter to the URL)
jaroslav@622
    74
     * @return launcher executing in external browser.
jaroslav@622
    75
     */
jaroslav@382
    76
    public static Launcher createBrowser(String cmd) {
jaroslav@382
    77
        final Bck2BrwsrLauncher l = new Bck2BrwsrLauncher(cmd);
jaroslav@382
    78
        l.addClassLoader(Bck2Brwsr.class.getClassLoader());
jaroslav@382
    79
        l.setTimeout(180000);
jaroslav@382
    80
        return l;
jaroslav@382
    81
    }
jaroslav@622
    82
    
jaroslav@622
    83
    /** Starts an HTTP server which provides access to classes and resources
jaroslav@622
    84
     * available in the <code>classes</code> URL and shows a start page
jaroslav@622
    85
     * available as {@link ClassLoader#getResource(java.lang.String)} from the
jaroslav@622
    86
     * provide classloader. Opens a browser with URL showing the start page.
jaroslav@622
    87
     * 
jaroslav@622
    88
     * @param classes classloader offering access to classes and resources
jaroslav@622
    89
     * @param startpage page to show in the browser
jaroslav@622
    90
     * @return interface that allows one to stop the server
jaroslav@622
    91
     * @throws IOException if something goes wrong
jaroslav@622
    92
     */
jaroslav@382
    93
    public static Closeable showURL(URLClassLoader classes, String startpage) throws IOException {
jaroslav@382
    94
        Bck2BrwsrLauncher l = new Bck2BrwsrLauncher(null);
jaroslav@382
    95
        l.addClassLoader(classes);
jaroslav@382
    96
        l.showURL(startpage);
jaroslav@382
    97
        return l;
jaroslav@382
    98
    }
jaroslav@622
    99
    /** Starts an HTTP server which provides access to certain directory.
jaroslav@622
   100
     * The <code>startpage</code> should be relative location inside the root 
jaroslav@622
   101
     * driecotry
jaroslav@622
   102
     * Opens a browser with URL showing the start page.
jaroslav@622
   103
     * 
jaroslav@622
   104
     * @param directory the root directory on disk
jaroslav@622
   105
     * @praam startpage relative path from the root to the page
jaroslav@622
   106
     * @exception IOException if something goes wrong.
jaroslav@622
   107
     */
jaroslav@613
   108
    public static Closeable showDir(File directory, String startpage) throws IOException {
jaroslav@613
   109
        Bck2BrwsrLauncher l = new Bck2BrwsrLauncher(null);
jaroslav@613
   110
        l.showDirectory(directory, startpage);
jaroslav@613
   111
        return l;
jaroslav@613
   112
    }
jaroslav@613
   113
jaroslav@622
   114
    abstract InvocationContext runMethod(InvocationContext c) throws IOException; 
jaroslav@382
   115
}