jdk/test/tools/launcher/modules/basic/InitErrors.java
author alanb
Wed, 22 Mar 2017 16:26:27 +0000
changeset 44359 c6761862ca0b
permissions -rw-r--r--
8174823: Module system implementation refresh (3/2017) Reviewed-by: chegar, mchung, alanb Contributed-by: alan.bateman@oracle.com, mandy.chung@oracle.com, sundararajan.athijegannathan@oracle.com, peter.levart@gmail.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44359
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     1
/*
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     2
 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     4
 *
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     7
 * published by the Free Software Foundation.
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     8
 *
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    13
 * accompanied this code).
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    14
 *
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    18
 *
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    21
 * questions.
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    22
 */
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    23
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    24
/**
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    25
 * @test
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    26
 * @library /lib/testlibrary
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    27
 * @build InitErrors jdk.testlibrary.*
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    28
 * @run testng InitErrors
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    29
 * @summary Basic test to ensure that module system initialization errors
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    30
 *          go the right stream and with the right level of verbosity
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    31
 */
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    32
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    33
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    34
import java.util.Arrays;
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    35
import jdk.testlibrary.ProcessTools;
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    36
import jdk.testlibrary.OutputAnalyzer;
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    37
import org.testng.annotations.Test;
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    38
import static org.testng.Assert.*;
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    39
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    40
public class InitErrors {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    41
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    42
    // the option to cause module initialization to fail
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    43
    private static final String ADD_UNKNOWN_MODULE = "--add-modules=XXX";
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    44
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    45
    // the expected error message
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    46
    private static final String UNKNOWN_MODULE_NOT_FOUND= "Module XXX not found";
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    47
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    48
    // output expected in the stack trace when using -Xlog:init=debug
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    49
    private static final String STACK_FRAME = "java.base/java.lang.System.initPhase2";
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    50
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    51
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    52
    /**
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    53
     * Default behavior, send error message to stdout
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    54
     */
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    55
    @Test
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    56
    public void testDefaultOutput() throws Exception {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    57
        expectFail(showVersion(ADD_UNKNOWN_MODULE)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    58
                .stdoutShouldContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    59
                .stdoutShouldNotContain(STACK_FRAME)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    60
                .stderrShouldNotContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    61
                .stderrShouldNotContain(STACK_FRAME));
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    62
    }
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    63
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    64
    /**
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    65
     * -XX:+DisplayVMOutputToStderr should send error message to stderr
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    66
     */
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    67
    @Test
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    68
    public void testOutputToStderr() throws Exception {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    69
        expectFail(showVersion(ADD_UNKNOWN_MODULE, "-XX:+DisplayVMOutputToStderr")
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    70
                .stdoutShouldNotContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    71
                .stdoutShouldNotContain(STACK_FRAME)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    72
                .stderrShouldContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    73
                .stderrShouldNotContain(STACK_FRAME));
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    74
    }
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    75
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    76
    /**
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    77
     * -Xlog:init=debug should print stack trace to stdout
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    78
     */
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    79
    @Test
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    80
    public void testStackTrace() throws Exception {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    81
        expectFail(showVersion(ADD_UNKNOWN_MODULE, "-Xlog:init=debug")
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    82
                .stdoutShouldContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    83
                .stdoutShouldContain(STACK_FRAME)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    84
                .stderrShouldNotContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    85
                .stderrShouldNotContain(STACK_FRAME));
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    86
    }
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    87
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    88
    /**
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    89
     * -Xlog:init=debug -XX:+DisplayVMOutputToStderr should print stack trace
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    90
     * to stderr
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    91
     */
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    92
    @Test
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    93
    public void testStackTraceToStderr() throws Exception {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    94
        expectFail(showVersion(ADD_UNKNOWN_MODULE,
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    95
                               "-Xlog:init=debug",
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    96
                               "-XX:+DisplayVMOutputToStderr")
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    97
                .stdoutShouldNotContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    98
                .stdoutShouldNotContain(STACK_FRAME)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
    99
                .stderrShouldContain(UNKNOWN_MODULE_NOT_FOUND)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   100
                .stderrShouldContain(STACK_FRAME));
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   101
    }
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   102
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   103
    private OutputAnalyzer showVersion(String... args) throws Exception {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   104
        int len = args.length;
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   105
        args = Arrays.copyOf(args, len+1);
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   106
        args[len] = "-version";
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   107
        return ProcessTools.executeTestJava(args)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   108
                .outputTo(System.out)
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   109
                .errorTo(System.out);
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   110
    }
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   111
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   112
    private void expectFail(OutputAnalyzer output) {
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   113
        assertFalse(output.getExitValue() == 0);
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   114
    }
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   115
c6761862ca0b 8174823: Module system implementation refresh (3/2017)
alanb
parents:
diff changeset
   116
}