mirror of
https://github.com/openjdk/jdk8u.git
synced 2025-12-11 05:44:42 -06:00
8152432: Implement setting jtreg @requires properties vm.flavor, vm.bits, vm.compMode
Reviewed-by: phh, sgehwolf Backport-of: 24a9e0ac188a37dc57cc4d1bb8d8635abb4c4f89
This commit is contained in:
parent
ae6405fe64
commit
de0e5a2dcb
@ -30,4 +30,10 @@
|
|||||||
keys=cte_test jcmd nmt regression gc stress
|
keys=cte_test jcmd nmt regression gc stress
|
||||||
|
|
||||||
groups=TEST.groups [closed/TEST.groups]
|
groups=TEST.groups [closed/TEST.groups]
|
||||||
requires.properties=sun.arch.data.model
|
|
||||||
|
# Source files for classes that will be used at the beginning of each test suite run,
|
||||||
|
# to determine additional characteristics of the system for use with the @requires tag.
|
||||||
|
requires.extraPropDefns = ../../test/jtreg-ext/requires/VMProps.java
|
||||||
|
requires.properties=sun.arch.data.model \
|
||||||
|
vm.flavor \
|
||||||
|
vm.bits
|
||||||
|
|||||||
@ -23,10 +23,10 @@
|
|||||||
|
|
||||||
import com.oracle.java.testlibrary.ProcessTools;
|
import com.oracle.java.testlibrary.ProcessTools;
|
||||||
import com.oracle.java.testlibrary.OutputAnalyzer;
|
import com.oracle.java.testlibrary.OutputAnalyzer;
|
||||||
import com.oracle.java.testlibrary.Platform;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @test MaxMetaspaceSizeTest
|
* @test MaxMetaspaceSizeTest
|
||||||
|
* @requires vm.bits == "64"
|
||||||
* @bug 8087291
|
* @bug 8087291
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @run main/othervm MaxMetaspaceSizeTest
|
* @run main/othervm MaxMetaspaceSizeTest
|
||||||
@ -34,10 +34,6 @@ import com.oracle.java.testlibrary.Platform;
|
|||||||
|
|
||||||
public class MaxMetaspaceSizeTest {
|
public class MaxMetaspaceSizeTest {
|
||||||
public static void main(String... args) throws Exception {
|
public static void main(String... args) throws Exception {
|
||||||
if (!Platform.is64bit()) {
|
|
||||||
System.out.println("Test requires 64-bit JVM. Skipping...");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||||
"-Xmx1g",
|
"-Xmx1g",
|
||||||
"-XX:InitialBootClassLoaderMetaspaceSize=4195328",
|
"-XX:InitialBootClassLoaderMetaspaceSize=4195328",
|
||||||
|
|||||||
@ -25,6 +25,7 @@
|
|||||||
* @test
|
* @test
|
||||||
* @key nmt jcmd
|
* @key nmt jcmd
|
||||||
* @library /testlibrary /testlibrary/whitebox
|
* @library /testlibrary /testlibrary/whitebox
|
||||||
|
* @requires vm.bits == 64
|
||||||
* @build HugeArenaTracking
|
* @build HugeArenaTracking
|
||||||
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
||||||
* @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:NativeMemoryTracking=detail HugeArenaTracking
|
* @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:NativeMemoryTracking=detail HugeArenaTracking
|
||||||
@ -38,10 +39,6 @@ public class HugeArenaTracking {
|
|||||||
private static final long GB = 1024 * 1024 * 1024;
|
private static final long GB = 1024 * 1024 * 1024;
|
||||||
|
|
||||||
public static void main(String args[]) throws Exception {
|
public static void main(String args[]) throws Exception {
|
||||||
if (!Platform.is64bit()) {
|
|
||||||
System.out.println("Test requires 64-bit JVM. Skipping...");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
OutputAnalyzer output;
|
OutputAnalyzer output;
|
||||||
final WhiteBox wb = WhiteBox.getWhiteBox();
|
final WhiteBox wb = WhiteBox.getWhiteBox();
|
||||||
|
|
||||||
|
|||||||
@ -24,8 +24,9 @@
|
|||||||
/*
|
/*
|
||||||
* @test DefaultUseWithClient
|
* @test DefaultUseWithClient
|
||||||
* @summary Test default behavior of sharing with -client
|
* @summary Test default behavior of sharing with -client
|
||||||
|
* @requires os.family == "windows" & vm.bits == "32" & vm.flavor == "client"
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @run main/othervm -client DefaultUseWithClient
|
* @run main/othervm DefaultUseWithClient
|
||||||
* @bug 8032224
|
* @bug 8032224
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -37,12 +38,6 @@ public class DefaultUseWithClient {
|
|||||||
String fileName = "test.jsa";
|
String fileName = "test.jsa";
|
||||||
|
|
||||||
// On 32-bit windows CDS should be on by default in "-client" config
|
// On 32-bit windows CDS should be on by default in "-client" config
|
||||||
// Skip this test on any other platform
|
|
||||||
boolean is32BitWindowsClient = (Platform.isWindows() && Platform.is32bit() && Platform.isClient());
|
|
||||||
if (!is32BitWindowsClient) {
|
|
||||||
System.out.println("Test only applicable on 32-bit Windows Client VM. Skipping");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// create the archive
|
// create the archive
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||||
|
|||||||
136
test/jtreg-ext/requires/VMProps.java
Normal file
136
test/jtreg-ext/requires/VMProps.java
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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 requires;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.Callable;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Class to be invoked by jtreg prior Test Suite execution to
|
||||||
|
* collect information about VM.
|
||||||
|
* Properties set by this Class will be available in the @requires expressions.
|
||||||
|
*/
|
||||||
|
public class VMProps implements Callable<Map<String, String>> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Collects information about VM properties.
|
||||||
|
* This method will be invoked by jtreg.
|
||||||
|
*
|
||||||
|
* @return Map of property-value pairs.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Map<String, String> call() {
|
||||||
|
Map<String, String> map = new HashMap<>();
|
||||||
|
map.put("vm.flavor", vmFlavor());
|
||||||
|
map.put("vm.compMode", vmCompMode());
|
||||||
|
map.put("vm.bits", vmBits());
|
||||||
|
dump(map);
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return VM type value extracted from the "java.vm.name" property.
|
||||||
|
*/
|
||||||
|
protected String vmFlavor() {
|
||||||
|
// E.g. "Java HotSpot(TM) 64-Bit Server VM"
|
||||||
|
String vmName = System.getProperty("java.vm.name");
|
||||||
|
if (vmName == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Pattern startP = Pattern.compile(".* (\\S+) VM");
|
||||||
|
Matcher m = startP.matcher(vmName);
|
||||||
|
if (m.matches()) {
|
||||||
|
return m.group(1).toLowerCase();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return VM compilation mode extracted from the "java.vm.info" property.
|
||||||
|
*/
|
||||||
|
protected String vmCompMode() {
|
||||||
|
// E.g. "mixed mode"
|
||||||
|
String vmInfo = System.getProperty("java.vm.info");
|
||||||
|
if (vmInfo == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
int k = vmInfo.toLowerCase().indexOf(" mode");
|
||||||
|
if (k < 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
vmInfo = vmInfo.substring(0, k);
|
||||||
|
switch (vmInfo) {
|
||||||
|
case "mixed" : return "Xmixed";
|
||||||
|
case "compiled" : return "Xcomp";
|
||||||
|
case "interpreted" : return "Xint";
|
||||||
|
default: return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return VM bitness, the value of the "sun.arch.data.model" property.
|
||||||
|
*/
|
||||||
|
protected String vmBits() {
|
||||||
|
return System.getProperty("sun.arch.data.model");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dumps the map to the file if the file name is given as the property.
|
||||||
|
* This functionality could be helpful to know context in the real
|
||||||
|
* execution.
|
||||||
|
*
|
||||||
|
* @param map
|
||||||
|
*/
|
||||||
|
protected void dump(Map<String, String> map) {
|
||||||
|
String dumpFileName = System.getProperty("vmprops.dump");
|
||||||
|
if (dumpFileName == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
List<String> lines = new ArrayList<>();
|
||||||
|
map.forEach((k,v) -> lines.add(k + ":" + v));
|
||||||
|
try {
|
||||||
|
Files.write(Paths.get(dumpFileName), lines);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new RuntimeException("Failed to dump properties into '"
|
||||||
|
+ dumpFileName + "'", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method is for the testing purpose only.
|
||||||
|
* @param args
|
||||||
|
*/
|
||||||
|
public static void main(String args[]) {
|
||||||
|
Map<String, String> map = new VMProps().call();
|
||||||
|
map.forEach((k,v) -> System.out.println(k + ": '" + v + "'"));
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user