rt/launcher/src/main/java/org/apidesign/bck2brwsr/launcher/Launcher.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Thu, 28 Feb 2013 21:00:39 +0100
changeset 794 b4284da2fb3b
parent 772 d382dacfd73f
child 844 023cda5b8b0b
child 858 afba662cf624
permissions -rw-r--r--
Few tweaks to launcher's Javadoc
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@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@622
    73
    /** Creates launcher that is using external browser.
jaroslav@622
    74
     * 
jaroslav@622
    75
     * @param cmd <code>null</code> to use <code>java.awt.Desktop</code> to show the launcher
jaroslav@622
    76
     *    or a string to execute in an external process (with a parameter to the URL)
jaroslav@622
    77
     * @return launcher executing in external browser.
jaroslav@622
    78
     */
jaroslav@382
    79
    public static Launcher createBrowser(String cmd) {
jaroslav@382
    80
        final Bck2BrwsrLauncher l = new Bck2BrwsrLauncher(cmd);
jaroslav@382
    81
        l.addClassLoader(Bck2Brwsr.class.getClassLoader());
jaroslav@382
    82
        l.setTimeout(180000);
jaroslav@382
    83
        return l;
jaroslav@382
    84
    }
jaroslav@622
    85
    
jaroslav@622
    86
    /** Starts an HTTP server which provides access to classes and resources
jaroslav@622
    87
     * available in the <code>classes</code> URL and shows a start page
jaroslav@622
    88
     * available as {@link ClassLoader#getResource(java.lang.String)} from the
jaroslav@622
    89
     * provide classloader. Opens a browser with URL showing the start page.
jaroslav@622
    90
     * 
jaroslav@622
    91
     * @param classes classloader offering access to classes and resources
jaroslav@622
    92
     * @param startpage page to show in the browser
jaroslav@622
    93
     * @return interface that allows one to stop the server
jaroslav@622
    94
     * @throws IOException if something goes wrong
jaroslav@622
    95
     */
jaroslav@382
    96
    public static Closeable showURL(URLClassLoader classes, String startpage) throws IOException {
jaroslav@382
    97
        Bck2BrwsrLauncher l = new Bck2BrwsrLauncher(null);
jaroslav@382
    98
        l.addClassLoader(classes);
jaroslav@382
    99
        l.showURL(startpage);
jaroslav@382
   100
        return l;
jaroslav@382
   101
    }
jaroslav@622
   102
    /** Starts an HTTP server which provides access to certain directory.
jaroslav@622
   103
     * The <code>startpage</code> should be relative location inside the root 
jaroslav@794
   104
     * directory. Opens a browser with URL showing the start page.
jaroslav@622
   105
     * 
jaroslav@622
   106
     * @param directory the root directory on disk
jaroslav@794
   107
     * @param startpage relative path from the root to the page
jaroslav@622
   108
     * @exception IOException if something goes wrong.
jaroslav@622
   109
     */
jaroslav@613
   110
    public static Closeable showDir(File directory, String startpage) throws IOException {
jaroslav@613
   111
        Bck2BrwsrLauncher l = new Bck2BrwsrLauncher(null);
jaroslav@613
   112
        l.showDirectory(directory, startpage);
jaroslav@613
   113
        return l;
jaroslav@613
   114
    }
jaroslav@613
   115
jaroslav@622
   116
    abstract InvocationContext runMethod(InvocationContext c) throws IOException; 
jaroslav@382
   117
}