36d578cddb
Reviewed-by: mchung, rriggs
327 lines
13 KiB
Java
327 lines
13 KiB
Java
/*
|
|
* Copyright (c) 2010, 2023, 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.File;
|
|
import java.io.IOException;
|
|
|
|
/*
|
|
* @test
|
|
* @bug 6994753 7123582 8305950 8281658 8310201 8311653
|
|
* @summary tests -XshowSettings options
|
|
* @modules jdk.compiler
|
|
* jdk.zipfs
|
|
* @compile -XDignore.symbol.file Settings.java
|
|
* @run main Settings
|
|
* @author ksrini
|
|
*/
|
|
public class Settings extends TestHelper {
|
|
private static File testJar = null;
|
|
|
|
static void init() throws IOException {
|
|
if (testJar != null) {
|
|
return;
|
|
}
|
|
testJar = new File("test.jar");
|
|
StringBuilder tsrc = new StringBuilder();
|
|
tsrc.append("public static void main(String... args) {\n");
|
|
tsrc.append(" for (String x : args) {\n");
|
|
tsrc.append(" System.out.println(x);\n");
|
|
tsrc.append(" }\n");
|
|
tsrc.append("}\n");
|
|
createJar(testJar, tsrc.toString());
|
|
}
|
|
|
|
static void checkContains(TestResult tr, String str) {
|
|
if (!tr.contains(str)) {
|
|
System.out.println(tr);
|
|
throw new RuntimeException(str + " not found");
|
|
}
|
|
}
|
|
|
|
static void checkNotContains(TestResult tr, String str) {
|
|
if (!tr.notContains(str)) {
|
|
System.out.println(tr);
|
|
throw new RuntimeException(str + " found");
|
|
}
|
|
}
|
|
|
|
private static final String VM_SETTINGS = "VM settings:";
|
|
private static final String PROP_SETTINGS = "Property settings:";
|
|
private static final String LOCALE_SETTINGS = "Locale settings:";
|
|
private static final String LOCALE_SUMMARY_SETTINGS =
|
|
"Locale settings summary:";
|
|
private static final String AVAILABLE_LOCALES = "available locales";
|
|
private static final String SEC_PROPS_SETTINGS = "Security properties:";
|
|
private static final String SEC_SUMMARY_PROPS_SETTINGS =
|
|
"Security settings summary:";
|
|
private static final String SEC_PROVIDER_SETTINGS =
|
|
"Security provider static configuration:";
|
|
private static final String SEC_TLS_SETTINGS = "Security TLS configuration";
|
|
private static final String BAD_SEC_OPTION_MSG = "Valid \"security\" suboption values are";
|
|
private static final String SYSTEM_SETTINGS = "Operating System Metrics:";
|
|
private static final String METRICS_NOT_AVAILABLE_MSG = "No metrics available for this platform";
|
|
private static final String STACKSIZE_SETTINGS = "Stack Size:";
|
|
private static final String TZDATA_SETTINGS = "tzdata version";
|
|
private static final String ERR_MSG = "Unrecognized showSettings option:";
|
|
|
|
/*
|
|
* "all" should print verbose settings
|
|
*/
|
|
static void containsAllOptions(TestResult tr) {
|
|
checkContains(tr, VM_SETTINGS);
|
|
checkContains(tr, PROP_SETTINGS);
|
|
checkContains(tr, LOCALE_SETTINGS);
|
|
checkContains(tr, AVAILABLE_LOCALES);
|
|
checkNotContains(tr, LOCALE_SUMMARY_SETTINGS);
|
|
checkContains(tr, SEC_PROPS_SETTINGS);
|
|
checkNotContains(tr, SEC_SUMMARY_PROPS_SETTINGS);
|
|
checkContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkContains(tr, SEC_TLS_SETTINGS);
|
|
checkContains(tr, TZDATA_SETTINGS);
|
|
if (System.getProperty("os.name").contains("Linux")) {
|
|
checkContains(tr, SYSTEM_SETTINGS);
|
|
} else {
|
|
// only invoke system option by default on Linux
|
|
checkNotContains(tr, METRICS_NOT_AVAILABLE_MSG);
|
|
}
|
|
}
|
|
/*
|
|
* default (no options) should print non verbose
|
|
* details on each component
|
|
*/
|
|
static void containsDefaultOptions(TestResult tr) {
|
|
checkContains(tr, VM_SETTINGS);
|
|
checkContains(tr, PROP_SETTINGS);
|
|
checkNotContains(tr, LOCALE_SETTINGS);
|
|
checkNotContains(tr, AVAILABLE_LOCALES);
|
|
checkContains(tr, LOCALE_SUMMARY_SETTINGS);
|
|
// no verbose security settings unless "security" or "all" used
|
|
checkNotContains(tr, SEC_PROPS_SETTINGS);
|
|
checkContains(tr, SEC_SUMMARY_PROPS_SETTINGS);
|
|
checkContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkContains(tr, SEC_TLS_SETTINGS);
|
|
checkContains(tr, TZDATA_SETTINGS);
|
|
if (System.getProperty("os.name").contains("Linux")) {
|
|
checkContains(tr, SYSTEM_SETTINGS);
|
|
} else {
|
|
// only invoke system option by default on Linux
|
|
checkNotContains(tr, METRICS_NOT_AVAILABLE_MSG);
|
|
}
|
|
}
|
|
|
|
static void runTestOptionDefault() throws IOException {
|
|
int stackSize = 256; // in kb
|
|
if (getArch().equals("ppc64") || getArch().equals("ppc64le")) {
|
|
stackSize = 800;
|
|
} else if (getArch().equals("aarch64")) {
|
|
/*
|
|
* The max value of minimum stack size allowed for aarch64 can be estimated as
|
|
* such: suppose the vm page size is 64KB and the test runs with a debug build,
|
|
* the initial _java_thread_min_stack_allowed defined in os_linux_aarch64.cpp is
|
|
* 72K, stack guard zones could take 192KB, and the shadow zone needs 128KB,
|
|
* after aligning up all parts to the page size, the final size would be 448KB.
|
|
* See details in JDK-8163363
|
|
*/
|
|
stackSize = 448;
|
|
}
|
|
TestResult tr;
|
|
tr = doExec(javaCmd, "-Xms64m", "-Xmx512m",
|
|
"-Xss" + stackSize + "k", "-XshowSettings", "-jar", testJar.getAbsolutePath());
|
|
// Check the stack size logs printed by -XshowSettings to verify -Xss meaningfully.
|
|
checkContains(tr, STACKSIZE_SETTINGS);
|
|
containsDefaultOptions(tr);
|
|
if (!tr.isOK()) {
|
|
System.out.println(tr);
|
|
throw new RuntimeException("test fails");
|
|
}
|
|
tr = doExec(javaCmd, "-Xms65536k", "-Xmx712m",
|
|
"-Xss" + (stackSize * 1024), "-XshowSettings", "-jar", testJar.getAbsolutePath());
|
|
checkContains(tr, STACKSIZE_SETTINGS);
|
|
containsDefaultOptions(tr);
|
|
if (!tr.isOK()) {
|
|
System.out.println(tr);
|
|
throw new RuntimeException("test fails");
|
|
}
|
|
}
|
|
|
|
static void runTestOptionAll() throws IOException {
|
|
init();
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:all");
|
|
containsAllOptions(tr);
|
|
}
|
|
|
|
static void runTestOptionVM() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:vm");
|
|
checkContains(tr, VM_SETTINGS);
|
|
checkNotContains(tr, PROP_SETTINGS);
|
|
checkNotContains(tr, LOCALE_SETTINGS);
|
|
}
|
|
|
|
static void runTestOptionProperty() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:properties");
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkContains(tr, PROP_SETTINGS);
|
|
checkNotContains(tr, LOCALE_SETTINGS);
|
|
}
|
|
|
|
static void runTestOptionLocale() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:locale");
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkNotContains(tr, PROP_SETTINGS);
|
|
checkContains(tr, LOCALE_SETTINGS);
|
|
checkContains(tr, AVAILABLE_LOCALES);
|
|
checkNotContains(tr, LOCALE_SUMMARY_SETTINGS);
|
|
checkContains(tr, TZDATA_SETTINGS);
|
|
}
|
|
|
|
static void runTestOptionSecurity() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:security");
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkNotContains(tr, PROP_SETTINGS);
|
|
checkContains(tr, SEC_PROPS_SETTINGS);
|
|
checkContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkContains(tr, SEC_TLS_SETTINGS);
|
|
}
|
|
|
|
static void runTestOptionSecurityProps() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:security:properties");
|
|
checkContains(tr, SEC_PROPS_SETTINGS);
|
|
checkNotContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkNotContains(tr, SEC_TLS_SETTINGS);
|
|
// test a well known property for sanity
|
|
checkContains(tr, "keystore.type=pkcs12");
|
|
}
|
|
|
|
static void runTestOptionSecurityProv() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:security:providers");
|
|
checkNotContains(tr, SEC_PROPS_SETTINGS);
|
|
checkContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkNotContains(tr, SEC_TLS_SETTINGS);
|
|
// test a well known Provider for sanity
|
|
checkContains(tr, "Provider name: SUN");
|
|
// test for a well known alias (SunJCE: AlgorithmParameterGenerator.DiffieHellman)
|
|
checkContains(tr, "aliases: [1.2.840.113549.1.3.1, " +
|
|
"DH, OID.1.2.840.113549.1.3.1]");
|
|
}
|
|
|
|
static void runTestOptionSecurityTLS() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:security:tls");
|
|
checkNotContains(tr, SEC_PROPS_SETTINGS);
|
|
checkNotContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkContains(tr, SEC_TLS_SETTINGS);
|
|
// test a well known TLS config for sanity
|
|
checkContains(tr, "TLSv1.2");
|
|
}
|
|
|
|
// ensure error message is printed when unrecognized option used
|
|
static void runTestOptionBadSecurityOption() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:security:bad");
|
|
tr.checkNegative();
|
|
checkContains(tr, BAD_SEC_OPTION_MSG);
|
|
// we print all security settings in such scenario
|
|
checkNotContains(tr, SEC_PROPS_SETTINGS);
|
|
checkNotContains(tr, SEC_PROVIDER_SETTINGS);
|
|
checkNotContains(tr, SEC_TLS_SETTINGS);
|
|
}
|
|
static void runTestOptionSystem() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings:system");
|
|
if (System.getProperty("os.name").contains("Linux")) {
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkNotContains(tr, PROP_SETTINGS);
|
|
checkNotContains(tr, LOCALE_SETTINGS);
|
|
checkContains(tr, SYSTEM_SETTINGS);
|
|
} else {
|
|
// "system" should print a "No metrics available"
|
|
// message on other OSes
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkContains(tr, METRICS_NOT_AVAILABLE_MSG);
|
|
}
|
|
}
|
|
|
|
static void runTestBadOptions() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettingsBadOption");
|
|
tr.checkNegative();
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkNotContains(tr, PROP_SETTINGS);
|
|
checkNotContains(tr, LOCALE_SETTINGS);
|
|
checkContains(tr, "Unrecognized option: -XshowSettingsBadOption");
|
|
|
|
// no such component option
|
|
tr = doExec(javaCmd, "-XshowSettings:BadOption");
|
|
tr.checkNegative();
|
|
checkNotContains(tr, VM_SETTINGS);
|
|
checkNotContains(tr, PROP_SETTINGS);
|
|
checkNotContains(tr, LOCALE_SETTINGS);
|
|
checkContains(tr, ERR_MSG);
|
|
|
|
// don't allow invalid sub options
|
|
tr = doExec(javaCmd, "-XshowSettings:locale:bad");
|
|
tr.checkNegative();
|
|
checkContains(tr, ERR_MSG);
|
|
|
|
// don't allow ":" as an option
|
|
tr = doExec(javaCmd, "-XshowSettings:");
|
|
tr.checkNegative();
|
|
checkContains(tr, ERR_MSG);
|
|
|
|
// case-sensitive test
|
|
tr = doExec(javaCmd, "-XshowSettings:VM");
|
|
tr.checkNegative();
|
|
checkContains(tr, ERR_MSG);
|
|
|
|
// exclude this enum value
|
|
tr = doExec(javaCmd, "-XshowSettings:empty");
|
|
tr.checkNegative();
|
|
checkContains(tr, ERR_MSG);
|
|
|
|
|
|
}
|
|
|
|
static void runTest7123582() throws IOException {
|
|
TestResult tr = doExec(javaCmd, "-XshowSettings", "-version");
|
|
if (!tr.isOK()) {
|
|
System.out.println(tr);
|
|
throw new RuntimeException("test fails");
|
|
}
|
|
containsDefaultOptions(tr);
|
|
}
|
|
|
|
public static void main(String... args) throws IOException {
|
|
runTestOptionAll();
|
|
runTestOptionDefault();
|
|
runTestOptionVM();
|
|
runTestOptionProperty();
|
|
runTestOptionLocale();
|
|
runTestOptionSecurity();
|
|
runTestOptionSecurityProps();
|
|
runTestOptionSecurityProv();
|
|
runTestOptionSecurityTLS();
|
|
runTestOptionBadSecurityOption();
|
|
runTestOptionSystem();
|
|
runTestBadOptions();
|
|
runTest7123582();
|
|
if (testExitValue != 0) {
|
|
throw new Error(testExitValue + " tests failed");
|
|
}
|
|
}
|
|
}
|