2017-04-19 16:33:37 -07:00
|
|
|
/*
|
2023-07-07 19:14:17 +00:00
|
|
|
* Copyright (c) 2017, 2023, Oracle and/or its affiliates. All rights reserved.
|
2017-04-19 16:33:37 -07:00
|
|
|
* 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 applications.jcstress;
|
|
|
|
|
|
|
|
import jdk.test.lib.Utils;
|
|
|
|
import jdk.test.lib.artifacts.Artifact;
|
|
|
|
import jdk.test.lib.artifacts.ArtifactResolver;
|
2018-03-09 19:20:19 +01:00
|
|
|
import jdk.test.lib.artifacts.ArtifactResolverException;
|
2017-04-19 16:33:37 -07:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
|
|
|
import jdk.test.lib.process.ProcessTools;
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
import java.nio.file.Files;
|
|
|
|
import java.nio.file.Path;
|
|
|
|
import java.nio.file.Paths;
|
|
|
|
import java.util.ArrayList;
|
2017-05-11 16:35:02 -07:00
|
|
|
import java.util.Map;
|
2017-04-19 16:33:37 -07:00
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* jcstress tests wrapper
|
|
|
|
*/
|
|
|
|
@Artifact(organization = "org.openjdk.jcstress", name = "jcstress-tests-all",
|
2023-07-07 19:14:17 +00:00
|
|
|
revision = "0.16", extension = "jar", unpack = false)
|
2017-04-19 16:33:37 -07:00
|
|
|
public class JcstressRunner {
|
|
|
|
|
|
|
|
public static final String MAIN_CLASS = "org.openjdk.jcstress.Main";
|
|
|
|
|
2023-07-07 19:14:17 +00:00
|
|
|
// Allow to configure jcstress mode parameter.
|
|
|
|
// Test mode preset: sanity, quick, default, tough, stress.
|
|
|
|
public static final String MODE_PROPERTY = "jcstress.mode";
|
|
|
|
|
2017-04-19 16:33:37 -07:00
|
|
|
public static Path pathToArtifact() {
|
2017-05-11 16:35:02 -07:00
|
|
|
Map<String, Path> artifacts;
|
2017-04-19 16:33:37 -07:00
|
|
|
try {
|
|
|
|
artifacts = ArtifactResolver.resolve(JcstressRunner.class);
|
2018-03-09 19:20:19 +01:00
|
|
|
} catch (ArtifactResolverException e) {
|
2017-04-19 16:33:37 -07:00
|
|
|
throw new Error("TESTBUG: Can not resolve artifacts for "
|
|
|
|
+ JcstressRunner.class.getName(), e);
|
|
|
|
}
|
2023-07-07 19:14:17 +00:00
|
|
|
return artifacts.get("org.openjdk.jcstress.jcstress-tests-all-0.16")
|
2017-04-19 16:33:37 -07:00
|
|
|
.toAbsolutePath();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Throwable {
|
|
|
|
if (args.length < 1) {
|
|
|
|
throw new Error("Usage: [jcstress flag]*");
|
|
|
|
}
|
|
|
|
Path out = Paths.get("jcstress.out").toAbsolutePath();
|
|
|
|
|
2023-10-27 08:47:26 +00:00
|
|
|
ProcessBuilder pb = ProcessTools.createLimitedTestJavaProcessBuilder(getCmd(args))
|
2017-04-19 16:33:37 -07:00
|
|
|
.redirectErrorStream(true)
|
|
|
|
.redirectOutput(out.toFile());
|
|
|
|
OutputAnalyzer oa = ProcessTools.executeProcess(pb);
|
|
|
|
if (0 != oa.getExitValue()) {
|
|
|
|
String message = "jctress test finished with nonzero exitcode "
|
|
|
|
+ oa.getExitValue();
|
|
|
|
System.err.println(message);
|
|
|
|
|
|
|
|
System.err.print("cmd = ");
|
|
|
|
System.err.println(pb.command());
|
|
|
|
|
|
|
|
System.err.print("cout/cerr(");
|
|
|
|
System.err.print(out.toString());
|
|
|
|
System.err.println(")[");
|
|
|
|
Files.lines(out).forEach(System.err::println);
|
|
|
|
System.err.println("]cout/cerr");
|
|
|
|
throw new Error(message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static String[] getCmd(String[] args) {
|
|
|
|
List<String> extraFlags = new ArrayList<>();
|
|
|
|
|
2018-12-13 14:16:21 -08:00
|
|
|
// java.io.tmpdir is set for both harness and forked VM so temporary files
|
|
|
|
// created like this File.createTempFile("jcstress", "stdout");
|
|
|
|
// don't pollute temporary directories
|
|
|
|
extraFlags.add("-Djava.io.tmpdir=" + System.getProperty("user.dir"));
|
|
|
|
|
2017-04-19 16:33:37 -07:00
|
|
|
// add jar with jcstress tests and harness to CP
|
|
|
|
extraFlags.add("-cp");
|
|
|
|
extraFlags.add(System.getProperty("java.class.path")
|
|
|
|
+ File.pathSeparator
|
|
|
|
+ pathToArtifact().toString());
|
|
|
|
|
|
|
|
extraFlags.add(MAIN_CLASS);
|
|
|
|
|
2018-12-13 14:16:21 -08:00
|
|
|
extraFlags.add("--jvmArgs");
|
|
|
|
extraFlags.add("-Djava.io.tmpdir=" + System.getProperty("user.dir"));
|
2023-07-07 19:14:17 +00:00
|
|
|
|
|
|
|
// The "default" preset might take days for some tests
|
|
|
|
// so use quick testing by default.
|
|
|
|
String mode = "quick";
|
2018-12-13 14:16:21 -08:00
|
|
|
for (String jvmArg : Utils.getTestJavaOpts()) {
|
2023-07-07 19:14:17 +00:00
|
|
|
if(jvmArg.startsWith("-D" + MODE_PROPERTY)) {
|
|
|
|
String[] pair = jvmArg.split("=", 2);
|
|
|
|
mode = pair[1];
|
|
|
|
continue;
|
|
|
|
}
|
2017-04-19 16:33:37 -07:00
|
|
|
extraFlags.add("--jvmArgs");
|
2018-12-13 14:16:21 -08:00
|
|
|
extraFlags.add(jvmArg);
|
2017-04-19 16:33:37 -07:00
|
|
|
}
|
|
|
|
|
2023-07-07 19:14:17 +00:00
|
|
|
extraFlags.add("-m");
|
|
|
|
extraFlags.add(mode);
|
|
|
|
|
|
|
|
extraFlags.add("-sc");
|
|
|
|
extraFlags.add("false");
|
|
|
|
|
|
|
|
extraFlags.add("-af");
|
|
|
|
extraFlags.add("GLOBAL");
|
|
|
|
|
2017-04-19 16:33:37 -07:00
|
|
|
String[] result = new String[extraFlags.size() + args.length];
|
|
|
|
extraFlags.toArray(result);
|
|
|
|
System.arraycopy(args, 0, result, extraFlags.size(), args.length);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|