rt/launcher/src/main/java/org/apidesign/bck2brwsr/launcher/Launcher.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Thu, 18 Apr 2013 23:09:30 +0200
branchfx
changeset 1016 6dc2c6c752df
parent 1006 691c5cd3fb93
permissions -rw-r--r--
Can execute 'dual' tests: bck2brwsr can use regular launcher, javaquery.api can use FX Web View one
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 org.apidesign.vm4brwsr.Bck2Brwsr;
jaroslav@382
    24
jaroslav@382
    25
/** An abstraction for executing tests in a Bck2Brwsr virtual machine.
jaroslav@622
    26
 * Either in {@linkm Launcher#createJavaScript JavaScript engine}, 
jaroslav@622
    27
 * or in {@linkm Launcher#createBrowser external browser}.
jaroslav@794
    28
 * <p>
jaroslav@794
    29
 * There also are methods to {@link #showDir(java.io.File, java.lang.String) display pages} 
jaroslav@794
    30
 * in an external browser served by internal HTTP server.
jaroslav@382
    31
 *
jaroslav@382
    32
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@382
    33
 */
jaroslav@382
    34
public abstract class Launcher {
jaroslav@382
    35
jaroslav@382
    36
    Launcher() {
jaroslav@382
    37
    }
jaroslav@622
    38
jaroslav@622
    39
    /** Initializes the launcher. This may mean starting a web browser or
jaroslav@622
    40
     * initializing execution engine.
jaroslav@622
    41
     * @throws IOException if something goes wrong
jaroslav@622
    42
     */
jaroslav@622
    43
    public abstract void initialize() throws IOException;
jaroslav@382
    44
    
jaroslav@622
    45
    /** Shuts down the launcher.
jaroslav@622
    46
     * @throws IOException if something goes wrong
jaroslav@622
    47
     */
jaroslav@382
    48
    public abstract void shutdown() throws IOException;
jaroslav@622
    49
    
jaroslav@622
    50
    
jaroslav@622
    51
    /** Builds an invocation context. The context can later be customized
jaroslav@622
    52
     * and {@link InvocationContext#invoke() invoked}.
jaroslav@622
    53
     * 
jaroslav@622
    54
     * @param clazz the class to execute method from
jaroslav@622
    55
     * @param method the method to execute
jaroslav@622
    56
     * @return the context pointing to the selected method
jaroslav@622
    57
     */
jaroslav@622
    58
    public InvocationContext createInvocation(Class<?> clazz, String method) {
jaroslav@622
    59
        return new InvocationContext(this, clazz, method);
jaroslav@382
    60
    }
jaroslav@382
    61
    
jaroslav@382
    62
jaroslav@622
    63
    /** Creates launcher that uses internal JavaScript engine (Rhino).
jaroslav@622
    64
     * @return the launcher
jaroslav@622
    65
     */
jaroslav@382
    66
    public static Launcher createJavaScript() {
jaroslav@382
    67
        final JSLauncher l = new JSLauncher();
jaroslav@382
    68
        l.addClassLoader(Bck2Brwsr.class.getClassLoader());
jaroslav@382
    69
        return l;
jaroslav@382
    70
    }
jaroslav@382
    71
    
jaroslav@844
    72
    /** Creates launcher that is using external browser. Value of <code>cmd</code>
jaroslav@844
    73
     * may be <code>"fx"</code> to indicate one wants to use JavaFX's WebView
jaroslav@844
    74
     * instead of command line browser.
jaroslav@622
    75
     * 
jaroslav@622
    76
     * @param cmd <code>null</code> to use <code>java.awt.Desktop</code> to show the launcher
jaroslav@622
    77
     *    or a string to execute in an external process (with a parameter to the URL)
jaroslav@622
    78
     * @return launcher executing in external browser.
jaroslav@622
    79
     */
jaroslav@382
    80
    public static Launcher createBrowser(String cmd) {
jaroslav@844
    81
        final Bck2BrwsrLauncher l;
jaroslav@1016
    82
        if ("fx".equals(cmd)) {
jaroslav@844
    83
            l = new WebViewLauncher();
jaroslav@844
    84
        } else {
jaroslav@844
    85
            l = new Bck2BrwsrLauncher(cmd);
jaroslav@844
    86
        }
jaroslav@382
    87
        l.addClassLoader(Bck2Brwsr.class.getClassLoader());
jaroslav@382
    88
        l.setTimeout(180000);
jaroslav@382
    89
        return l;
jaroslav@382
    90
    }
jaroslav@622
    91
    
jaroslav@622
    92
    /** Starts an HTTP server which provides access to classes and resources
jaroslav@622
    93
     * available in the <code>classes</code> URL and shows a start page
jaroslav@622
    94
     * available as {@link ClassLoader#getResource(java.lang.String)} from the
jaroslav@622
    95
     * provide classloader. Opens a browser with URL showing the start page.
jaroslav@622
    96
     * 
jaroslav@622
    97
     * @param classes classloader offering access to classes and resources
jaroslav@622
    98
     * @param startpage page to show in the browser
jaroslav@622
    99
     * @return interface that allows one to stop the server
jaroslav@622
   100
     * @throws IOException if something goes wrong
jaroslav@622
   101
     */
jaroslav@858
   102
    public static Closeable showURL(ClassLoader classes, String startpage) throws IOException {
jaroslav@845
   103
        Bck2BrwsrLauncher l = new WebViewLauncher();
jaroslav@382
   104
        l.addClassLoader(classes);
jaroslav@382
   105
        l.showURL(startpage);
jaroslav@382
   106
        return l;
jaroslav@382
   107
    }
jaroslav@622
   108
    /** Starts an HTTP server which provides access to certain directory.
jaroslav@622
   109
     * The <code>startpage</code> should be relative location inside the root 
jaroslav@794
   110
     * directory. Opens a browser with URL showing the start page.
jaroslav@622
   111
     * 
jaroslav@622
   112
     * @param directory the root directory on disk
jaroslav@794
   113
     * @param startpage relative path from the root to the page
jaroslav@622
   114
     * @exception IOException if something goes wrong.
jaroslav@622
   115
     */
jaroslav@613
   116
    public static Closeable showDir(File directory, String startpage) throws IOException {
jaroslav@845
   117
        Bck2BrwsrLauncher l = new WebViewLauncher();
jaroslav@613
   118
        l.showDirectory(directory, startpage);
jaroslav@613
   119
        return l;
jaroslav@613
   120
    }
jaroslav@613
   121
jaroslav@622
   122
    abstract InvocationContext runMethod(InvocationContext c) throws IOException; 
jaroslav@382
   123
}