test/langtools/tools/javac/launcher/SourceLauncherTest.java
author jjg
Thu, 07 Jun 2018 16:06:49 -0700
changeset 50453 f91927a2c8d3
child 50497 ee8524126794
permissions -rw-r--r--
8201274: Launch Single-File Source-Code Programs Reviewed-by: mcimadamore, jlahoda, ksrini, mchung, ihse, alanb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50453
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     1
/*
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     2
 * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     4
 *
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     7
 * published by the Free Software Foundation.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     8
 *
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    13
 * accompanied this code).
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    14
 *
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    18
 *
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    21
 * questions.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    22
 */
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    23
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    24
/*
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    25
 * @test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    26
 * @bug 8192920
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    27
 * @summary Test source launcher
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    28
 * @library /tools/lib
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    29
 * @modules jdk.compiler/com.sun.tools.javac.api
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    30
 *          jdk.compiler/com.sun.tools.javac.launcher
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    31
 *          jdk.compiler/com.sun.tools.javac.main
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    32
 * @build toolbox.JavaTask toolbox.JavacTask toolbox.TestRunner toolbox.ToolBox
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    33
 * @run main SourceLauncherTest
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    34
 */
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    35
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    36
import java.io.ByteArrayOutputStream;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    37
import java.io.IOException;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    38
import java.io.PrintStream;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    39
import java.io.PrintWriter;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    40
import java.io.StringWriter;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    41
import java.lang.reflect.InvocationTargetException;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    42
import java.nio.file.Files;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    43
import java.nio.file.Path;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    44
import java.nio.file.Paths;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    45
import java.util.ArrayList;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    46
import java.util.Collections;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    47
import java.util.List;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    48
import java.util.Properties;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    49
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    50
import com.sun.tools.javac.launcher.Main;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    51
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    52
import toolbox.JavaTask;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    53
import toolbox.JavacTask;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    54
import toolbox.Task;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    55
import toolbox.TestRunner;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    56
import toolbox.TestRunner;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    57
import toolbox.ToolBox;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    58
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    59
public class SourceLauncherTest extends TestRunner {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    60
    public static void main(String... args) throws Exception {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    61
        SourceLauncherTest t = new SourceLauncherTest();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    62
        t.runTests(m -> new Object[] { Paths.get(m.getName()) });
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    63
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    64
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    65
    SourceLauncherTest() {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    66
        super(System.err);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    67
        tb = new ToolBox();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    68
        System.err.println("version: " + thisVersion);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    69
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    70
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    71
    private final ToolBox tb;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    72
    private static final String thisVersion = System.getProperty("java.specification.version");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    73
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    74
    /*
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    75
     * Positive tests.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    76
     */
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    77
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    78
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    79
    public void testHelloWorld(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    80
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    81
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    82
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    83
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    84
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    85
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    86
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    87
        testSuccess(base.resolve("HelloWorld.java"), "Hello World! [1, 2, 3]\n");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    88
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    89
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    90
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    91
    public void testHelloWorldInPackage(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    92
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    93
            "package hello;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    94
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    95
            "class World {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    96
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    97
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    98
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
    99
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   100
        testSuccess(base.resolve("hello").resolve("World.java"), "Hello World! [1, 2, 3]\n");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   101
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   102
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   103
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   104
    public void testHelloWorldWithAux(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   105
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   106
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   107
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   108
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   109
            "        Aux.write(args);\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   110
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   111
            "}\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   112
            "class Aux {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   113
            "    static void write(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   114
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   115
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   116
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   117
        testSuccess(base.resolve("HelloWorld.java"), "Hello World! [1, 2, 3]\n");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   118
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   119
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   120
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   121
    public void testHelloWorldWithShebang(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   122
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   123
            "#!/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   124
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   125
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   126
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   127
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   128
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   129
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   130
        Files.copy(base.resolve("HelloWorld.java"), base.resolve("HelloWorld"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   131
        testSuccess(base.resolve("HelloWorld"), "Hello World! [1, 2, 3]\n");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   132
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   133
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   134
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   135
    public void testNoAnnoProcessing(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   136
        Path annoSrc = base.resolve("annoSrc");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   137
        tb.writeJavaFiles(annoSrc,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   138
            "import java.util.*;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   139
            "import javax.annotation.processing.*;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   140
            "import javax.lang.model.element.*;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   141
            "@SupportedAnnotationTypes(\"*\")\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   142
            "public class AnnoProc extends AbstractProcessor {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   143
            "    public boolean process(Set<? extends TypeElement> annos, RoundEnvironment rEnv) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   144
            "        throw new Error(\"Annotation processor should not be invoked\");\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   145
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   146
            "}\n");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   147
        Path annoClasses = Files.createDirectories(base.resolve("classes"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   148
        new JavacTask(tb)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   149
                .outdir(annoClasses)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   150
                .files(annoSrc.resolve("AnnoProc.java").toString())
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   151
                .run();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   152
        Path serviceFile = annoClasses.resolve("META-INF").resolve("services")
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   153
                .resolve("javax.annotation.processing.Processor");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   154
        tb.writeFile(serviceFile, "AnnoProc");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   155
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   156
        Path mainSrc = base.resolve("mainSrc");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   157
        tb.writeJavaFiles(mainSrc,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   158
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   159
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   160
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   161
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   162
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   163
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   164
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   165
        List<String> javacArgs = List.of("-classpath", annoClasses.toString());
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   166
        List<String> classArgs = List.of("1", "2", "3");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   167
        String expect = "Hello World! [1, 2, 3]\n";
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   168
        Result r = run(mainSrc.resolve("HelloWorld.java"), javacArgs, classArgs);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   169
        checkEqual("stdout", r.stdOut, expect);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   170
        checkEmpty("stderr", r.stdErr);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   171
        checkNull("exception", r.exception);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   172
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   173
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   174
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   175
    public void testEnablePreview(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   176
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   177
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   178
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   179
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   180
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   181
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   182
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   183
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   184
        String log = new JavaTask(tb)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   185
                .vmOptions("--enable-preview", "--source", thisVersion)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   186
                .className(base.resolve("HelloWorld.java").toString())
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   187
                .classArgs("1", "2", "3")
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   188
                .run(Task.Expect.SUCCESS)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   189
                .getOutput(Task.OutputKind.STDOUT);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   190
        checkEqual("stdout", log.trim(), "Hello World! [1, 2, 3]");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   191
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   192
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   193
    void testSuccess(Path file, String expect) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   194
        Result r = run(file, Collections.emptyList(), List.of("1", "2", "3"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   195
        checkEqual("stdout", r.stdOut, expect);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   196
        checkEmpty("stderr", r.stdErr);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   197
        checkNull("exception", r.exception);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   198
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   199
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   200
    /*
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   201
     * Negative tests: such as cannot find or execute main method.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   202
     */
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   203
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   204
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   205
    public void testHelloWorldWithShebangJava(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   206
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   207
            "#!/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   208
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   209
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   210
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   211
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   212
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   213
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   214
        Path file = base.resolve("HelloWorld.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   215
        testError(file,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   216
            file + ":1: error: illegal character: '#'\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   217
            "#!/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   218
            "^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   219
            file + ":1: error: class, interface, or enum expected\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   220
            "#!/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   221
            "  ^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   222
            "2 errors\n",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   223
            "error: compilation failed");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   224
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   225
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   226
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   227
    public void testNoClass(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   228
        Files.createDirectories(base);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   229
        Path file = base.resolve("NoClass.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   230
        Files.write(file, List.of("package p;"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   231
        testError(file, "", "error: no class declared in file");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   232
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   233
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   234
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   235
    public void testWrongClass(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   236
        Path src = base.resolve("src");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   237
        Path file = src.resolve("WrongClass.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   238
        tb.writeJavaFiles(src, "class WrongClass { }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   239
        Path classes = Files.createDirectories(base.resolve("classes"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   240
        new JavacTask(tb)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   241
                .outdir(classes)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   242
                .files(file)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   243
                .run();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   244
        String log = new JavaTask(tb)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   245
                .classpath(classes.toString())
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   246
                .className(file.toString())
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   247
                .run(Task.Expect.FAIL)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   248
                .getOutput(Task.OutputKind.STDERR);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   249
        checkEqual("stderr", log.trim(),
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   250
                "error: class found on application class path: WrongClass");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   251
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   252
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   253
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   254
    public void testSyntaxErr(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   255
        tb.writeJavaFiles(base, "class SyntaxErr {");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   256
        Path file = base.resolve("SyntaxErr.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   257
        testError(file,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   258
                file + ":1: error: reached end of file while parsing\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   259
                "class SyntaxErr {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   260
                "                 ^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   261
                "1 error\n",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   262
                "error: compilation failed");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   263
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   264
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   265
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   266
    public void testNoSourceOnClassPath(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   267
        Path auxSrc = base.resolve("auxSrc");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   268
        tb.writeJavaFiles(auxSrc,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   269
            "public class Aux {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   270
            "    static final String MESSAGE = \"Hello World\";\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   271
            "}\n");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   272
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   273
        Path mainSrc = base.resolve("mainSrc");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   274
        tb.writeJavaFiles(mainSrc,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   275
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   276
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   277
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   278
            "        System.out.println(Aux.MESSAGE + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   279
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   280
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   281
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   282
        List<String> javacArgs = List.of("-classpath", auxSrc.toString());
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   283
        List<String> classArgs = List.of("1", "2", "3");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   284
        String expectStdErr =
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   285
            "testNoSourceOnClassPath/mainSrc/HelloWorld.java:4: error: cannot find symbol\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   286
            "        System.out.println(Aux.MESSAGE + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   287
            "                           ^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   288
            "  symbol:   variable Aux\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   289
            "  location: class HelloWorld\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   290
            "1 error\n";
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   291
        Result r = run(mainSrc.resolve("HelloWorld.java"), javacArgs, classArgs);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   292
        checkEmpty("stdout", r.stdOut);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   293
        checkEqual("stderr", r.stdErr, expectStdErr);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   294
        checkFault("exception", r.exception, "error: compilation failed");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   295
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   296
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   297
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   298
    // For any source file that is invoked through the OS shebang mechanism, invalid shebang
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   299
    // lines will be caught and handled by the OS, before the launcher is even invoked.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   300
    // However, if such a file is passed directly to the launcher, perhaps using the --source
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   301
    // option, a well-formed shebang line will be removed but a badly-formed one will be not be
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   302
    // removed and will cause compilation errors.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   303
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   304
    public void testBadShebang(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   305
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   306
            "#/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   307
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   308
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   309
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   310
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   311
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   312
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   313
        Path file = base.resolve("HelloWorld.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   314
        testError(file,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   315
            file + ":1: error: illegal character: '#'\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   316
            "#/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   317
            "^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   318
            file + ":1: error: class, interface, or enum expected\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   319
            "#/usr/bin/java --source 11\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   320
            "  ^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   321
            "2 errors\n",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   322
            "error: compilation failed");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   323
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   324
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   325
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   326
    public void testBadSourceOpt(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   327
        Files.createDirectories(base);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   328
        Path file = base.resolve("DummyClass.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   329
        Files.write(file, List.of("class DummyClass { }"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   330
        Properties sysProps = System.getProperties();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   331
        Properties p = new Properties(sysProps);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   332
        p.setProperty("jdk.internal.javac.source", "<BAD>");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   333
        System.setProperties(p);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   334
        try {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   335
            testError(file, "", "error: invalid value for --source option: <BAD>");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   336
        } finally {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   337
            System.setProperties(sysProps);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   338
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   339
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   340
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   341
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   342
    public void testEnablePreviewNoSource(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   343
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   344
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   345
            "class HelloWorld {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   346
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   347
            "        System.out.println(\"Hello World! \" + Arrays.toString(args));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   348
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   349
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   350
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   351
        String log = new JavaTask(tb)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   352
                .vmOptions("--enable-preview")
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   353
                .className(base.resolve("HelloWorld.java").toString())
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   354
                .run(Task.Expect.FAIL)
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   355
                .getOutput(Task.OutputKind.STDERR);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   356
        checkEqual("stderr", log.trim(),
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   357
                "error: --enable-preview must be used with --source");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   358
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   359
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   360
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   361
    public void testNoMain(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   362
        tb.writeJavaFiles(base, "class NoMain { }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   363
        testError(base.resolve("NoMain.java"), "",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   364
                "error: can't find main(String[]) method in class: NoMain");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   365
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   366
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   367
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   368
    public void testMainBadParams(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   369
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   370
                "class BadParams { public static void main() { } }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   371
        testError(base.resolve("BadParams.java"), "",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   372
                "error: can't find main(String[]) method in class: BadParams");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   373
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   374
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   375
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   376
    public void testMainNotPublic(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   377
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   378
                "class NotPublic { static void main(String... args) { } }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   379
        testError(base.resolve("NotPublic.java"), "",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   380
                "error: 'main' method is not declared 'public static'");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   381
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   382
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   383
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   384
    public void testMainNotStatic(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   385
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   386
                "class NotStatic { public void main(String... args) { } }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   387
        testError(base.resolve("NotStatic.java"), "",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   388
                "error: 'main' method is not declared 'public static'");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   389
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   390
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   391
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   392
    public void testMainNotVoid(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   393
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   394
                "class NotVoid { public static int main(String... args) { return 0; } }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   395
        testError(base.resolve("NotVoid.java"), "",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   396
                "error: 'main' method is not declared with a return type of 'void'");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   397
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   398
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   399
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   400
    public void testClassInModule(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   401
        tb.writeJavaFiles(base, "package java.net; class InModule { }");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   402
        Path file = base.resolve("java").resolve("net").resolve("InModule.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   403
        testError(file,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   404
                file + ":1: error: package exists in another module: java.base\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   405
                "package java.net; class InModule { }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   406
                "^\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   407
                "1 error\n",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   408
                "error: compilation failed");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   409
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   410
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   411
    void testError(Path file, String expectStdErr, String expectFault) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   412
        Result r = run(file, Collections.emptyList(), List.of("1", "2", "3"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   413
        checkEmpty("stdout", r.stdOut);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   414
        checkEqual("stderr", r.stdErr, expectStdErr);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   415
        checkFault("exception", r.exception, expectFault);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   416
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   417
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   418
    /*
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   419
     * Tests in which main throws an exception.
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   420
     */
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   421
    @Test
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   422
    public void testTargetException1(Path base) throws IOException {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   423
        tb.writeJavaFiles(base,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   424
            "import java.util.Arrays;\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   425
            "class Thrower {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   426
            "    public static void main(String... args) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   427
            "        throwWhenZero(Integer.parseInt(args[0]));\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   428
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   429
            "    static void throwWhenZero(int arg) {\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   430
            "        if (arg == 0) throw new Error(\"zero!\");\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   431
            "        throwWhenZero(arg - 1);\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   432
            "    }\n" +
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   433
            "}");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   434
        Path file = base.resolve("Thrower.java");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   435
        Result r = run(file, Collections.emptyList(), List.of("3"));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   436
        checkEmpty("stdout", r.stdOut);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   437
        checkEmpty("stderr", r.stdErr);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   438
        checkTrace("exception", r.exception,
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   439
                "java.lang.Error: zero!",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   440
                "at Thrower.throwWhenZero(Thrower.java:7)",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   441
                "at Thrower.throwWhenZero(Thrower.java:8)",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   442
                "at Thrower.throwWhenZero(Thrower.java:8)",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   443
                "at Thrower.throwWhenZero(Thrower.java:8)",
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   444
                "at Thrower.main(Thrower.java:4)");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   445
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   446
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   447
    Result run(Path file, List<String> runtimeArgs, List<String> appArgs) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   448
        List<String> args = new ArrayList<>();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   449
        args.add(file.toString());
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   450
        args.addAll(appArgs);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   451
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   452
        PrintStream prev = System.out;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   453
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   454
        try (PrintStream out = new PrintStream(baos, true)) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   455
            System.setOut(out);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   456
            StringWriter sw = new StringWriter();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   457
            try (PrintWriter err = new PrintWriter(sw, true)) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   458
                Main m = new Main(err);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   459
                m.run(toArray(runtimeArgs), toArray(args));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   460
                return new Result(baos.toString(), sw.toString(), null);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   461
            } catch (Throwable t) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   462
                return new Result(baos.toString(), sw.toString(), t);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   463
            }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   464
        } finally {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   465
            System.setOut(prev);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   466
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   467
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   468
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   469
    void checkEqual(String name, String found, String expect) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   470
        expect = expect.replace("\n", tb.lineSeparator);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   471
        out.println(name + ": " + found);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   472
        out.println(name + ": " + found);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   473
        if (!expect.equals(found)) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   474
            error("Unexpected output; expected: " + expect);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   475
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   476
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   477
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   478
    void checkEmpty(String name, String found) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   479
        out.println(name + ": " + found);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   480
        if (!found.isEmpty()) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   481
            error("Unexpected output; expected empty string");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   482
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   483
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   484
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   485
    void checkNull(String name, Throwable found) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   486
        out.println(name + ": " + found);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   487
        if (found != null) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   488
            error("Unexpected exception; expected null");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   489
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   490
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   491
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   492
    void checkFault(String name, Throwable found, String expect) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   493
        expect = expect.replace("\n", tb.lineSeparator);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   494
        out.println(name + ": " + found);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   495
        if (found == null) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   496
            error("No exception thrown; expected Main.Fault");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   497
        } else {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   498
            if (!(found instanceof Main.Fault)) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   499
                error("Unexpected exception; expected Main.Fault");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   500
            }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   501
            if (!(found.getMessage().equals(expect))) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   502
                error("Unexpected detail message; expected: " + expect);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   503
            }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   504
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   505
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   506
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   507
    void checkTrace(String name, Throwable found, String... expect) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   508
        if (!(found instanceof InvocationTargetException)) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   509
            error("Unexpected exception; expected InvocationTargetException");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   510
            out.println("Found:");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   511
            found.printStackTrace(out);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   512
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   513
        StringWriter sw = new StringWriter();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   514
        try (PrintWriter pw = new PrintWriter(sw)) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   515
            ((InvocationTargetException) found).getTargetException().printStackTrace(pw);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   516
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   517
        String trace = sw.toString();
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   518
        out.println(name + ":\n" + trace);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   519
        String[] traceLines = trace.trim().split("[\r\n]+\\s+");
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   520
        try {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   521
            tb.checkEqual(List.of(traceLines), List.of(expect));
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   522
        } catch (Error e) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   523
            error(e.getMessage());
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   524
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   525
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   526
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   527
    String[] toArray(List<String> list) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   528
        return list.toArray(new String[list.size()]);
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   529
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   530
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   531
    class Result {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   532
        private final String stdOut;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   533
        private final String stdErr;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   534
        private final Throwable exception;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   535
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   536
        Result(String stdOut, String stdErr, Throwable exception) {
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   537
            this.stdOut = stdOut;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   538
            this.stdErr = stdErr;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   539
            this.exception = exception;
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   540
        }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   541
    }
f91927a2c8d3 8201274: Launch Single-File Source-Code Programs
jjg
parents:
diff changeset
   542
}