test/failure_handler/src/share/classes/jdk/test/failurehandler/jtreg/GatherDiagnosticInfoObserver.java
author iignatyev
Mon, 10 Jun 2019 17:11:04 -0700
changeset 55320 670b4794f51e
parent 51280 a306c84e40fa
permissions -rw-r--r--
8209917: fix TODO in GatherDiagnosticInfoObserver Reviewed-by: jjg, dholmes
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     1
/*
55320
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
     2
 * Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved.
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     4
 *
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     7
 * published by the Free Software Foundation.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     8
 *
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    13
 * accompanied this code).
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    14
 *
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    18
 *
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    21
 * questions.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    22
 */
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    23
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    24
package jdk.test.failurehandler.jtreg;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    25
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    26
import com.sun.javatest.Harness;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    27
import com.sun.javatest.Parameters;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    28
import com.sun.javatest.TestResult;
55320
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
    29
import com.sun.javatest.regtest.config.RegressionParameters;
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    30
import jdk.test.failurehandler.*;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    31
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    32
import java.io.File;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    33
import java.io.FileWriter;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    34
import java.io.IOException;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    35
import java.io.PrintWriter;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    36
import java.nio.file.Path;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    37
import java.nio.file.Paths;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    38
import java.util.HashMap;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    39
import java.util.Map;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    40
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    41
/**
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    42
 * The jtreg test execution observer, which gathers info about
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    43
 * system and dumps it to a file.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    44
 */
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    45
public class GatherDiagnosticInfoObserver implements Harness.Observer {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    46
    public static final String LOG_FILENAME = "environment.log";
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    47
    public static final String ENVIRONMENT_OUTPUT = "environment.html";
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    48
55320
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
    49
    private Path compileJdk;
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
    50
    private Path testJdk;
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    51
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    52
    /*
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    53
     * The harness calls this method after each test.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    54
     */
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    55
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    56
    public void finishedTest(TestResult tr) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    57
        if (!tr.getStatus().isError() && !tr.getStatus().isFailed()) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    58
            return;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    59
        }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    60
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    61
        String jtrFile = tr.getFile().toString();
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    62
        final Path workDir = Paths.get(
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    63
                jtrFile.substring(0, jtrFile.lastIndexOf('.')));
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    64
        workDir.toFile().mkdir();
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    65
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    66
        String name = getClass().getName();
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    67
        PrintWriter log;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    68
        boolean needClose = false;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    69
        try {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    70
            log = new PrintWriter(new FileWriter(
42008
c3a16be259dc 8168412: Reduce buffering in jtreg timeouthandler
sla
parents: 41038
diff changeset
    71
                    workDir.resolve(LOG_FILENAME).toFile(), true), true);
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    72
            needClose = true;
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    73
        } catch (IOException e) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    74
            log = new PrintWriter(System.out);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    75
            log.printf("ERROR: %s cannot open log file %s", name,
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    76
                    LOG_FILENAME);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    77
            e.printStackTrace(log);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    78
        }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    79
        try {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    80
            log.printf("%s ---%n", name);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    81
            GathererFactory gathererFactory = new GathererFactory(
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    82
                    OS.current().family, workDir, log,
55320
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
    83
                    testJdk, compileJdk);
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    84
            gatherEnvInfo(workDir, name, log,
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    85
                    gathererFactory.getEnvironmentInfoGatherer());
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    86
        } catch (Throwable e) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    87
            log.printf("ERROR: exception in observer %s:", name);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    88
            e.printStackTrace(log);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    89
        } finally {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    90
            log.printf("--- %s%n", name);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    91
            if (needClose) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    92
                log.close();
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    93
            } else {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    94
                log.flush();
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    95
            }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    96
        }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    97
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    98
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
    99
    private void gatherEnvInfo(Path workDir, String name, PrintWriter log,
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   100
                               EnvironmentInfoGatherer gatherer) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   101
        File output = workDir.resolve(ENVIRONMENT_OUTPUT).toFile();
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   102
        try (HtmlPage html = new HtmlPage(new PrintWriter(
42008
c3a16be259dc 8168412: Reduce buffering in jtreg timeouthandler
sla
parents: 41038
diff changeset
   103
                new FileWriter(output, true), true))) {
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   104
            try (ElapsedTimePrinter timePrinter
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   105
                         = new ElapsedTimePrinter(new Stopwatch(), name, log)) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   106
                gatherer.gatherEnvironmentInfo(html.getRootSection());
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   107
            }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   108
        } catch (Throwable e) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   109
            log.printf("ERROR: exception in observer on getting environment "
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   110
                    + "information %s:", name);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   111
            e.printStackTrace(log);
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   112
        }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   113
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   114
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   115
    /*
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   116
     * The harness calls this method one time per run, not per test.
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   117
     */
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   118
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   119
    public void startingTestRun(Parameters params) {
55320
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
   120
        RegressionParameters rp = (RegressionParameters) params;
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
   121
        compileJdk = rp.getCompileJDK().getAbsoluteFile().toPath();
670b4794f51e 8209917: fix TODO in GatherDiagnosticInfoObserver
iignatyev
parents: 51280
diff changeset
   122
        testJdk = rp.getTestJDK().getAbsoluteFile().toPath();
35016
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   123
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   124
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   125
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   126
    public void startingTest(TestResult tr) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   127
        // no-op
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   128
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   129
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   130
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   131
    public void stoppingTestRun() {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   132
        // no-op
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   133
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   134
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   135
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   136
    public void finishedTesting() {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   137
        // no-op
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   138
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   139
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   140
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   141
    public void finishedTestRun(boolean allOK) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   142
        // no-op
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   143
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   144
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   145
    @Override
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   146
    public void error(String msg) {
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   147
        // no-op
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   148
    }
b509dfa96469 8132961: JEP 279: Improve Test-Failure Troubleshooting
iignatyev
parents:
diff changeset
   149
}