Path: blob/master/test/hotspot/jtreg/compiler/rtm/cli/TestUseRTMLockingOptionOnUnsupportedVM.java
41152 views
/*1* Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/**24* @test25* @bug 803132026* @summary Verify UseRTMLocking option processing on CPU with rtm support27* in case when VM should not support this option.28* @library /test/lib /29* @modules java.base/jdk.internal.misc30* java.management31* @requires vm.flagless32* @requires vm.rtm.cpu & !(vm.flavor == "server" & !vm.emulatedClient)33* @run driver compiler.rtm.cli.TestUseRTMLockingOptionOnUnsupportedVM34*/3536package compiler.rtm.cli;3738import jdk.test.lib.process.ExitCode;39import jdk.test.lib.cli.CommandLineOptionTest;4041public class TestUseRTMLockingOptionOnUnsupportedVM {42private static final String DEFAULT_VALUE = "false";4344public void runTestCases() throws Throwable {45String errorMessage46= RTMGenericCommandLineOptionTest.RTM_UNSUPPORTED_VM_ERROR;47String shouldFailMessage = "JVM startup should fail with option "48+ "-XX:+UseRTMLocking even on unsupported VM. Error message"49+ " should be shown";50String shouldPassMessage = "JVM startup should pass with option "51+ "-XX:-UseRTMLocking even on unsupported VM";52// verify that we can't use +UseRTMLocking53CommandLineOptionTest.verifySameJVMStartup(54new String[] { errorMessage }, null, shouldFailMessage,55shouldFailMessage, ExitCode.FAIL,56"-XX:+UseRTMLocking");57// verify that we can turn it off58CommandLineOptionTest.verifySameJVMStartup(null,59new String[] { errorMessage }, shouldPassMessage,60shouldPassMessage + " without any warnings", ExitCode.OK,61"-XX:-UseRTMLocking");62// verify that it is off by default63CommandLineOptionTest.verifyOptionValueForSameVM("UseRTMLocking",64TestUseRTMLockingOptionOnUnsupportedVM.DEFAULT_VALUE,65String.format("Default value of option 'UseRTMLocking' should"66+ " be '%s'", DEFAULT_VALUE));67}6869public static void main(String args[]) throws Throwable {70new TestUseRTMLockingOptionOnUnsupportedVM().runTestCases();71}72}737475