2014-04-11 00:35:28 +04:00
|
|
|
/*
|
2015-05-04 16:30:07 +02:00
|
|
|
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
2014-04-11 00:35:28 +04: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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-07-12 18:24:48 +03:00
|
|
|
package compiler.rtm.cli;
|
|
|
|
|
|
|
|
import jdk.test.lib.ExitCode;
|
|
|
|
import jdk.test.lib.Platform;
|
|
|
|
import jdk.test.lib.cli.CommandLineOptionTest;
|
2014-04-11 00:35:28 +04:00
|
|
|
|
|
|
|
import java.util.function.BooleanSupplier;
|
|
|
|
|
|
|
|
public abstract class TestPrintPreciseRTMLockingStatisticsBase
|
|
|
|
extends RTMGenericCommandLineOptionTest {
|
|
|
|
protected static final String DEFAULT_VALUE = "false";
|
|
|
|
|
|
|
|
protected TestPrintPreciseRTMLockingStatisticsBase(
|
|
|
|
BooleanSupplier predicate) {
|
|
|
|
super(predicate, "PrintPreciseRTMLockingStatistics", true, false,
|
|
|
|
TestPrintPreciseRTMLockingStatisticsBase.DEFAULT_VALUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void runNonX86TestCases() throws Throwable {
|
|
|
|
verifyJVMStartup();
|
|
|
|
verifyOptionValues();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void verifyJVMStartup() throws Throwable {
|
|
|
|
if (Platform.isServer()) {
|
|
|
|
if (!Platform.isDebugBuild()) {
|
2014-12-16 14:52:57 +03:00
|
|
|
String shouldFailMessage = String.format("VM option '%s' is "
|
|
|
|
+ "diagnostic%nJVM startup should fail without "
|
|
|
|
+ "-XX:\\+UnlockDiagnosticVMOptions flag", optionName);
|
|
|
|
String shouldPassMessage = String.format("VM option '%s' is "
|
|
|
|
+ "diagnostic%nJVM startup should pass with "
|
|
|
|
+ "-XX:\\+UnlockDiagnosticVMOptions in debug build",
|
|
|
|
optionName);
|
2014-04-11 00:35:28 +04:00
|
|
|
String errorMessage = CommandLineOptionTest.
|
|
|
|
getDiagnosticOptionErrorMessage(optionName);
|
|
|
|
// verify that option is actually diagnostic
|
|
|
|
CommandLineOptionTest.verifySameJVMStartup(
|
2014-12-16 14:52:57 +03:00
|
|
|
new String[] { errorMessage }, null, shouldFailMessage,
|
|
|
|
shouldFailMessage, ExitCode.FAIL,
|
2014-04-11 00:35:28 +04:00
|
|
|
prepareOptionValue("true"));
|
|
|
|
|
|
|
|
CommandLineOptionTest.verifySameJVMStartup(null,
|
2014-12-16 14:52:57 +03:00
|
|
|
new String[] { errorMessage }, shouldPassMessage,
|
|
|
|
shouldPassMessage + "without any warnings", ExitCode.OK,
|
2014-04-11 00:35:28 +04:00
|
|
|
CommandLineOptionTest.UNLOCK_DIAGNOSTIC_VM_OPTIONS,
|
|
|
|
prepareOptionValue("true"));
|
|
|
|
} else {
|
2014-12-16 14:52:57 +03:00
|
|
|
String shouldPassMessage = String.format("JVM startup should "
|
|
|
|
+ "pass with '%s' option in debug build",
|
|
|
|
optionName);
|
|
|
|
CommandLineOptionTest.verifySameJVMStartup(null, null,
|
|
|
|
shouldPassMessage, shouldPassMessage,
|
|
|
|
ExitCode.OK, prepareOptionValue("true"));
|
2014-04-11 00:35:28 +04:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
String errorMessage = CommandLineOptionTest.
|
|
|
|
getUnrecognizedOptionErrorMessage(optionName);
|
2014-12-16 14:52:57 +03:00
|
|
|
String shouldFailMessage = String.format("JVM startup should fail"
|
|
|
|
+ " with '%s' option in not debug build", optionName);
|
2014-04-11 00:35:28 +04:00
|
|
|
CommandLineOptionTest.verifySameJVMStartup(
|
2014-12-16 14:52:57 +03:00
|
|
|
new String[]{errorMessage}, null, shouldFailMessage,
|
|
|
|
shouldFailMessage, ExitCode.FAIL,
|
2014-04-11 00:35:28 +04:00
|
|
|
CommandLineOptionTest.UNLOCK_DIAGNOSTIC_VM_OPTIONS,
|
|
|
|
prepareOptionValue("true"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void verifyOptionValues() throws Throwable {
|
|
|
|
if (Platform.isServer()) {
|
|
|
|
// Verify default value
|
|
|
|
CommandLineOptionTest.verifyOptionValueForSameVM(optionName,
|
|
|
|
TestPrintPreciseRTMLockingStatisticsBase.DEFAULT_VALUE,
|
2014-12-16 14:52:57 +03:00
|
|
|
String.format("Option '%s' should have '%s' default value",
|
|
|
|
optionName,
|
|
|
|
TestPrintPreciseRTMLockingStatisticsBase.DEFAULT_VALUE),
|
2014-04-11 00:35:28 +04:00
|
|
|
CommandLineOptionTest.UNLOCK_DIAGNOSTIC_VM_OPTIONS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|