test/hotspot/jtreg/gtest/GTestWrapper.java
author iignatyev
Wed, 12 Jun 2019 11:48:14 -0700
changeset 55349 139f21bad9fd
parent 53273 bbc79e0ec9ee
permissions -rw-r--r--
8158048: Fix failure message from jtreg gtest wrapper Reviewed-by: kvn, mseledtsov
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
38307
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     1
/*
53273
bbc79e0ec9ee 8216265: [testbug] Introduce Platform.sharedLibraryPathVariableName() and adapt all tests.
goetz
parents: 49963
diff changeset
     2
 * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
38307
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     4
 *
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     7
 * published by the Free Software Foundation.
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     8
 *
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    13
 * accompanied this code).
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    14
 *
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    18
 *
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    21
 * questions.
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    22
 */
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    23
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    24
/* @test
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    25
 * @summary a jtreg wrapper for gtest tests
40631
ed82623d7831 8157957: ClassNotFoundException: jdk.test.lib.JDKToolFinder
ctornqvi
parents: 38731
diff changeset
    26
 * @library /test/lib
38307
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    27
 * @modules java.base/jdk.internal.misc
55349
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    28
 *          java.xml
38307
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    29
 * @run main/native GTestWrapper
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    30
 */
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    31
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    32
import jdk.test.lib.Platform;
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    33
import jdk.test.lib.Utils;
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    34
import jdk.test.lib.process.ProcessTools;
55349
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    35
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    36
import java.io.File;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    37
import java.nio.file.Files;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    38
import java.nio.file.Path;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    39
import java.nio.file.Paths;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    40
import java.util.Collections;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    41
import java.util.List;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    42
import java.util.Map;
38307
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    43
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    44
public class GTestWrapper {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    45
    public static void main(String[] args) throws Throwable {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    46
        // gtestLauncher is located in <test_image>/hotspot/gtest/<vm_variant>/
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    47
        // nativePath points either to <test_image>/hotspot/jtreg/native or to <test_image>/hotspot/gtest
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    48
        Path nativePath = Paths.get(System.getProperty("test.nativepath"));
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    49
        String jvmVariantDir = getJVMVariantSubDir();
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    50
        // let's assume it's <test_image>/hotspot/gtest
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    51
        Path path = nativePath.resolve(jvmVariantDir);
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    52
        if (!path.toFile().exists()) {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    53
            // maybe it is <test_image>/hotspot/jtreg/native
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    54
            path = nativePath.getParent()
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    55
                             .getParent()
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    56
                             .resolve("gtest")
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    57
                             .resolve(jvmVariantDir);
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    58
        }
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    59
        if (!path.toFile().exists()) {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    60
            throw new Error("TESTBUG: the library has not been found in " + nativePath);
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
    61
        }
49963
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    62
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    63
        Path execPath = path.resolve("gtestLauncher" + (Platform.isWindows() ? ".exe" : ""));
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    64
        ProcessBuilder pb = new ProcessBuilder();
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    65
        Map<String, String> env = pb.environment();
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    66
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    67
        // The GTestWrapper was started using the normal java launcher, which
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    68
        // may have set LD_LIBRARY_PATH or LIBPATH to point to the jdk libjvm. In
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    69
        // that case, prepend the path with the location of the gtest library."
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    70
53273
bbc79e0ec9ee 8216265: [testbug] Introduce Platform.sharedLibraryPathVariableName() and adapt all tests.
goetz
parents: 49963
diff changeset
    71
        String pathVar = Platform.sharedLibraryPathVariableName();
bbc79e0ec9ee 8216265: [testbug] Introduce Platform.sharedLibraryPathVariableName() and adapt all tests.
goetz
parents: 49963
diff changeset
    72
        String ldLibraryPath = System.getenv(pathVar);
49963
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    73
        if (ldLibraryPath != null) {
53273
bbc79e0ec9ee 8216265: [testbug] Introduce Platform.sharedLibraryPathVariableName() and adapt all tests.
goetz
parents: 49963
diff changeset
    74
            env.put(pathVar, path + File.pathSeparator + ldLibraryPath);
49963
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    75
        }
93a7cbd3f838 8195002: Fix test/hotspot/jtreg/gtest/GTestWrapper.java on Alpine/Musl
asiebenborn
parents: 47216
diff changeset
    76
55349
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    77
        Path resultFile = Paths.get("test_result.xml");
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    78
        pb.command(execPath.toAbsolutePath().toString(),
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    79
                "-jdk", Utils.TEST_JDK,
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    80
                "--gtest_output=xml:" + resultFile);
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    81
        int exitCode = ProcessTools.executeCommand(pb).getExitValue();
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    82
        if (exitCode != 0) {
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    83
            List<String> failedTests = failedTests(resultFile);
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    84
            String message = "gtest execution failed; exit code = " + exitCode + ".";
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    85
            if (!failedTests.isEmpty()) {
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    86
                message += " the failed tests: " + failedTests;
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    87
            }
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    88
            throw new AssertionError(message);
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    89
        }
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    90
    }
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    91
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    92
    private static List<String> failedTests(Path xml) {
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    93
        if (!Files.exists(xml)) {
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    94
            System.err.println("WARNING: test result file (" + xml + ") hasn't been found");
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    95
        }
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    96
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    97
        try {
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    98
            return new GTestResultParser(xml).failedTests();
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
    99
        } catch (Throwable t) {
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
   100
            System.err.println("WARNING: failed to parse result file (" + xml + ") " + t);
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
   101
            t.printStackTrace();
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
   102
        }
139f21bad9fd 8158048: Fix failure message from jtreg gtest wrapper
iignatyev
parents: 53273
diff changeset
   103
        return Collections.emptyList();
38307
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   104
    }
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   105
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   106
    private static String getJVMVariantSubDir() {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   107
        if (Platform.isServer()) {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   108
            return "server";
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   109
        } else if (Platform.isClient()) {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   110
            return "client";
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   111
        } else if (Platform.isMinimal()) {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   112
            return "minimal";
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   113
        } else {
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   114
            throw new Error("TESTBUG: unsuppported vm variant");
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   115
        }
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   116
    }
c9555da2ae99 8156681: Add jtreg wrapper for hotspot gtest tests
iignatyev
parents:
diff changeset
   117
}