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