8132961: JEP 279: Improve Test-Failure Troubleshooting
Co-authored-by: Kirill Shirokov <kirill.shirokov@oracle.com> Co-authored-by: Dmitry Fazunenko <dmitry.fazunenko@oracle.com> Co-authored-by: Kirill Zhaldybin <kirill.zhaldybin@oracle.com> Reviewed-by: lmesnik, sla
This commit is contained in:
parent
72119404ca
commit
a59ce6689f
114
test/failure_handler/Makefile
Normal file
114
test/failure_handler/Makefile
Normal file
@ -0,0 +1,114 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# This is a temporary standalone makefile
|
||||||
|
#
|
||||||
|
|
||||||
|
BUILD_DIR := $(shell pwd)/build
|
||||||
|
CLASSES_DIR := ${BUILD_DIR}/classes
|
||||||
|
IMAGE_DIR := ${BUILD_DIR}/image
|
||||||
|
RUN_DIR := $(shell pwd)/run
|
||||||
|
|
||||||
|
SRC_DIR := src/share/classes/
|
||||||
|
SOURCES := ${SRC_DIR}/jdk/test/failurehandler/*.java \
|
||||||
|
${SRC_DIR}/jdk/test/failurehandler/action/*.java \
|
||||||
|
${SRC_DIR}/jdk/test/failurehandler/jtreg/*.java \
|
||||||
|
${SRC_DIR}/jdk/test/failurehandler/value/*.java
|
||||||
|
|
||||||
|
CONF_DIR = src/share/conf
|
||||||
|
|
||||||
|
JAVA_RELEASE = 7
|
||||||
|
|
||||||
|
TARGET_JAR = ${IMAGE_DIR}/lib/jtregFailureHandler.jar
|
||||||
|
|
||||||
|
OS_NAME := $(shell uname -o 2>&1)
|
||||||
|
|
||||||
|
ifeq ("${OS_NAME}", "Cygwin")
|
||||||
|
BUILD_DIR := $(shell cygpath -m "${BUILD_DIR}")
|
||||||
|
CLASSES_DIR := $(shell cygpath -m "${CLASSES_DIR}")
|
||||||
|
IMAGE_DIR := $(shell cygpath -m "${IMAGE_DIR}") RUN_DIR := $(shell cygpath -m "${RUN_DIR}")
|
||||||
|
SRC_DIR := $(shell cygpath -m "${SRC_DIR}")
|
||||||
|
JTREG_HOME := $(shell cygpath -m "${JTREG_HOME}")
|
||||||
|
CC := "cl.exe"
|
||||||
|
endif
|
||||||
|
|
||||||
|
all: clean test
|
||||||
|
|
||||||
|
native: require_env
|
||||||
|
ifeq ("${OS_NAME}", "Cygwin")
|
||||||
|
"${CC}" src/windows/native/jdk/test/failurehandler/jtreg/*.c \
|
||||||
|
-I"$(shell cygpath -w ${JAVA_HOME}/include)" \
|
||||||
|
-I"$(shell cygpath -w ${JAVA_HOME}/include/win32)" \
|
||||||
|
/link /MACHINE:X64 /DLL /OUT:timeoutHandler.dll
|
||||||
|
endif
|
||||||
|
|
||||||
|
check_defined = $(foreach 1,$1,$(__check_defined))
|
||||||
|
__check_defined = $(if $(value $1),, $(error $1 is not set))
|
||||||
|
|
||||||
|
classes: require_env
|
||||||
|
mkdir -p ${IMAGE_DIR}/bin ${IMAGE_DIR}/lib ${CLASSES_DIR}
|
||||||
|
"${JAVA_HOME}"/bin/javac -target ${JAVA_RELEASE} -source ${JAVA_RELEASE} \
|
||||||
|
-sourcepath $(shell pwd) \
|
||||||
|
-classpath ${JTREG_HOME}/lib/jtreg.jar:${JAVA_HOME}/lib/tools.jar \
|
||||||
|
-d ${CLASSES_DIR} \
|
||||||
|
${SOURCES}
|
||||||
|
"${JAVA_HOME}"/bin/jar cf ${TARGET_JAR} -C ${CLASSES_DIR} .
|
||||||
|
"${JAVA_HOME}"/bin/jar uf ${TARGET_JAR} -C ${CONF_DIR} .
|
||||||
|
|
||||||
|
#
|
||||||
|
# Use JTREG_TEST_OPTS for test VM options
|
||||||
|
# Use JTREG_TESTS for jtreg tests parameter
|
||||||
|
#
|
||||||
|
test: require_env build
|
||||||
|
rm -rf ${RUN_DIR}
|
||||||
|
mkdir -p ${RUN_DIR}
|
||||||
|
"${JTREG_HOME}"/bin/jtreg \
|
||||||
|
-jdk:"${JAVA_HOME}" \
|
||||||
|
${JTREG_TEST_OPTS} \
|
||||||
|
-timeout:0.1 -va -retain:all \
|
||||||
|
-noreport \
|
||||||
|
-agentvm \
|
||||||
|
-thd:"${TARGET_JAR}" \
|
||||||
|
-th:jdk.test.failurehandler.jtreg.GatherProcessInfoTimeoutHandler \
|
||||||
|
-od:"${TARGET_JAR}" \
|
||||||
|
-o:jdk.test.failurehandler.jtreg.GatherDiagnosticInfoObserver \
|
||||||
|
-w:${RUN_DIR}/JTwork -r:${RUN_DIR}/JTreport \
|
||||||
|
$(if ${JTREG_TESTS}, ${JTREG_TESTS}, test) \
|
||||||
|
&& false || true
|
||||||
|
|
||||||
|
debug: JTREG_TEST_OPTS += "-J-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005'"
|
||||||
|
debug: test
|
||||||
|
|
||||||
|
require_env:
|
||||||
|
$(call check_defined, JAVA_HOME)
|
||||||
|
$(call check_defined, JTREG_HOME)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -rf "${BUILD_DIR}" "${RUN_DIR}"
|
||||||
|
|
||||||
|
build: classes native
|
||||||
|
|
||||||
|
.PHONY: all build classes native test require_env clean
|
||||||
|
.DEFAULT: all
|
||||||
|
|
107
test/failure_handler/README
Normal file
107
test/failure_handler/README
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
|
||||||
|
This code is free software; you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU General Public License version 2 only, as
|
||||||
|
published by the Free Software Foundation.
|
||||||
|
|
||||||
|
This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
accompanied this code).
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License version
|
||||||
|
2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
|
||||||
|
Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
or visit www.oracle.com if you need additional information or have any
|
||||||
|
questions.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
|
||||||
|
The purpose of this library is gathering diagnostic information on test
|
||||||
|
failures and timeouts. The library runs platform specific tools, which are
|
||||||
|
configured in the way described below. The collected data will be available
|
||||||
|
in HTML format next to JTR files.
|
||||||
|
|
||||||
|
The library uses JTHarness Observer and jtreg TimeoutHandler extensions points.
|
||||||
|
|
||||||
|
DEPENDENCES
|
||||||
|
|
||||||
|
The library requires jtreg 4b13+ and JDK 7+.
|
||||||
|
|
||||||
|
BUILDING
|
||||||
|
|
||||||
|
To build a library, one should simply run make with 'JTREG_HOME' and
|
||||||
|
'JAVA_HOME' environment variables set. 'JAVA_HOME' should contain path to JDK,
|
||||||
|
'JTREG_HOME' -- path to jtreg.
|
||||||
|
|
||||||
|
'image/lib/jtregFailureHandler.jar' is created on successful build.
|
||||||
|
|
||||||
|
CONFIGURATION
|
||||||
|
|
||||||
|
Properties files are used to configure the library. They define which actions
|
||||||
|
to be performed in case of individual test failure or timeout. Each platform
|
||||||
|
family uses its own property file (named '<platform>.properties'). For platform
|
||||||
|
independent actions, 'common.properties' is used.
|
||||||
|
|
||||||
|
Actions to be performed on each failure are listed in 'environment' property.
|
||||||
|
Extra actions for timeouts are listed in 'onTimeout'.
|
||||||
|
|
||||||
|
Each action is defined via the following parameters:
|
||||||
|
- 'javaOnly' -- run the action only for java applications, false by default
|
||||||
|
- 'app' -- an application to run, mandatory parameter
|
||||||
|
- 'args' -- application command line arguments, none by default
|
||||||
|
- 'params' -- a structure which defines how an application should be run,
|
||||||
|
described below
|
||||||
|
|
||||||
|
Actions listed in 'onTimeout' are "patterned" actions. Besides the parameters
|
||||||
|
listed above, they also have 'pattern' parameter -- a string which will be
|
||||||
|
replaced by PID in 'args' parameter before action execution.
|
||||||
|
|
||||||
|
'params' structure has the following parameters:
|
||||||
|
- repeat -- how many times an action will be run, 1 by default
|
||||||
|
- pause -- delay in ms between iterations, 500 by default
|
||||||
|
- timeout -- time limitation for iteration in ms, 20 000 by default
|
||||||
|
- stopOnError -- if true, an action will be interrupted after the first error,
|
||||||
|
false by default
|
||||||
|
|
||||||
|
From '<platform>.properties', the library reads the following parameters
|
||||||
|
- 'config.execSuffix' -- a suffix for all binary application file names
|
||||||
|
- 'config.getChildren' -- a "patterned" action used to get the list of all
|
||||||
|
children
|
||||||
|
|
||||||
|
For simplicity we use parameter values inheritance. This means that we are
|
||||||
|
looking for the most specified parameter value. If we do not find it, we are
|
||||||
|
trying to find less specific value by reducing prefix.
|
||||||
|
For example, if properties contains 'p1=A', 'a.p1=B', 'a.b.p1=C', then
|
||||||
|
parameter 'p1' will be:
|
||||||
|
- 'C' for 'a.b.c'
|
||||||
|
- 'B' for 'a.c'
|
||||||
|
- 'A' for 'b.c'
|
||||||
|
|
||||||
|
RUNNING
|
||||||
|
|
||||||
|
To enable the library in jtreg, the following options should be set:
|
||||||
|
- '-timeoutHandlerDir' points to the built jar ('jtregFailureHandler.jar')
|
||||||
|
- '-observerDir' points to the built jar
|
||||||
|
- '-timeoutHandler' equals to jdk.test.failurehandler.jtreg.GatherProcessInfoTimeoutHandler
|
||||||
|
- '-observer' equals to jdk.test.failurehandler.jtreg.GatherDiagnosticInfoObserver
|
||||||
|
|
||||||
|
In case of environment issues during an action execution, such as missing
|
||||||
|
application, hung application, lack of disk space, etc, the corresponding
|
||||||
|
warning appears and the library proceeds to next action.
|
||||||
|
|
||||||
|
EXAMPLES
|
||||||
|
|
||||||
|
$ ${JTREG_HOME}/bin/jtreg -jdk:${JAVA_HOME} \
|
||||||
|
-timeoutHandlerDir:./image/lib/jtregFailureHandler.jar \
|
||||||
|
-observerDir:./image/lib/jtregFailureHandler.jar \
|
||||||
|
-timeoutHandler:jdk.test.failurehandler.jtreg.GatherProcessInfoTimeoutHandler\
|
||||||
|
-observer:jdk.test.failurehandler.jtreg.GatherDiagnosticInfoObserver \
|
||||||
|
${WS}/hotspot/test/
|
||||||
|
|
@ -0,0 +1,48 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
public class ElapsedTimePrinter implements AutoCloseable {
|
||||||
|
private final String name;
|
||||||
|
private final PrintWriter out;
|
||||||
|
private final Stopwatch stopwatch;
|
||||||
|
|
||||||
|
public ElapsedTimePrinter(Stopwatch stopwatch, String name,
|
||||||
|
PrintWriter out) {
|
||||||
|
this.stopwatch = stopwatch;
|
||||||
|
this.name = name;
|
||||||
|
this.out = out;
|
||||||
|
stopwatch.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
stopwatch.stop();
|
||||||
|
out.printf("%s took %d s%n", name,
|
||||||
|
TimeUnit.NANOSECONDS.toSeconds(stopwatch.getElapsedTimeNs()));
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
public interface EnvironmentInfoGatherer {
|
||||||
|
void gatherEnvironmentInfo(HtmlSection section);
|
||||||
|
}
|
@ -0,0 +1,63 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.action.ActionHelper;
|
||||||
|
import jdk.test.failurehandler.value.InvalidValueException;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public final class GathererFactory {
|
||||||
|
private final Path workdir;
|
||||||
|
private final Path[] jdks;
|
||||||
|
private final PrintWriter log;
|
||||||
|
private final String osName;
|
||||||
|
|
||||||
|
public GathererFactory(String osName, Path workdir, PrintWriter log, Path... jdks) {
|
||||||
|
this.osName = osName;
|
||||||
|
this.workdir = workdir;
|
||||||
|
this.log = log;
|
||||||
|
this.jdks = jdks;
|
||||||
|
}
|
||||||
|
|
||||||
|
public EnvironmentInfoGatherer getEnvironmentInfoGatherer() {
|
||||||
|
return create();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProcessInfoGatherer getProcessInfoGatherer() {
|
||||||
|
return create();
|
||||||
|
}
|
||||||
|
|
||||||
|
private ToolKit create() {
|
||||||
|
Properties osProperty = Utils.getProperties(osName);
|
||||||
|
try {
|
||||||
|
ActionHelper helper = new ActionHelper(workdir, "config", osProperty, jdks);
|
||||||
|
return new ToolKit(helper, log, osName, "common");
|
||||||
|
} catch (InvalidValueException e) {
|
||||||
|
throw new IllegalStateException("can't create tool kit", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
public class HtmlPage implements AutoCloseable {
|
||||||
|
private final PrintWriter writer;
|
||||||
|
private final HtmlSection rootSection;
|
||||||
|
|
||||||
|
public HtmlPage(PrintWriter writer) {
|
||||||
|
Objects.requireNonNull(writer, "writer cannot be null");
|
||||||
|
this.writer = writer;
|
||||||
|
rootSection = new HtmlSection(writer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
writer.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public HtmlSection getRootSection() {
|
||||||
|
return rootSection;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,237 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
import java.io.FilterWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
|
||||||
|
public class HtmlSection {
|
||||||
|
protected final HtmlSection rootSection;
|
||||||
|
protected final String id;
|
||||||
|
protected final String name;
|
||||||
|
|
||||||
|
public PrintWriter getWriter() {
|
||||||
|
return textWriter;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final PrintWriter pw;
|
||||||
|
protected final PrintWriter textWriter;
|
||||||
|
protected boolean closed;
|
||||||
|
|
||||||
|
private HtmlSection child;
|
||||||
|
|
||||||
|
|
||||||
|
public HtmlSection(PrintWriter pw) {
|
||||||
|
this(pw, "", null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private HtmlSection(PrintWriter pw, String id, String name, HtmlSection rootSection) {
|
||||||
|
this.pw = pw;
|
||||||
|
textWriter = new PrintWriter(new HtmlFilterWriter(pw));
|
||||||
|
this.id = id;
|
||||||
|
this.name = name;
|
||||||
|
child = null;
|
||||||
|
// main
|
||||||
|
if (rootSection == null) {
|
||||||
|
this.rootSection = this;
|
||||||
|
this.pw.println("<html>");
|
||||||
|
this.pw.println("<style>\n"
|
||||||
|
+ "div { display:none;}\n"
|
||||||
|
+ "</style>\n"
|
||||||
|
+ "\n"
|
||||||
|
+ "<script>\n"
|
||||||
|
+ "function show(e) {\n"
|
||||||
|
+ " while (e != null) {\n"
|
||||||
|
+ " if (e.tagName == 'DIV') {\n"
|
||||||
|
+ " e.style.display = 'block';\n"
|
||||||
|
+ " }\n"
|
||||||
|
+ " e = e.parentNode;\n"
|
||||||
|
+ " }\n"
|
||||||
|
+ "}\n"
|
||||||
|
+ "\n"
|
||||||
|
+ "function toggle(id) {\n"
|
||||||
|
+ " e = document.getElementById(id);\n"
|
||||||
|
+ " d = e.style.display;\n"
|
||||||
|
+ " if (d == 'block') {\n"
|
||||||
|
+ " e.style.display = 'none';\n"
|
||||||
|
+ " } else {\n"
|
||||||
|
+ " show(e);\n"
|
||||||
|
+ " }\n"
|
||||||
|
+ "}\n"
|
||||||
|
+ "\n"
|
||||||
|
+ "function main() {\n"
|
||||||
|
+ " index = location.href.indexOf(\"#\");"
|
||||||
|
+ " if (index != -1) {\n"
|
||||||
|
+ " show(document.getElementById(location.href.substring(index + 1)));\n"
|
||||||
|
+ " }\n"
|
||||||
|
+ "}\n"
|
||||||
|
+ "\n"
|
||||||
|
+ "</script>\n"
|
||||||
|
+ "</head>");
|
||||||
|
|
||||||
|
this.pw.println("<body onload='main()'>");
|
||||||
|
} else {
|
||||||
|
this.rootSection = rootSection;
|
||||||
|
this.pw.print("<ul>");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public HtmlSection createChildren(String section) {
|
||||||
|
if (child != null) {
|
||||||
|
if (child.name.equals(section)) {
|
||||||
|
return child;
|
||||||
|
}
|
||||||
|
child.close();
|
||||||
|
}
|
||||||
|
child = new SubSection(this, section, rootSection);
|
||||||
|
return child;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final void removeChild(HtmlSection child) {
|
||||||
|
if (this.child == child) {
|
||||||
|
this.child = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
closeChild();
|
||||||
|
if (closed) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
closed = true;
|
||||||
|
|
||||||
|
if (rootSection == this) {
|
||||||
|
pw.println("</body>");
|
||||||
|
pw.println("</html>");
|
||||||
|
pw.close();
|
||||||
|
} else {
|
||||||
|
pw.println("</ul>");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final void closeChild() {
|
||||||
|
if (child != null) {
|
||||||
|
child.close();
|
||||||
|
child = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void link(HtmlSection section, String child, String name) {
|
||||||
|
String path = section.id;
|
||||||
|
if (path.isEmpty()) {
|
||||||
|
path = child;
|
||||||
|
} else if (child != null) {
|
||||||
|
path = String.format("%s.%s", path, child);
|
||||||
|
}
|
||||||
|
pw.printf("<a href=\"#%1$s\" onclick=\"show(document.getElementById('%1$s')); return true;\">%2$s</a>%n",
|
||||||
|
path, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public HtmlSection createChildren(String[] sections) {
|
||||||
|
int i = 0;
|
||||||
|
int n = sections.length;
|
||||||
|
HtmlSection current = rootSection;
|
||||||
|
if (current != null) {
|
||||||
|
for (; i < n && current.child != null;
|
||||||
|
++i, current = current.child) {
|
||||||
|
if (!sections[i].equals(current.child.name)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (; i < n; ++i) {
|
||||||
|
current = current.createChildren(sections[i]);
|
||||||
|
}
|
||||||
|
return current;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class SubSection extends HtmlSection {
|
||||||
|
private final HtmlSection parent;
|
||||||
|
|
||||||
|
public SubSection(HtmlSection parent, String name,
|
||||||
|
HtmlSection rootSection) {
|
||||||
|
super(parent.pw,
|
||||||
|
parent.id.isEmpty()
|
||||||
|
? name
|
||||||
|
: String.format("%s.%s", parent.id, name),
|
||||||
|
name, rootSection);
|
||||||
|
this.parent = parent;
|
||||||
|
pw.printf("<li><a name='%1$s'/><a href='#%1$s' onclick=\"toggle('%1$s'); return false;\">%2$s</a><div id='%1$s'><code><pre>",
|
||||||
|
id, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
closeChild();
|
||||||
|
if (closed) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
pw.print("</pre></code></div></li><!-- " + id + "-->");
|
||||||
|
parent.removeChild(this);
|
||||||
|
super.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class HtmlFilterWriter extends FilterWriter {
|
||||||
|
public HtmlFilterWriter(PrintWriter pw) {
|
||||||
|
super(pw);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void write(int c) throws IOException {
|
||||||
|
switch (c) {
|
||||||
|
case '<':
|
||||||
|
super.write("<", 0, 4);
|
||||||
|
break;
|
||||||
|
case '>':
|
||||||
|
super.write(">", 0, 4);
|
||||||
|
break;
|
||||||
|
case '"':
|
||||||
|
super.write(""", 0, 5);
|
||||||
|
break;
|
||||||
|
case '&':
|
||||||
|
super.write("&", 0, 4);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
super.write(c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void write(char[] cbuf, int off, int len) throws IOException {
|
||||||
|
for (int i = off; i < len; ++i){
|
||||||
|
write(cbuf[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void write(String str, int off, int len) throws IOException {
|
||||||
|
for (int i = off; i < len; ++i){
|
||||||
|
write(str.charAt(i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
public interface ProcessInfoGatherer {
|
||||||
|
void gatherProcessInfo(HtmlSection section, long pid);
|
||||||
|
}
|
@ -0,0 +1,73 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
public final class Stopwatch {
|
||||||
|
protected boolean isResultAvailable;
|
||||||
|
protected boolean isRunning;
|
||||||
|
|
||||||
|
private long startTimeNs;
|
||||||
|
private long stopTimeNs;
|
||||||
|
|
||||||
|
public Stopwatch() {
|
||||||
|
isResultAvailable = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Starts measuring time.
|
||||||
|
*/
|
||||||
|
public void start() {
|
||||||
|
startTimeNs = System.nanoTime();
|
||||||
|
isRunning = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stops measuring time.
|
||||||
|
*/
|
||||||
|
public void stop() {
|
||||||
|
if (!isRunning) {
|
||||||
|
throw new IllegalStateException(" hasn't been started");
|
||||||
|
}
|
||||||
|
stopTimeNs = System.nanoTime();
|
||||||
|
isRunning = false;
|
||||||
|
isResultAvailable = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return time in nanoseconds measured between
|
||||||
|
* calls of {@link #start()} and {@link #stop()} methods.
|
||||||
|
*
|
||||||
|
* @throws IllegalStateException if called without preceding
|
||||||
|
* {@link #start()} {@link #stop()} method
|
||||||
|
*/
|
||||||
|
public long getElapsedTimeNs() {
|
||||||
|
if (isRunning) {
|
||||||
|
throw new IllegalStateException("hasn't been stopped");
|
||||||
|
}
|
||||||
|
if (!isResultAvailable) {
|
||||||
|
throw new IllegalStateException("was not run");
|
||||||
|
}
|
||||||
|
return stopTimeNs - startTimeNs;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,72 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.action.ActionSet;
|
||||||
|
import jdk.test.failurehandler.action.ActionHelper;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Queue;
|
||||||
|
|
||||||
|
public class ToolKit implements EnvironmentInfoGatherer, ProcessInfoGatherer {
|
||||||
|
private final List<ActionSet> actions = new ArrayList<>();
|
||||||
|
private final ActionHelper helper;
|
||||||
|
|
||||||
|
public ToolKit(ActionHelper helper, PrintWriter log, String... names) {
|
||||||
|
this.helper = helper;
|
||||||
|
for (String name : names) {
|
||||||
|
actions.add(new ActionSet(helper, log, name));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void gatherEnvironmentInfo(HtmlSection section) {
|
||||||
|
for (ActionSet set : actions) {
|
||||||
|
set.gatherEnvironmentInfo(section);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void gatherProcessInfo(HtmlSection section, long pid) {
|
||||||
|
Queue<Long> pids = new LinkedList<>();
|
||||||
|
pids.add(pid);
|
||||||
|
for (Long p = pids.poll(); p != null; p = pids.poll()) {
|
||||||
|
HtmlSection pidSection = section.createChildren("" + p);
|
||||||
|
for (ActionSet set : actions) {
|
||||||
|
set.gatherProcessInfo(pidSection, p);
|
||||||
|
}
|
||||||
|
List<Long> children = helper.getChildren(pidSection, p);
|
||||||
|
if (!children.isEmpty()) {
|
||||||
|
HtmlSection s = pidSection.createChildren("children");
|
||||||
|
for (Long c : children) {
|
||||||
|
s.link(section, c.toString(), c.toString());
|
||||||
|
}
|
||||||
|
pids.addAll(children);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,88 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.Reader;
|
||||||
|
import java.io.Writer;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public final class Utils {
|
||||||
|
private static final int BUFFER_LENGTH = 1024;
|
||||||
|
|
||||||
|
public static String prependPrefix(String prefix, String name) {
|
||||||
|
return (prefix == null || prefix.isEmpty())
|
||||||
|
? name
|
||||||
|
: (name == null || name.isEmpty())
|
||||||
|
? prefix
|
||||||
|
: String.format("%s.%s", prefix, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void copyStream(InputStream in, OutputStream out)
|
||||||
|
throws IOException {
|
||||||
|
int n;
|
||||||
|
byte[] buffer = new byte[BUFFER_LENGTH];
|
||||||
|
while ((n = in.read(buffer)) != -1) {
|
||||||
|
out.write(buffer, 0, n);
|
||||||
|
}
|
||||||
|
out.flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void copyStream(Reader in, Writer out)
|
||||||
|
throws IOException {
|
||||||
|
int n;
|
||||||
|
char[] buffer = new char[BUFFER_LENGTH];
|
||||||
|
while ((n = in.read(buffer)) != -1) {
|
||||||
|
out.write(buffer, 0, n);
|
||||||
|
}
|
||||||
|
out.flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Properties getProperties(String name) {
|
||||||
|
Properties properties = new Properties();
|
||||||
|
String resourceName = String.format(
|
||||||
|
"/%s.%s", name.toLowerCase(), "properties");
|
||||||
|
InputStream stream = Utils.class.getResourceAsStream(resourceName);
|
||||||
|
if (stream == null) {
|
||||||
|
throw new IllegalStateException(String.format(
|
||||||
|
"resource '%s' doesn't exist%n", resourceName));
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
try {
|
||||||
|
properties.load(stream);
|
||||||
|
} finally {
|
||||||
|
stream.close();
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new IllegalStateException(String.format(
|
||||||
|
"can't read resource '%s' : %s%n",
|
||||||
|
resourceName, e.getMessage()), e);
|
||||||
|
}
|
||||||
|
return properties;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Utils() { }
|
||||||
|
}
|
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.action;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.HtmlSection;
|
||||||
|
|
||||||
|
public interface Action {
|
||||||
|
boolean isJavaOnly();
|
||||||
|
HtmlSection getSection(HtmlSection section);
|
||||||
|
|
||||||
|
ActionParameters getParameters();
|
||||||
|
}
|
@ -0,0 +1,360 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.action;
|
||||||
|
|
||||||
|
import com.sun.tools.attach.VirtualMachine;
|
||||||
|
import com.sun.tools.attach.VirtualMachineDescriptor;
|
||||||
|
import jdk.test.failurehandler.value.InvalidValueException;
|
||||||
|
import jdk.test.failurehandler.value.Value;
|
||||||
|
import jdk.test.failurehandler.value.ValueHandler;
|
||||||
|
import jdk.test.failurehandler.HtmlSection;
|
||||||
|
import jdk.test.failurehandler.Stopwatch;
|
||||||
|
import jdk.test.failurehandler.Utils;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.CharArrayReader;
|
||||||
|
import java.io.CharArrayWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.io.Reader;
|
||||||
|
import java.io.Writer;
|
||||||
|
import java.io.File;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
public class ActionHelper {
|
||||||
|
private final Path workDir;
|
||||||
|
@Value(name = "execSuffix")
|
||||||
|
private String executableSuffix = "";
|
||||||
|
private Path[] paths;
|
||||||
|
|
||||||
|
private final PatternAction getChildren;
|
||||||
|
|
||||||
|
public ActionHelper(Path workDir, String prefix, Properties properties,
|
||||||
|
Path... jdks) throws InvalidValueException {
|
||||||
|
this.workDir = workDir.toAbsolutePath();
|
||||||
|
getChildren = new PatternAction("children",
|
||||||
|
Utils.prependPrefix(prefix, "getChildren"), properties);
|
||||||
|
ValueHandler.apply(this, properties, prefix);
|
||||||
|
String[] pathStrings = System.getenv("PATH").split(File.pathSeparator);
|
||||||
|
paths = new Path[pathStrings.length];
|
||||||
|
for (int i = 0; i < paths.length; ++i) {
|
||||||
|
paths[i] = Paths.get(pathStrings[i]);
|
||||||
|
}
|
||||||
|
addJdks(jdks);
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Long> getChildren(HtmlSection section, long pid) {
|
||||||
|
String pidStr = "" + pid;
|
||||||
|
ProcessBuilder pb = getChildren.prepareProcess(section, this, pidStr);
|
||||||
|
PrintWriter log = getChildren.getSection(section).getWriter();
|
||||||
|
CharArrayWriter writer = new CharArrayWriter();
|
||||||
|
ExitCode code = run(log, writer, pb, getChildren.getParameters());
|
||||||
|
Reader output = new CharArrayReader(writer.toCharArray());
|
||||||
|
|
||||||
|
if (!ExitCode.OK.equals(code)) {
|
||||||
|
log.println("WARNING: get children pids action failed");
|
||||||
|
try {
|
||||||
|
Utils.copyStream(output, log);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
|
||||||
|
List<Long> result = new ArrayList<>();
|
||||||
|
try {
|
||||||
|
try (BufferedReader reader = new BufferedReader(output)) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
String value = line.trim();
|
||||||
|
if (value.isEmpty()) {
|
||||||
|
// ignore empty lines
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
result.add(Long.valueOf(value));
|
||||||
|
} catch (NumberFormatException e) {
|
||||||
|
log.printf("WARNING: can't parse child pid %s : %s%n",
|
||||||
|
line, e.getMessage());
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProcessBuilder prepareProcess(PrintWriter log, String app,
|
||||||
|
String... args) {
|
||||||
|
File appBin = findApp(app);
|
||||||
|
if (appBin == null) {
|
||||||
|
log.printf("ERROR: can't find %s in %s.%n",
|
||||||
|
app, Arrays.toString(paths));
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
List<String> command = new ArrayList<>(args.length + 1);
|
||||||
|
command.add(appBin.toString());
|
||||||
|
Collections.addAll(command, args);
|
||||||
|
return new ProcessBuilder()
|
||||||
|
.command(command)
|
||||||
|
.directory(workDir.toFile());
|
||||||
|
}
|
||||||
|
|
||||||
|
private File findApp(String app) {
|
||||||
|
String name = app + executableSuffix;
|
||||||
|
for (Path pathElem : paths) {
|
||||||
|
File result = pathElem.resolve(name).toFile();
|
||||||
|
if (result.exists()) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addJdks(Path[] jdkPaths) {
|
||||||
|
if (jdkPaths != null && jdkPaths.length != 0) {
|
||||||
|
Path[] result = new Path[jdkPaths.length + paths.length];
|
||||||
|
for (int i = 0; i < jdkPaths.length; ++i) {
|
||||||
|
result[i] = jdkPaths[i].resolve("bin");
|
||||||
|
}
|
||||||
|
System.arraycopy(paths, 0, result, jdkPaths.length, paths.length);
|
||||||
|
paths = result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private ExitCode run(PrintWriter log, Writer out, ProcessBuilder pb,
|
||||||
|
ActionParameters params) {
|
||||||
|
char[] lineChars = new char[40];
|
||||||
|
Arrays.fill(lineChars, '-');
|
||||||
|
String line = new String(lineChars);
|
||||||
|
Stopwatch stopwatch = new Stopwatch();
|
||||||
|
stopwatch.start();
|
||||||
|
|
||||||
|
log.printf("%s%n[%tF %<tT] %s%n%1$s%n", line, new Date(), pb.command());
|
||||||
|
Process process;
|
||||||
|
KillerTask killer;
|
||||||
|
|
||||||
|
ExitCode result = ExitCode.NEVER_STARTED;
|
||||||
|
|
||||||
|
try {
|
||||||
|
process = pb.start();
|
||||||
|
killer = new KillerTask(process);
|
||||||
|
killer.schedule(params.timeout);
|
||||||
|
Utils.copyStream(new InputStreamReader(process.getInputStream()),
|
||||||
|
out);
|
||||||
|
try {
|
||||||
|
result = new ExitCode(process.waitFor());
|
||||||
|
killer.cancel();
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
if (!killer.cancel()) {
|
||||||
|
log.println(
|
||||||
|
"WARNING: interrupted when waiting for the tool:");
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (killer.hasTimedOut()) {
|
||||||
|
log.printf(
|
||||||
|
"WARNING: tool timed out: killed process after %d ms%n",
|
||||||
|
TimeUnit.MILLISECONDS.toMicros(params.timeout));
|
||||||
|
result = ExitCode.TIMED_OUT;
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace(log);
|
||||||
|
result = ExitCode.LAUNCH_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
stopwatch.stop();
|
||||||
|
log.printf("%s%n[%tF %<tT] exit code : %d time : %d ms%n%1$s%n",
|
||||||
|
line, new Date(), result.value,
|
||||||
|
TimeUnit.MILLISECONDS.toSeconds(stopwatch.getElapsedTimeNs()));
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void runPatternAction(SimpleAction action, HtmlSection section) {
|
||||||
|
if (action != null) {
|
||||||
|
HtmlSection subSection = action.getSection(section);
|
||||||
|
PrintWriter log = subSection.getWriter();
|
||||||
|
ProcessBuilder pb = action.prepareProcess(log, this);
|
||||||
|
exec(subSection, pb, action.getParameters());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void runPatternAction(PatternAction action, HtmlSection section,
|
||||||
|
String value) {
|
||||||
|
if (action != null) {
|
||||||
|
ProcessBuilder pb = action.prepareProcess(section, this, value);
|
||||||
|
HtmlSection subSection = action.getSection(section);
|
||||||
|
exec(subSection, pb, action.getParameters());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isJava(long pid, PrintWriter log) {
|
||||||
|
ProcessBuilder pb = prepareProcess(log, "jps", "-q");
|
||||||
|
if (pb == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
pb.redirectErrorStream(true);
|
||||||
|
boolean result = false;
|
||||||
|
String pidStr = "" + pid;
|
||||||
|
try {
|
||||||
|
Process process = pb.start();
|
||||||
|
try (BufferedReader reader = new BufferedReader(
|
||||||
|
new InputStreamReader(process.getInputStream()))) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null){
|
||||||
|
if (pidStr.equals(line)) {
|
||||||
|
result = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
process.waitFor();
|
||||||
|
} catch (IOException e) {
|
||||||
|
log.printf("WARNING: can't run jps : %s%n", e.getMessage());
|
||||||
|
e.printStackTrace(log);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class KillerTask extends TimerTask {
|
||||||
|
private static final Timer WATCHDOG = new Timer("WATCHDOG", true);
|
||||||
|
private final Process process;
|
||||||
|
private boolean timedOut;
|
||||||
|
|
||||||
|
public KillerTask(Process process) {
|
||||||
|
this.process = process;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
process.exitValue();
|
||||||
|
} catch (IllegalThreadStateException e) {
|
||||||
|
// !prepareProcess.isAlive()
|
||||||
|
process.destroy();
|
||||||
|
timedOut = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean hasTimedOut() {
|
||||||
|
return timedOut;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void schedule(long timeout) {
|
||||||
|
if (timeout > 0) {
|
||||||
|
WATCHDOG.schedule(this, timeout);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void exec(HtmlSection section, ProcessBuilder process,
|
||||||
|
ActionParameters params) {
|
||||||
|
if (process == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PrintWriter sectionWriter = section.getWriter();
|
||||||
|
if (params.repeat > 1) {
|
||||||
|
for (int i = 0, n = params.repeat; i < n; ++i) {
|
||||||
|
HtmlSection iteration = section.createChildren(
|
||||||
|
String.format("iteration_%d", i));
|
||||||
|
PrintWriter writer = iteration.getWriter();
|
||||||
|
ExitCode exitCode = run(writer, writer, process, params);
|
||||||
|
if (params.stopOnError && !ExitCode.OK.equals(exitCode)) {
|
||||||
|
sectionWriter.printf(
|
||||||
|
"ERROR: non zero exit code[%d] -- break.",
|
||||||
|
exitCode.value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(params.pause);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
e.printStackTrace(sectionWriter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
run(section.getWriter(), section.getWriter(), process, params);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Special values for prepareProcess exit code.
|
||||||
|
*
|
||||||
|
* <p>Can we clash with normal codes?
|
||||||
|
* On Solaris and Linux, only [0..255] are returned.
|
||||||
|
* On Windows, prepareProcess exit codes are stored in unsigned int.
|
||||||
|
* On MacOSX no limits (except it should fit C int type)
|
||||||
|
* are defined in the exit() man pages.
|
||||||
|
*/
|
||||||
|
private static class ExitCode {
|
||||||
|
/** Process exits gracefully */
|
||||||
|
public static final ExitCode OK = new ExitCode(0);
|
||||||
|
/** Error launching prepareProcess */
|
||||||
|
public static final ExitCode LAUNCH_ERROR = new ExitCode(-1);
|
||||||
|
/** Application prepareProcess has been killed by watchdog due to timeout */
|
||||||
|
public static final ExitCode TIMED_OUT = new ExitCode(-2);
|
||||||
|
/** Application prepareProcess has never been started due to program logic */
|
||||||
|
public static final ExitCode NEVER_STARTED = new ExitCode(-3);
|
||||||
|
|
||||||
|
public final int value;
|
||||||
|
|
||||||
|
private ExitCode(int value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (o == null || getClass() != o.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
ExitCode exitCode = (ExitCode) o;
|
||||||
|
return value == exitCode.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.action;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.value.DefaultValue;
|
||||||
|
import jdk.test.failurehandler.value.Value;
|
||||||
|
|
||||||
|
public class ActionParameters {
|
||||||
|
@Value (name = "repeat")
|
||||||
|
@DefaultValue (value = "1")
|
||||||
|
public int repeat = 1;
|
||||||
|
|
||||||
|
@Value (name = "pause")
|
||||||
|
@DefaultValue (value = "500")
|
||||||
|
public long pause = 500;
|
||||||
|
|
||||||
|
@Value (name = "stopOnError")
|
||||||
|
@DefaultValue (value = "false")
|
||||||
|
public boolean stopOnError = false;
|
||||||
|
|
||||||
|
@Value (name = "timeout")
|
||||||
|
@DefaultValue (value = "" + 20_000L)
|
||||||
|
public long timeout = -1L;
|
||||||
|
|
||||||
|
public ActionParameters() { }
|
||||||
|
}
|
@ -0,0 +1,126 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.action;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.ProcessInfoGatherer;
|
||||||
|
import jdk.test.failurehandler.EnvironmentInfoGatherer;
|
||||||
|
import jdk.test.failurehandler.HtmlSection;
|
||||||
|
import jdk.test.failurehandler.Utils;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public class ActionSet implements ProcessInfoGatherer, EnvironmentInfoGatherer {
|
||||||
|
private static final String ENVIRONMENT_PROPERTY = "environment";
|
||||||
|
private static final String ON_PID_PROPERTY = "onTimeout";
|
||||||
|
|
||||||
|
private final ActionHelper helper;
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
private final String name;
|
||||||
|
private final List<SimpleAction> environmentActions;
|
||||||
|
private final List<PatternAction> processActions;
|
||||||
|
|
||||||
|
|
||||||
|
public ActionSet(ActionHelper helper, PrintWriter log, String name) {
|
||||||
|
this.helper = helper;
|
||||||
|
this.name = name;
|
||||||
|
|
||||||
|
Properties p = Utils.getProperties(name);
|
||||||
|
environmentActions = getSimpleActions(log, p, ENVIRONMENT_PROPERTY);
|
||||||
|
processActions = getPatternActions(log, p, ON_PID_PROPERTY);
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<SimpleAction> getSimpleActions(PrintWriter log, Properties p,
|
||||||
|
String key) {
|
||||||
|
String[] tools = getTools(log, p, key);
|
||||||
|
List<SimpleAction> result = new ArrayList<>(tools.length);
|
||||||
|
for (String tool : tools) {
|
||||||
|
try {
|
||||||
|
SimpleAction action = new SimpleAction(
|
||||||
|
Utils.prependPrefix(name, tool), tool, p);
|
||||||
|
result.add(action);
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.printf("ERROR: %s cannot be created : %s %n",
|
||||||
|
tool, e.getMessage());
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<PatternAction> getPatternActions(PrintWriter log,
|
||||||
|
Properties p, String key) {
|
||||||
|
String[] tools = getTools(log, p, key);
|
||||||
|
List<PatternAction> result = new ArrayList<>(tools.length);
|
||||||
|
for (String tool : tools) {
|
||||||
|
try {
|
||||||
|
PatternAction action = new PatternAction(
|
||||||
|
Utils.prependPrefix(name, tool), tool, p);
|
||||||
|
result.add(action);
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.printf("ERROR: %s cannot be created : %s %n",
|
||||||
|
tool, e.getMessage());
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String[] getTools(PrintWriter writer, Properties p, String key) {
|
||||||
|
String value = p.getProperty(key);
|
||||||
|
if (value == null || value.isEmpty()) {
|
||||||
|
writer.printf("ERROR: '%s' property is empty%n", key);
|
||||||
|
return new String[]{};
|
||||||
|
}
|
||||||
|
return value.split(" ");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void gatherProcessInfo(HtmlSection section, long pid) {
|
||||||
|
String pidStr = "" + pid;
|
||||||
|
for (PatternAction action : processActions) {
|
||||||
|
if (action.isJavaOnly()) {
|
||||||
|
if (helper.isJava(pid, section.getWriter())) {
|
||||||
|
helper.runPatternAction(action, section, pidStr);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
helper.runPatternAction(action, section, pidStr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void gatherEnvironmentInfo(HtmlSection section) {
|
||||||
|
for (SimpleAction action : environmentActions) {
|
||||||
|
helper.runPatternAction(action, section);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,79 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.action;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.value.InvalidValueException;
|
||||||
|
import jdk.test.failurehandler.HtmlSection;
|
||||||
|
import jdk.test.failurehandler.value.Value;
|
||||||
|
import jdk.test.failurehandler.value.ValueHandler;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public class PatternAction implements Action {
|
||||||
|
@Value(name = "pattern")
|
||||||
|
private String pattern = null;
|
||||||
|
|
||||||
|
private final SimpleAction action;
|
||||||
|
private final String[] originalArgs;
|
||||||
|
|
||||||
|
public PatternAction(String id, Properties properties)
|
||||||
|
throws InvalidValueException {
|
||||||
|
this(id, id, properties);
|
||||||
|
}
|
||||||
|
|
||||||
|
public PatternAction(String name, String id, Properties properties)
|
||||||
|
throws InvalidValueException {
|
||||||
|
action = new SimpleAction(("pattern." + name), id, properties);
|
||||||
|
ValueHandler.apply(this, properties, id);
|
||||||
|
originalArgs = action.args.clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProcessBuilder prepareProcess(HtmlSection section,
|
||||||
|
ActionHelper helper, String value) {
|
||||||
|
action.sections[0] = value;
|
||||||
|
section = getSection(section);
|
||||||
|
String[] args = action.args;
|
||||||
|
System.arraycopy(originalArgs, 0, args, 0, originalArgs.length);
|
||||||
|
|
||||||
|
for (int i = 0, n = args.length; i < n; ++i) {
|
||||||
|
args[i] = args[i].replace(pattern, value) ;
|
||||||
|
}
|
||||||
|
return action.prepareProcess(section.getWriter(), helper);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HtmlSection getSection(HtmlSection section) {
|
||||||
|
return action.getSection(section);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ActionParameters getParameters() {
|
||||||
|
return action.getParameters();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isJavaOnly() {
|
||||||
|
return action.isJavaOnly();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,86 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.action;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.HtmlSection;
|
||||||
|
import jdk.test.failurehandler.value.InvalidValueException;
|
||||||
|
import jdk.test.failurehandler.value.SubValues;
|
||||||
|
import jdk.test.failurehandler.value.Value;
|
||||||
|
import jdk.test.failurehandler.value.ValueHandler;
|
||||||
|
import jdk.test.failurehandler.value.DefaultValue;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public class SimpleAction implements Action {
|
||||||
|
/* package-private */ final String[] sections;
|
||||||
|
@Value(name = "javaOnly")
|
||||||
|
@DefaultValue(value = "false")
|
||||||
|
private boolean javaOnly = false;
|
||||||
|
|
||||||
|
@Value (name = "app")
|
||||||
|
private String app = null;
|
||||||
|
|
||||||
|
@Value (name = "args")
|
||||||
|
@DefaultValue (value = "")
|
||||||
|
/* package-private */ String[] args = new String[]{};
|
||||||
|
|
||||||
|
@SubValues(prefix = "params")
|
||||||
|
private final ActionParameters params;
|
||||||
|
|
||||||
|
public SimpleAction(String id, Properties properties)
|
||||||
|
throws InvalidValueException {
|
||||||
|
this(id, id, properties);
|
||||||
|
}
|
||||||
|
public SimpleAction(String name, String id, Properties properties)
|
||||||
|
throws InvalidValueException {
|
||||||
|
sections = name.split("\\.");
|
||||||
|
this.params = new ActionParameters();
|
||||||
|
ValueHandler.apply(this, properties, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProcessBuilder prepareProcess(PrintWriter log, ActionHelper helper) {
|
||||||
|
ProcessBuilder process = helper.prepareProcess(log, app, args);
|
||||||
|
if (process != null) {
|
||||||
|
process.redirectErrorStream(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
return process;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isJavaOnly() {
|
||||||
|
return javaOnly;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HtmlSection getSection(HtmlSection section) {
|
||||||
|
return section.createChildren(sections);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ActionParameters getParameters() {
|
||||||
|
return params;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,153 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.jtreg;
|
||||||
|
|
||||||
|
import com.sun.javatest.Harness;
|
||||||
|
import com.sun.javatest.Parameters;
|
||||||
|
import com.sun.javatest.TestResult;
|
||||||
|
import com.sun.javatest.regtest.RegressionParameters;
|
||||||
|
import com.sun.javatest.regtest.OS;
|
||||||
|
import jdk.test.failurehandler.*;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The jtreg test execution observer, which gathers info about
|
||||||
|
* system and dumps it to a file.
|
||||||
|
*/
|
||||||
|
public class GatherDiagnosticInfoObserver implements Harness.Observer {
|
||||||
|
public static final String LOG_FILENAME = "environment.log";
|
||||||
|
public static final String ENVIRONMENT_OUTPUT = "environment.html";
|
||||||
|
|
||||||
|
private String compileJdk;
|
||||||
|
private String testJdk;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The harness calls this method after each test.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void finishedTest(TestResult tr) {
|
||||||
|
if (!tr.getStatus().isError() && !tr.getStatus().isFailed()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
String jtrFile = tr.getFile().toString();
|
||||||
|
final Path workDir = Paths.get(
|
||||||
|
jtrFile.substring(0, jtrFile.lastIndexOf('.')));
|
||||||
|
workDir.toFile().mkdir();
|
||||||
|
|
||||||
|
String name = getClass().getName();
|
||||||
|
PrintWriter log;
|
||||||
|
boolean needClose = false;
|
||||||
|
try {
|
||||||
|
log = new PrintWriter(new FileWriter(
|
||||||
|
workDir.resolve(LOG_FILENAME).toFile(), true));
|
||||||
|
needClose = true;
|
||||||
|
} catch (IOException e) {
|
||||||
|
log = new PrintWriter(System.out);
|
||||||
|
log.printf("ERROR: %s cannot open log file %s", name,
|
||||||
|
LOG_FILENAME);
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
log.printf("%s ---%n", name);
|
||||||
|
GathererFactory gathererFactory = new GathererFactory(
|
||||||
|
OS.current().family, workDir, log,
|
||||||
|
Paths.get(testJdk), Paths.get(compileJdk));
|
||||||
|
gatherEnvInfo(workDir, name, log,
|
||||||
|
gathererFactory.getEnvironmentInfoGatherer());
|
||||||
|
} catch (Throwable e) {
|
||||||
|
log.printf("ERROR: exception in observer %s:", name);
|
||||||
|
e.printStackTrace(log);
|
||||||
|
} finally {
|
||||||
|
log.printf("--- %s%n", name);
|
||||||
|
if (needClose) {
|
||||||
|
log.close();
|
||||||
|
} else {
|
||||||
|
log.flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void gatherEnvInfo(Path workDir, String name, PrintWriter log,
|
||||||
|
EnvironmentInfoGatherer gatherer) {
|
||||||
|
File output = workDir.resolve(ENVIRONMENT_OUTPUT).toFile();
|
||||||
|
try (HtmlPage html = new HtmlPage(new PrintWriter(
|
||||||
|
new FileWriter(output, true)))) {
|
||||||
|
try (ElapsedTimePrinter timePrinter
|
||||||
|
= new ElapsedTimePrinter(new Stopwatch(), name, log)) {
|
||||||
|
gatherer.gatherEnvironmentInfo(html.getRootSection());
|
||||||
|
}
|
||||||
|
} catch (Throwable e) {
|
||||||
|
log.printf("ERROR: exception in observer on getting environment "
|
||||||
|
+ "information %s:", name);
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The harness calls this method one time per run, not per test.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void startingTestRun(Parameters params) {
|
||||||
|
// TODO find a better way to get JDKs
|
||||||
|
RegressionParameters rp = (RegressionParameters) params;
|
||||||
|
Map<?,?> map = new HashMap<>();
|
||||||
|
rp.save(map);
|
||||||
|
compileJdk = (String) map.get("regtest.compilejdk");
|
||||||
|
testJdk = (String) map.get("regtest.testjdk");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void startingTest(TestResult tr) {
|
||||||
|
// no-op
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void stoppingTestRun() {
|
||||||
|
// no-op
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void finishedTesting() {
|
||||||
|
// no-op
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void finishedTestRun(boolean allOK) {
|
||||||
|
// no-op
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void error(String msg) {
|
||||||
|
// no-op
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,144 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.jtreg;
|
||||||
|
|
||||||
|
import com.sun.javatest.regtest.OS;
|
||||||
|
import com.sun.javatest.regtest.TimeoutHandler;
|
||||||
|
import jdk.test.failurehandler.*;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A timeout handler for jtreg, which gathers information about the timed out
|
||||||
|
* process and its children.
|
||||||
|
*/
|
||||||
|
public class GatherProcessInfoTimeoutHandler extends TimeoutHandler {
|
||||||
|
static {
|
||||||
|
try {
|
||||||
|
System.loadLibrary("timeoutHandler");
|
||||||
|
} catch (UnsatisfiedLinkError ignore) {
|
||||||
|
// not all os need timeoutHandler native-library
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private static final String LOG_FILENAME = "processes.log";
|
||||||
|
private static final String OUTPUT_FILENAME = "processes.html";
|
||||||
|
|
||||||
|
public GatherProcessInfoTimeoutHandler(PrintWriter jtregLog, File outputDir,
|
||||||
|
File testJdk) {
|
||||||
|
super(jtregLog, outputDir, testJdk);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runs various actions for jtreg timeout handler.
|
||||||
|
*
|
||||||
|
* <p>Please see method code for the actions.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void runActions(Process process, long pid)
|
||||||
|
throws InterruptedException {
|
||||||
|
Path workDir = outputDir.toPath();
|
||||||
|
|
||||||
|
String name = getClass().getName();
|
||||||
|
PrintWriter actionsLog;
|
||||||
|
try {
|
||||||
|
// try to open a separate file for aciton log
|
||||||
|
actionsLog = new PrintWriter(new FileWriter(
|
||||||
|
workDir.resolve(LOG_FILENAME).toFile(), true));
|
||||||
|
} catch (IOException e) {
|
||||||
|
// use jtreg log as a fallback
|
||||||
|
actionsLog = log;
|
||||||
|
actionsLog.printf("ERROR: %s cannot open log file %s : %s", name,
|
||||||
|
LOG_FILENAME, e.getMessage());
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
actionsLog.printf("%s ---%n", name);
|
||||||
|
|
||||||
|
File output = workDir.resolve(OUTPUT_FILENAME).toFile();
|
||||||
|
try {
|
||||||
|
PrintWriter pw = new PrintWriter(new FileWriter(output, true));
|
||||||
|
runGatherer(name, workDir, actionsLog, pw, pid);
|
||||||
|
} catch (IOException e) {
|
||||||
|
actionsLog.printf("IOException: cannot open output file[%s] : %s",
|
||||||
|
output, e.getMessage());
|
||||||
|
e.printStackTrace(actionsLog);
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
actionsLog.printf("--- %s%n", name);
|
||||||
|
// don't close jtreg log
|
||||||
|
if (actionsLog != log) {
|
||||||
|
actionsLog.close();
|
||||||
|
} else {
|
||||||
|
log.flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected long getProcessId(Process process) {
|
||||||
|
long result = super.getProcessId(process);
|
||||||
|
if (result == 0L) {
|
||||||
|
/* jtreg didn't find pid, most probably we are on JDK < 9
|
||||||
|
there is no Process::getPid */
|
||||||
|
if ("windows".equals(OS.current().family)) {
|
||||||
|
try {
|
||||||
|
Field field = process.getClass().getDeclaredField("handle");
|
||||||
|
boolean old = field.isAccessible();
|
||||||
|
try {
|
||||||
|
field.setAccessible(true);
|
||||||
|
long handle = field.getLong(process);
|
||||||
|
result = getWin32Pid(handle);
|
||||||
|
} finally {
|
||||||
|
field.setAccessible(old);
|
||||||
|
}
|
||||||
|
} catch (ReflectiveOperationException e) {
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private native long getWin32Pid(long handle);
|
||||||
|
|
||||||
|
private void runGatherer(String name, Path workDir, PrintWriter log,
|
||||||
|
PrintWriter out, long pid) {
|
||||||
|
try (HtmlPage html = new HtmlPage(out)) {
|
||||||
|
ProcessInfoGatherer gatherer = new GathererFactory(
|
||||||
|
OS.current().family,
|
||||||
|
workDir, log, testJdk.toPath()).getProcessInfoGatherer();
|
||||||
|
try (ElapsedTimePrinter timePrinter
|
||||||
|
= new ElapsedTimePrinter(new Stopwatch(), name, log)) {
|
||||||
|
gatherer.gatherProcessInfo(html.getRootSection(), pid);
|
||||||
|
}
|
||||||
|
} catch (Throwable e) {
|
||||||
|
log.printf("ERROR: exception in timeout handler %s:", name);
|
||||||
|
e.printStackTrace(log);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import java.lang.reflect.Array;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
public class ArrayParser implements ValueParser {
|
||||||
|
private final ValueParser parser;
|
||||||
|
|
||||||
|
public ArrayParser(ValueParser parser) {
|
||||||
|
Objects.requireNonNull(parser);
|
||||||
|
this.parser = parser;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String delimiter) {
|
||||||
|
Class<?> component = type.getComponentType();
|
||||||
|
if (component.isArray()) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"multidimensional array fields aren't supported");
|
||||||
|
}
|
||||||
|
String[] values = (value == null || value.isEmpty())
|
||||||
|
? new String[]{}
|
||||||
|
: value.split(delimiter);
|
||||||
|
Object result = Array.newInstance(component, values.length);
|
||||||
|
for (int i = 0, n = values.length; i < n; ++i) {
|
||||||
|
Array.set(result, i, parser.parse(component, values[i], delimiter));
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,120 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class DefaultParser implements ValueParser {
|
||||||
|
private static final Map<Class<?>, BasicParser> PARSERS = new HashMap<>();
|
||||||
|
|
||||||
|
static {
|
||||||
|
BasicParser.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
if (type.isArray()) {
|
||||||
|
return new ArrayParser(this).parse(type, value, s);
|
||||||
|
}
|
||||||
|
ValueParser parser = PARSERS.get(type);
|
||||||
|
if (parser == null) {
|
||||||
|
throw new IllegalArgumentException("can't find parser for "
|
||||||
|
+ type.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
return parser.parse(type, value, s);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static enum BasicParser implements ValueParser {
|
||||||
|
BOOL(boolean.class, Boolean.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Boolean.valueOf(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
BYTE(byte.class, Byte.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Byte.decode(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
CHAR(char.class, Character.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
if (value.length() != 1) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
String.format("can't cast %s to char", value));
|
||||||
|
}
|
||||||
|
return value.charAt(0);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
SHORT(short.class, Short.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Short.decode(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
INT(int.class, Integer.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Integer.decode(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
LONG(long.class, Long.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Long.decode(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
FLOAT(float.class, Float.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Float.parseFloat(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
DOUBLE(double.class, Double.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return Double.parseDouble(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
STRING(String.class, Object.class) {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String s) {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private BasicParser(Class<?>... classes) {
|
||||||
|
for (Class<?> aClass : classes) {
|
||||||
|
DefaultParser.PARSERS.put(aClass, this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void init() {
|
||||||
|
// no-op used to provoke <cinit>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
@Retention(value = RetentionPolicy.RUNTIME)
|
||||||
|
@Target(value = ElementType.FIELD)
|
||||||
|
public @interface DefaultValue {
|
||||||
|
String value();
|
||||||
|
}
|
@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
public class InvalidValueException extends Exception {
|
||||||
|
public InvalidValueException() { }
|
||||||
|
|
||||||
|
public InvalidValueException(String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
public InvalidValueException(String s, Throwable e) {
|
||||||
|
super(s, e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public InvalidValueException(Throwable cause) {
|
||||||
|
super(cause);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
public class PathValueParser implements ValueParser {
|
||||||
|
@Override
|
||||||
|
public Object parse(Class<?> type, String value, String delimiter) {
|
||||||
|
if (type.isArray()) {
|
||||||
|
return new ArrayParser(this).parse(type, value, delimiter);
|
||||||
|
}
|
||||||
|
return new File(value).toPath();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
@Retention(value = RetentionPolicy.RUNTIME)
|
||||||
|
@Target(value = ElementType.FIELD)
|
||||||
|
public @interface SubValues {
|
||||||
|
String prefix();
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
@Retention(value = RetentionPolicy.RUNTIME)
|
||||||
|
@Target(value = ElementType.FIELD)
|
||||||
|
public @interface Value {
|
||||||
|
String name();
|
||||||
|
Class<? extends ValueParser> parser() default DefaultParser.class;
|
||||||
|
}
|
@ -0,0 +1,122 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import jdk.test.failurehandler.Utils;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
import java.lang.reflect.Modifier;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public final class ValueHandler {
|
||||||
|
public static <T> void apply(T object, Properties properties,
|
||||||
|
String prefix) throws InvalidValueException {
|
||||||
|
Objects.requireNonNull(object, "object cannot be null");
|
||||||
|
Objects.requireNonNull(properties, "properties cannot be null");
|
||||||
|
Class<?> aClass = object.getClass();
|
||||||
|
while (aClass != null) {
|
||||||
|
for (Field field : aClass.getDeclaredFields()) {
|
||||||
|
Value p = field.getAnnotation(Value.class);
|
||||||
|
if (p != null) {
|
||||||
|
applyToField(p, object, field, properties, prefix);
|
||||||
|
} else {
|
||||||
|
SubValues sub
|
||||||
|
= field.getAnnotation(SubValues.class);
|
||||||
|
if (sub != null) {
|
||||||
|
getAccess(field);
|
||||||
|
try {
|
||||||
|
apply(field.get(object), properties,
|
||||||
|
Utils.prependPrefix(prefix, sub.prefix()));
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
throw new InvalidValueException(String.format(
|
||||||
|
"can't apply sub properties to %s.",
|
||||||
|
field.getName()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
aClass = aClass.getSuperclass();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void applyToField(Value property, Object object,
|
||||||
|
Field field, Properties properties, String prefix)
|
||||||
|
throws InvalidValueException {
|
||||||
|
getAccess(field);
|
||||||
|
if (Modifier.isFinal(field.getModifiers())) {
|
||||||
|
throw new InvalidValueException(
|
||||||
|
String.format("field '%s' is final", field));
|
||||||
|
}
|
||||||
|
String name = Utils.prependPrefix(prefix, property.name());
|
||||||
|
String value = getProperty(properties, prefix, property.name());
|
||||||
|
if (value == null) {
|
||||||
|
DefaultValue defaultValue
|
||||||
|
= field.getAnnotation(DefaultValue.class);
|
||||||
|
value = defaultValue == null ? null : defaultValue.value();
|
||||||
|
}
|
||||||
|
if (value == null) {
|
||||||
|
throw new InvalidValueException(String.format(
|
||||||
|
"can't set '%s', because properties don't have '%s'.",
|
||||||
|
field.getName(), name));
|
||||||
|
}
|
||||||
|
String delimiter = getProperty(properties,
|
||||||
|
Utils.prependPrefix(prefix, property.name()), "delimiter");
|
||||||
|
delimiter = delimiter == null ? " " : delimiter;
|
||||||
|
Class<? extends ValueParser> parserClass = property.parser();
|
||||||
|
try {
|
||||||
|
field.set(object, parserClass.newInstance().parse(
|
||||||
|
field.getType(), value, delimiter));
|
||||||
|
} catch (ReflectiveOperationException | IllegalArgumentException e) {
|
||||||
|
throw new InvalidValueException(
|
||||||
|
String.format("can't set field '%s' : %s",
|
||||||
|
field.getName(), e.getMessage()), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String getProperty(Properties properties,
|
||||||
|
String prefix, String name) {
|
||||||
|
if (prefix == null || prefix.isEmpty()) {
|
||||||
|
return properties.getProperty(name);
|
||||||
|
}
|
||||||
|
int index = prefix.length();
|
||||||
|
do {
|
||||||
|
String value = properties.getProperty(
|
||||||
|
Utils.prependPrefix(prefix.substring(0, index), name));
|
||||||
|
if (value != null) {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
index = prefix.lastIndexOf('.', index - 1);
|
||||||
|
} while (index > 0);
|
||||||
|
return properties.getProperty(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void getAccess(Field field) {
|
||||||
|
int modifiers = field.getModifiers();
|
||||||
|
if (!Modifier.isPublic(modifiers)) {
|
||||||
|
field.setAccessible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
public interface ValueParser {
|
||||||
|
Object parse(Class<?> type, String value, String delimiter);
|
||||||
|
}
|
74
test/failure_handler/src/share/conf/common.properties
Normal file
74
test/failure_handler/src/share/conf/common.properties
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
pattern=%p
|
||||||
|
javaOnly=true
|
||||||
|
args=%p
|
||||||
|
################################################################################
|
||||||
|
# process info to gather
|
||||||
|
################################################################################
|
||||||
|
onTimeout=\
|
||||||
|
jinfo \
|
||||||
|
jcmd.compiler.codecache jcmd.compiler.codelist \
|
||||||
|
jcmd.compiler.queue \
|
||||||
|
jcmd.vm.classloader_stats jcmd.vm.stringtable \
|
||||||
|
jcmd.vm.symboltable jcmd.vm.uptime jcmd.vm.dynlibs \
|
||||||
|
jcmd.vm.system_properties \
|
||||||
|
jcmd.gc.class_stats jcmd.gc.class_histogram \
|
||||||
|
jstack \
|
||||||
|
jmap.heap jmap.histo jmap.clstats jmap.finalizerinfo
|
||||||
|
|
||||||
|
jinfo.app=jinfo
|
||||||
|
|
||||||
|
jcmd.app=jcmd
|
||||||
|
|
||||||
|
jcmd.compiler.codecache.args=%p Compiler.codecache
|
||||||
|
jcmd.compiler.codelist.args=%p Compiler.codelist
|
||||||
|
jcmd.compiler.queue.args=%p Compiler.queue
|
||||||
|
|
||||||
|
jcmd.vm.classloader_stats.args=%p VM.classloader_stats
|
||||||
|
jcmd.vm.stringtable.args=%p VM.stringtable
|
||||||
|
jcmd.vm.symboltable.args=%p VM.symboltable
|
||||||
|
jcmd.vm.uptime.args=%p VM.uptime
|
||||||
|
jcmd.vm.dynlibs.args=%p VM.dynlibs
|
||||||
|
jcmd.vm.system_properties.args=%p VM.system_properties
|
||||||
|
|
||||||
|
jcmd.gc.class_stats.args=%p GC.class_stats
|
||||||
|
jcmd.gc.class_histogram.args=%p GC.class_histogram
|
||||||
|
|
||||||
|
jstack.app=jstack
|
||||||
|
jstack.params.repeat=6
|
||||||
|
|
||||||
|
jmap.app=jmap
|
||||||
|
jmap.heap.args=-heap %p
|
||||||
|
jmap.histo.args=-histo %p
|
||||||
|
jmap.clstats.args=-clstats %p
|
||||||
|
jmap.finalizerinfo.args=-finalizerinfo %p
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
# environment info to gather
|
||||||
|
################################################################################
|
||||||
|
environment=jps
|
||||||
|
jps.app=jps
|
||||||
|
jps.args=-mlv
|
||||||
|
################################################################################
|
110
test/failure_handler/src/share/conf/linux.properties
Normal file
110
test/failure_handler/src/share/conf/linux.properties
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
config.execSuffix=
|
||||||
|
config.getChildren.pattern=%p
|
||||||
|
config.getChildren.app=ps
|
||||||
|
config.getChildren.args=--no-headers -o pid --ppid %p
|
||||||
|
################################################################################
|
||||||
|
# process info to gather
|
||||||
|
################################################################################
|
||||||
|
onTimeout=\
|
||||||
|
native.pmap.normal native.pmap.everything \
|
||||||
|
native.files native.locks \
|
||||||
|
native.stack native.core
|
||||||
|
################################################################################
|
||||||
|
native.pattern=%p
|
||||||
|
native.javaOnly=false
|
||||||
|
native.args=%p
|
||||||
|
|
||||||
|
native.pmap.app=pmap
|
||||||
|
native.pmap.normal.args=-p %p
|
||||||
|
native.pmap.everything.args=-XXp %p
|
||||||
|
|
||||||
|
native.files.app=lsof
|
||||||
|
native.files.args=-p %p
|
||||||
|
|
||||||
|
native.locks.app=lslocks
|
||||||
|
native.locks.args=-u --pid %p
|
||||||
|
|
||||||
|
native.stack.app=gdb
|
||||||
|
native.stack.args=--pid=%p\0-batch\0-ex\0thread apply all backtrace
|
||||||
|
native.stack.args.delimiter=\0
|
||||||
|
native.stack.params.repeat=6
|
||||||
|
|
||||||
|
native.core.app=gcore
|
||||||
|
native.core.args=-o ./core.%p %p
|
||||||
|
native.core.params.timeout=3600000
|
||||||
|
################################################################################
|
||||||
|
# environment info to gather
|
||||||
|
################################################################################
|
||||||
|
environment=\
|
||||||
|
users.current users.logged users.last \
|
||||||
|
disk \
|
||||||
|
env \
|
||||||
|
system.dmesg system.sysctl \
|
||||||
|
process.top process.ps \
|
||||||
|
memory.free memory.vmstat.default memory.vmstat.statistics \
|
||||||
|
memory.vmstat.slabinfo memory.vmstat.disk \
|
||||||
|
files \
|
||||||
|
locks \
|
||||||
|
net.sockets net.statistics
|
||||||
|
################################################################################
|
||||||
|
users.current.app=id
|
||||||
|
users.current.args=-a
|
||||||
|
users.logged.app=who
|
||||||
|
users.logged.args=-a
|
||||||
|
users.last.app=last
|
||||||
|
users.last.args=-10
|
||||||
|
|
||||||
|
disk.app=df
|
||||||
|
disk.args=-h
|
||||||
|
|
||||||
|
env.app=env
|
||||||
|
|
||||||
|
system.dmesg.app=dmesg
|
||||||
|
system.sysctl.app=sysctl
|
||||||
|
system.sysctl.args=-a
|
||||||
|
|
||||||
|
process.top.app=top
|
||||||
|
process.top.args=-b -n 1
|
||||||
|
process.ps.app=ps
|
||||||
|
process.ps.args=-Leo pid,pcpu,cputime,start,pmem,vsz,rssize,stackp,stat,sgi_p,wchan,user,args
|
||||||
|
|
||||||
|
memory.free.app=free
|
||||||
|
memory.free.args=-h
|
||||||
|
memory.vmstat.app=vmstat
|
||||||
|
memory.vmstat.default.args=3 3
|
||||||
|
memory.vmstat.statistics.args=-s
|
||||||
|
memory.vmstat.slabinfo.args=-m
|
||||||
|
memory.vmstat.disk.args=-d
|
||||||
|
|
||||||
|
files.app=lsof
|
||||||
|
locks.app=lslocks
|
||||||
|
locks.args=-u
|
||||||
|
|
||||||
|
net.app=netstat
|
||||||
|
net.sockets.args=-aeeopv
|
||||||
|
net.statistics.args=-sv
|
||||||
|
################################################################################
|
||||||
|
|
98
test/failure_handler/src/share/conf/mac.properties
Normal file
98
test/failure_handler/src/share/conf/mac.properties
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
config.execSuffix=
|
||||||
|
config.getChildren.pattern=%p
|
||||||
|
config.getChildren.app=pgrep
|
||||||
|
config.getChildren.args=-P %p
|
||||||
|
################################################################################
|
||||||
|
# process info to gather
|
||||||
|
################################################################################
|
||||||
|
onTimeout=\
|
||||||
|
native.vmmap native.heap native.leaks native.spindump \
|
||||||
|
native.stack native.core
|
||||||
|
################################################################################
|
||||||
|
native.pattern=%p
|
||||||
|
native.javaOnly=false
|
||||||
|
native.args=%p
|
||||||
|
|
||||||
|
# Some of them require root privileges
|
||||||
|
native.vmmap.app=vmmap
|
||||||
|
native.heap.app=heap
|
||||||
|
native.leaks.app=leaks
|
||||||
|
native.spindump.app=spindump
|
||||||
|
native.spindump.args=%p -stdout
|
||||||
|
|
||||||
|
native.stack.app=lldb
|
||||||
|
native.stack.delimiter=\0
|
||||||
|
native.stack.params.repeat=6
|
||||||
|
native.stack.args=-o\0attach %p\0-o\0thread backtrace all\0-o\0detach\0-o\0quit
|
||||||
|
|
||||||
|
native.core.app=bash
|
||||||
|
native.core.delimiter=\0
|
||||||
|
native.core.args=-c\0gcore -o ./core.%p %p || \
|
||||||
|
lldb -o 'attach %p' -o 'process save-core core.%p' -o 'detach' -o 'quit'
|
||||||
|
native.core.params.timeout=3600000
|
||||||
|
################################################################################
|
||||||
|
# environment info to gather
|
||||||
|
################################################################################
|
||||||
|
environment=\
|
||||||
|
users.current users.logged users.last \
|
||||||
|
disk \
|
||||||
|
env \
|
||||||
|
system.dmesg system.sysctl \
|
||||||
|
process.ps process.top \
|
||||||
|
memory.vmstat \
|
||||||
|
netstat.av netstat.aL netstat.m netstat.s
|
||||||
|
################################################################################
|
||||||
|
users.current.app=id
|
||||||
|
users.current.args=-a
|
||||||
|
users.logged.app=who
|
||||||
|
users.logged.args=-a
|
||||||
|
users.last.app=last
|
||||||
|
users.last.args=-10
|
||||||
|
|
||||||
|
disk.app=df
|
||||||
|
disk.args=-h
|
||||||
|
|
||||||
|
env.app=env
|
||||||
|
|
||||||
|
system.dmesg.app=dmesg
|
||||||
|
system.sysctl.app=sysctl
|
||||||
|
system.sysctl.args=-a
|
||||||
|
|
||||||
|
process.ps.app=ps
|
||||||
|
process.ps.args=-Meo pid,pcpu,cputime,start,pmem,vsz,rss,state,wchan,user,args
|
||||||
|
process.top.app=top
|
||||||
|
process.top.args=-l 1
|
||||||
|
|
||||||
|
memory.vmstat.app=vm_stat
|
||||||
|
memory.vmstat.args=-c 3 3
|
||||||
|
|
||||||
|
|
||||||
|
netstat.app=netstat
|
||||||
|
netstat.av.args=-av
|
||||||
|
netstat.aL.args=-aL
|
||||||
|
netstat.m.args=-m
|
||||||
|
netstat.s.args=-s
|
||||||
|
################################################################################
|
111
test/failure_handler/src/share/conf/solaris.properties
Normal file
111
test/failure_handler/src/share/conf/solaris.properties
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
config.execSuffix=
|
||||||
|
# pattern will be replaced with the PID
|
||||||
|
config.getChildren.pattern=%p
|
||||||
|
config.getChildren.app=pgrep
|
||||||
|
config.getChildren.args=-P %p
|
||||||
|
################################################################################
|
||||||
|
# prepareProcess info to gather
|
||||||
|
################################################################################
|
||||||
|
onTimeout=\
|
||||||
|
native.pmap \
|
||||||
|
native.pfiles \
|
||||||
|
native.stack native.core
|
||||||
|
################################################################################
|
||||||
|
# solaris specific
|
||||||
|
################################################################################
|
||||||
|
native.pattern=%p
|
||||||
|
native.javaOnly=false
|
||||||
|
|
||||||
|
native.pmap.app=pmap
|
||||||
|
native.pmap.args=-F %p
|
||||||
|
|
||||||
|
native.pfiles.app=pfiles
|
||||||
|
native.pfiles.args=-F %p
|
||||||
|
|
||||||
|
# native.locks TODO find 'analog for solaris' for Linux lslocks
|
||||||
|
|
||||||
|
native.stack.app=pstack
|
||||||
|
native.stack.args=-F %p
|
||||||
|
native.stack.params.repeat=6
|
||||||
|
|
||||||
|
native.core.app=gcore
|
||||||
|
native.core.args=-F -o ./core %p
|
||||||
|
native.core.params.timeout=3600000
|
||||||
|
################################################################################
|
||||||
|
# environment info to gather
|
||||||
|
################################################################################
|
||||||
|
environment=\
|
||||||
|
users.current users.logged users.last \
|
||||||
|
disk \
|
||||||
|
env \
|
||||||
|
system.dmesg system.prtconf system.sysdef \
|
||||||
|
process.ps process.top \
|
||||||
|
memory.swap memory.vmstat.default memory.vmstat.statistics memory.pagesize \
|
||||||
|
netstat.av netstat.m netstat.s netstat.i
|
||||||
|
################################################################################
|
||||||
|
# common unix
|
||||||
|
################################################################################
|
||||||
|
users.current.app=id
|
||||||
|
users.current.args=-a
|
||||||
|
users.logged.app=who
|
||||||
|
users.logged.args=-a
|
||||||
|
users.last.app=last
|
||||||
|
users.last.args=-10
|
||||||
|
|
||||||
|
disk.app=df
|
||||||
|
disk.args=-h
|
||||||
|
|
||||||
|
env.app=env
|
||||||
|
|
||||||
|
system.dmesg.app=dmesg
|
||||||
|
system.prtconf.app=prtconf
|
||||||
|
system.sysdef.app=sysdef
|
||||||
|
|
||||||
|
memory.swap.app=swap
|
||||||
|
memory.swap.args=-l
|
||||||
|
|
||||||
|
process.ps.app=ps
|
||||||
|
process.ps.args=-Leo pid,lwp,ppid,tty,s,wchan,pcpu,time,stime,pmem,vsz,osz,rss,args
|
||||||
|
|
||||||
|
process.top.app=top
|
||||||
|
process.top.args=-b -n
|
||||||
|
|
||||||
|
memory.vmstat.app=vmstat
|
||||||
|
memory.vmstat.default.args=3 3
|
||||||
|
memory.vmstat.statistics.args=-s
|
||||||
|
|
||||||
|
memory.pagesize.app=pagesize
|
||||||
|
|
||||||
|
# TODO: how to start prstat to show statistics and exit?
|
||||||
|
# prstat.app=prstat
|
||||||
|
# prstat.args=-a
|
||||||
|
|
||||||
|
netstat.app=netstat
|
||||||
|
netstat.av.args=-av
|
||||||
|
netstat.m.args=-m
|
||||||
|
netstat.s.args=-s
|
||||||
|
netstat.i.args=-i 1 5
|
||||||
|
################################################################################
|
115
test/failure_handler/src/share/conf/windows.properties
Normal file
115
test/failure_handler/src/share/conf/windows.properties
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
config.execSuffix=.exe
|
||||||
|
config.getChildren.app=bash
|
||||||
|
config.getChildren.pattern=%p
|
||||||
|
config.getChildren.args=-c\0wmic process where ParentProcessId=%p get ProcessId | tail -n+2
|
||||||
|
config.getChildren.args.delimiter=\0
|
||||||
|
################################################################################
|
||||||
|
# process info to gather
|
||||||
|
################################################################################
|
||||||
|
onTimeout=\
|
||||||
|
native.info \
|
||||||
|
native.pmap.normal native.pmap.everything \
|
||||||
|
native.files native.locks \
|
||||||
|
native.stack native.core
|
||||||
|
################################################################################
|
||||||
|
native.pattern=%p
|
||||||
|
native.javaOnly=false
|
||||||
|
native.args=%p
|
||||||
|
|
||||||
|
native.info.app=wmic
|
||||||
|
native.info.args=process where processId=%p list full
|
||||||
|
|
||||||
|
native.pmap.app=pmap
|
||||||
|
native.pmap.normal.args=%p
|
||||||
|
native.pmap.everything.args=-x %p
|
||||||
|
|
||||||
|
native.files.app=handle
|
||||||
|
native.files.args=-p %p
|
||||||
|
# TODO
|
||||||
|
native.locks.app=lslocks
|
||||||
|
native.locks.args=-u --pid %p
|
||||||
|
|
||||||
|
native.stack.app=cdb
|
||||||
|
native.stack.args=-c "~*kP n;qd" -p %p
|
||||||
|
native.stack.params.repeat=6
|
||||||
|
|
||||||
|
native.core.app=cdb
|
||||||
|
native.core.args=-c ".dump /f core.%p;qd" -p %p
|
||||||
|
native.core.params.timeout=3600000
|
||||||
|
################################################################################
|
||||||
|
# environment info to gather
|
||||||
|
################################################################################
|
||||||
|
environment=\
|
||||||
|
users.current users.logged \
|
||||||
|
disk \
|
||||||
|
env \
|
||||||
|
system.events.system system.events.application system.os \
|
||||||
|
process.top process.ps process.tasklist \
|
||||||
|
memory.free memory.vmstat.default memory.vmstat.statistics \
|
||||||
|
memory.vmstat.slabinfo memory.vmstat.disk \
|
||||||
|
files \
|
||||||
|
net.sockets net.statistics
|
||||||
|
################################################################################
|
||||||
|
users.current.app=id
|
||||||
|
users.current.args=-a
|
||||||
|
users.logged.app=query
|
||||||
|
users.logged.args=user
|
||||||
|
|
||||||
|
disk.app=df
|
||||||
|
disk.args=-h
|
||||||
|
|
||||||
|
env.app=env
|
||||||
|
|
||||||
|
system.events.app=powershell
|
||||||
|
system.events.delimiter=\0
|
||||||
|
system.events.system.args=-NoLogo\0-Command\0Get-EventLog System -After (Get-Date).AddDays(-1) | Format-List
|
||||||
|
system.events.application.args=-NoLogo\0-Command\0Get-EventLog Application -After (Get-Date).AddDays(-1) | Format-List
|
||||||
|
|
||||||
|
system.os.app=wmic
|
||||||
|
system.os.args=os get /format:list
|
||||||
|
|
||||||
|
process.top.app=top
|
||||||
|
process.top.args=-b -n 1
|
||||||
|
process.ps.app=ps
|
||||||
|
process.ps.args=-efW
|
||||||
|
process.tasklist.app=tasklist
|
||||||
|
process.tasklist.args=/V
|
||||||
|
|
||||||
|
memory.free.app=free
|
||||||
|
memory.vmstat.app=vmstat
|
||||||
|
memory.vmstat.statistics.args=-s
|
||||||
|
memory.vmstat.slabinfo.args=-m
|
||||||
|
memory.vmstat.disk.args=-d
|
||||||
|
|
||||||
|
files.app=openfiles
|
||||||
|
files.args=/query
|
||||||
|
|
||||||
|
net.sockets.app=bash
|
||||||
|
net.sockets.args=-c\0netstat -b -a -t -o || netstat -a -t -o
|
||||||
|
net.sockets.args.delimiter=\0
|
||||||
|
net.statistics.app=netstat
|
||||||
|
net.statistics.args=-s -e
|
||||||
|
################################################################################
|
@ -0,0 +1,37 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <jni.h>
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
JNIEXPORT jlong JNICALL Java_jdk_test_failurehandler_jtreg_GatherProcessInfoTimeoutHandler_getWin32Pid
|
||||||
|
(JNIEnv* env, jobject o, jlong handle) {
|
||||||
|
return GetProcessId(handle);
|
||||||
|
}
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
0
test/failure_handler/test/TEST.ROOT
Normal file
0
test/failure_handler/test/TEST.ROOT
Normal file
39
test/failure_handler/test/sanity/Crash.java
Normal file
39
test/failure_handler/test/sanity/Crash.java
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import sun.misc.Unsafe;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @run main/othervm Crash
|
||||||
|
*/
|
||||||
|
public class Crash {
|
||||||
|
public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {
|
||||||
|
Field f = Unsafe.class.getDeclaredField("theUnsafe");
|
||||||
|
f.setAccessible(true);
|
||||||
|
Unsafe u = (Unsafe) f.get(null);
|
||||||
|
u.setMemory(0, 42, (byte) 0xFF);
|
||||||
|
}
|
||||||
|
}
|
63
test/failure_handler/test/sanity/Deadlock.java
Normal file
63
test/failure_handler/test/sanity/Deadlock.java
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Deadlocked client
|
||||||
|
*/
|
||||||
|
public class Deadlock {
|
||||||
|
public double e;
|
||||||
|
private volatile int i;
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
new Deadlock().test();
|
||||||
|
}
|
||||||
|
private void test() {
|
||||||
|
final Object a = new Object();
|
||||||
|
final Object b = new Object();
|
||||||
|
|
||||||
|
new Thread(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
synchronized (a) {
|
||||||
|
do {
|
||||||
|
i |= 1;
|
||||||
|
} while (i != 3);
|
||||||
|
|
||||||
|
synchronized (b) {
|
||||||
|
e = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}}).start();
|
||||||
|
|
||||||
|
synchronized (b) {
|
||||||
|
do {
|
||||||
|
i |= 2;
|
||||||
|
} while (i != 3);
|
||||||
|
synchronized (a) {
|
||||||
|
e = 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
55
test/failure_handler/test/sanity/Livelock.java
Normal file
55
test/failure_handler/test/sanity/Livelock.java
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Busy infinite loop client, calculating E number
|
||||||
|
*/
|
||||||
|
public class Livelock {
|
||||||
|
|
||||||
|
public static double elim;
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
System.out.printf(
|
||||||
|
"%24s %24s %24s %24s %24s %24s%n",
|
||||||
|
"n", "n!", "e = lim(...)", "e = taylor series",
|
||||||
|
"err e-lim", "err e-taylor");
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
double esum = 2;
|
||||||
|
double nfac = 1;
|
||||||
|
double iter = 1;
|
||||||
|
for (double n = 1; !Double.isInfinite(n) && !Double.isNaN(n) ; n = n * 2) {
|
||||||
|
elim = Math.pow(1 + 1 / n, n);
|
||||||
|
|
||||||
|
iter += 1;
|
||||||
|
nfac *= iter;
|
||||||
|
esum += 1 / nfac;
|
||||||
|
|
||||||
|
System.out.printf("% 24.16e % 24.16e % 24.16e % 24.16e"
|
||||||
|
+ "%- 24.16e %- 24.16e%n",
|
||||||
|
n, nfac, elim, esum, (Math.E - elim), (Math.E - esum));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
49
test/failure_handler/test/sanity/OOME.java
Normal file
49
test/failure_handler/test/sanity/OOME.java
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
import java.util.LinkedList;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Slowly eat all memory in an infinite loop
|
||||||
|
* @run main/othervm Crash
|
||||||
|
*/
|
||||||
|
public class OOME {
|
||||||
|
@SuppressWarnings ("UnusedDeclaration")
|
||||||
|
private static Object garbage;
|
||||||
|
public static void main(String args[]) {
|
||||||
|
|
||||||
|
int chunkSize = 0x8000;
|
||||||
|
LinkedList<int[]> list = new LinkedList<>();
|
||||||
|
garbage = list;
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
try {
|
||||||
|
list.add(new int[chunkSize]);
|
||||||
|
} catch (OutOfMemoryError e) {
|
||||||
|
chunkSize >>= 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
55
test/failure_handler/test/sanity/Suicide.java
Normal file
55
test/failure_handler/test/sanity/Suicide.java
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
import java.lang.management.ManagementFactory;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Suicide test
|
||||||
|
* @run main/othervm Crash
|
||||||
|
*/
|
||||||
|
public class Suicide {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
String cmd = null;
|
||||||
|
try {
|
||||||
|
String pidStr = ManagementFactory.getRuntimeMXBean().getName()
|
||||||
|
.split("@")[0];
|
||||||
|
String osName = System.getProperty("os.name");
|
||||||
|
if (osName.contains("Windows")) {
|
||||||
|
cmd = "taskkill.exe /F /PID " + pidStr;
|
||||||
|
} else {
|
||||||
|
cmd = "kill -9 " + pidStr;
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.printf("executing `%s'%n", cmd);
|
||||||
|
Runtime.getRuntime().exec(cmd);
|
||||||
|
Thread.sleep(2000);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
System.err.printf("TEST/ENV BUG: %s didn't kill JVM%n", cmd);
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
}
|
32
test/failure_handler/test/sanity/SystemExit.java
Normal file
32
test/failure_handler/test/sanity/SystemExit.java
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @run main/othervm SystemExit
|
||||||
|
*/
|
||||||
|
public class SystemExit {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
System.exit(1);
|
||||||
|
}
|
||||||
|
}
|
31
test/failure_handler/test/sanity/ThrowError.java
Normal file
31
test/failure_handler/test/sanity/ThrowError.java
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public class ThrowError {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
throw new Error("TEST FAIL");
|
||||||
|
}
|
||||||
|
}
|
44
test/failure_handler/test/sanity/WaitForDeadlock.java
Normal file
44
test/failure_handler/test/sanity/WaitForDeadlock.java
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @build Deadlock
|
||||||
|
* @run driver WaitForDeadlock
|
||||||
|
*/
|
||||||
|
public class WaitForDeadlock {
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
System.out.println("START");
|
||||||
|
ProcessBuilder pb = new ProcessBuilder(Paths.get(
|
||||||
|
System.getProperty("test.jdk"), "bin", "java").toString(),
|
||||||
|
"-cp", System.getProperty("java.class.path"),
|
||||||
|
Deadlock.class.getName());
|
||||||
|
pb.redirectError(ProcessBuilder.Redirect.to(Paths.get("out").toFile()));
|
||||||
|
pb.redirectOutput(ProcessBuilder.Redirect.to(Paths.get("err").toFile()));
|
||||||
|
int r = pb.start().waitFor();
|
||||||
|
System.out.println("END. " + r);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,118 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class DefaultParserTest {
|
||||||
|
@Test
|
||||||
|
public void testParseStringArray() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
String line = "a aa aaa";
|
||||||
|
String[] result = {"a", "aa", "", "", "aaa"};
|
||||||
|
Assert.assertArrayEquals(result,
|
||||||
|
(Object[]) parser.parse(result.getClass(), line, " "));
|
||||||
|
|
||||||
|
line = null;
|
||||||
|
result = new String[]{};
|
||||||
|
Assert.assertArrayEquals(result,
|
||||||
|
(Object[]) parser.parse(result.getClass(), line, " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testParseObjectArray() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
String line = "a aa aaa";
|
||||||
|
String[] result = {"a", "aa", "", "", "aaa"};
|
||||||
|
Assert.assertArrayEquals(result,
|
||||||
|
(String[]) parser.parse(result.getClass(), line, " "));
|
||||||
|
Object[] result2 = {"a", "aa", "", "", "aaa"};
|
||||||
|
Assert.assertArrayEquals(result2,
|
||||||
|
(Object[]) parser.parse(result.getClass(), line, " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testParseCharArray() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
String line = "a b c a";
|
||||||
|
char[] result = {'a', 'b', 'c', 'a'};
|
||||||
|
Assert.assertArrayEquals(result,
|
||||||
|
(char[]) parser.parse(result.getClass(), line, " "));
|
||||||
|
|
||||||
|
Character[] result2 = {'a', 'b', 'c', 'a'};
|
||||||
|
Assert.assertArrayEquals(result2,
|
||||||
|
(Character[]) parser.parse(result2.getClass(), line, " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testParseBoolean() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
String line = "a b c a";
|
||||||
|
Assert.assertEquals(false,
|
||||||
|
(boolean) parser.parse(boolean.class, line, " "));
|
||||||
|
Assert.assertEquals(Boolean.FALSE,
|
||||||
|
parser.parse(Boolean.class, line, " "));
|
||||||
|
line = "trUe";
|
||||||
|
Assert.assertEquals(true,
|
||||||
|
(boolean) parser.parse(boolean.class, line, " "));
|
||||||
|
Assert.assertEquals(Boolean.TRUE,
|
||||||
|
parser.parse(Boolean.class, line, " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testParseShort() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
Assert.assertSame("10", (short) 10,
|
||||||
|
parser.parse(short.class, "10", " "));
|
||||||
|
Assert.assertSame("010", (short) 8,
|
||||||
|
parser.parse(short.class, "010", " "));
|
||||||
|
Assert.assertSame("0x10", (short) 16,
|
||||||
|
parser.parse(short.class, "0x10", " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testParseByte() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
Assert.assertSame("11", (byte) 11,
|
||||||
|
parser.parse(byte.class, "11", " "));
|
||||||
|
Assert.assertSame("011", (byte) 9,
|
||||||
|
parser.parse(byte.class, "011", " "));
|
||||||
|
Assert.assertSame("0x11", (byte) 17,
|
||||||
|
parser.parse(byte.class, "0x11", " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testParseInt() throws Exception {
|
||||||
|
DefaultParser parser = new DefaultParser();
|
||||||
|
Assert.assertEquals("20", (int) 20,
|
||||||
|
parser.parse(int.class, "20", " "));
|
||||||
|
Assert.assertEquals("020", (int) 16,
|
||||||
|
parser.parse(int.class, "020", " "));
|
||||||
|
Assert.assertEquals("0x20", (int) 32,
|
||||||
|
parser.parse(int.class, "0x20", " "));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,110 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package jdk.test.failurehandler.value;
|
||||||
|
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
public class ValueHandlerTest {
|
||||||
|
@Test
|
||||||
|
public void testApplyAnonymousPrivateFinalInt() throws Exception {
|
||||||
|
Properties p = new Properties();
|
||||||
|
p.put("int", "010");
|
||||||
|
Object o = new Object() {
|
||||||
|
@Value (name = "int")
|
||||||
|
private final int i1 = -1;
|
||||||
|
};
|
||||||
|
Field f = o.getClass().getDeclaredField("i1");
|
||||||
|
f.setAccessible(true);
|
||||||
|
int value = f.getInt(o);
|
||||||
|
Assert.assertEquals(value, -1);
|
||||||
|
f.setAccessible(false);
|
||||||
|
ValueHandler.apply(o, p, null);
|
||||||
|
f.setAccessible(true);
|
||||||
|
value = f.getInt(o);
|
||||||
|
Assert.assertEquals(value, 8);
|
||||||
|
f.setAccessible(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testApplyPublicStaticWithDefault() throws Exception {
|
||||||
|
Assert.assertEquals(StaticDefaultCase.s, null);
|
||||||
|
Properties p = new Properties();
|
||||||
|
StaticDefaultCase o = new StaticDefaultCase();
|
||||||
|
ValueHandler.apply(o, p, "prefix");
|
||||||
|
Assert.assertEquals(StaticDefaultCase.s, "default");
|
||||||
|
p.put("s", "new2");
|
||||||
|
ValueHandler.apply(o, p, "prefix");
|
||||||
|
Assert.assertEquals(StaticDefaultCase.s, "new2");
|
||||||
|
p.put("prefix.s", "new");
|
||||||
|
ValueHandler.apply(o, p, "prefix");
|
||||||
|
Assert.assertEquals(StaticDefaultCase.s, "new");
|
||||||
|
ValueHandler.apply(o, p, null);
|
||||||
|
Assert.assertEquals(StaticDefaultCase.s, "new2");
|
||||||
|
}
|
||||||
|
|
||||||
|
protected class InnerClass1 {
|
||||||
|
@Value (name = "innerClass")
|
||||||
|
String[] arr = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public class InnerClass2 extends InnerClass1 {
|
||||||
|
@Value (name = "float")
|
||||||
|
float f = 0.0f;
|
||||||
|
|
||||||
|
@SubValues (prefix = "inner")
|
||||||
|
InnerClass1 inner1 = new InnerClass1();
|
||||||
|
|
||||||
|
@SubValues (prefix = "")
|
||||||
|
InnerClass1 inner2 = new InnerClass1();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testApplySub() throws Exception {
|
||||||
|
InnerClass2 o = new InnerClass2();
|
||||||
|
Assert.assertArrayEquals(o.arr, null);
|
||||||
|
Assert.assertArrayEquals(o.inner1.arr, null);
|
||||||
|
Assert.assertArrayEquals(o.inner2.arr, null);
|
||||||
|
Assert.assertEquals(o.f, 0.0f, Float.MIN_VALUE);
|
||||||
|
|
||||||
|
Properties p = new Properties();
|
||||||
|
p.put("float", "1.f");
|
||||||
|
p.put("innerClass", "a b");
|
||||||
|
p.put("inner.innerClass", "a b c");
|
||||||
|
ValueHandler.apply(o, p, "");
|
||||||
|
Assert.assertArrayEquals(o.arr, new String[]{"a", "b"});
|
||||||
|
Assert.assertArrayEquals(o.inner1.arr, new String[]{"a", "b", "c"});
|
||||||
|
Assert.assertArrayEquals(o.inner2.arr, new String[]{"a", "b"});
|
||||||
|
Assert.assertEquals(o.f, 1.0f, Float.MIN_VALUE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class StaticDefaultCase {
|
||||||
|
@Value (name = "s")
|
||||||
|
@DefaultValue (value = "default")
|
||||||
|
public static String s;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user