2015-11-24 17:52:15 +00:00
|
|
|
/*
|
2016-08-19 14:06:30 +00:00
|
|
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
2015-11-24 17:52:15 +00: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 compiler.compilercontrol.jcmd;
|
|
|
|
|
|
|
|
import compiler.compilercontrol.parser.HugeDirectiveUtil;
|
|
|
|
import compiler.compilercontrol.share.AbstractTestBase;
|
|
|
|
import compiler.compilercontrol.share.method.MethodDescriptor;
|
2016-07-12 15:24:48 +00:00
|
|
|
import compiler.compilercontrol.share.pool.PoolHelper;
|
2015-11-24 17:52:15 +00:00
|
|
|
import compiler.compilercontrol.share.scenario.Executor;
|
2016-08-19 14:06:30 +00:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
2017-05-22 22:27:20 +00:00
|
|
|
import jdk.test.lib.TimeLimitedRunner;
|
2015-11-24 17:52:15 +00:00
|
|
|
import jdk.test.lib.Utils;
|
|
|
|
|
2016-03-01 17:17:27 +00:00
|
|
|
import java.util.ArrayList;
|
2015-11-24 17:52:15 +00:00
|
|
|
import java.util.List;
|
2016-03-01 17:17:27 +00:00
|
|
|
import java.util.Random;
|
|
|
|
import java.util.concurrent.TimeUnit;
|
2015-11-24 17:52:15 +00:00
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
public abstract class StressAddJcmdBase {
|
|
|
|
private static final int DIRECTIVES_AMOUNT = Integer.getInteger(
|
|
|
|
"compiler.compilercontrol.jcmd.StressAddJcmdBase.directivesAmount",
|
2016-03-01 17:17:27 +00:00
|
|
|
200);
|
|
|
|
private static final int TIMEOUT = Integer.getInteger(
|
|
|
|
"compiler.compilercontrol.jcmd.StressAddJcmdBase.timeout",
|
|
|
|
30);
|
2015-11-24 17:52:15 +00:00
|
|
|
private static final List<MethodDescriptor> DESCRIPTORS = new PoolHelper()
|
|
|
|
.getAllMethods().stream()
|
|
|
|
.map(pair -> AbstractTestBase
|
|
|
|
.getValidMethodDescriptor(pair.first))
|
|
|
|
.collect(Collectors.toList());
|
2016-03-01 17:17:27 +00:00
|
|
|
private static final String DIRECTIVE_FILE = "directives.json";
|
|
|
|
private static final List<String> VM_OPTIONS = new ArrayList<>();
|
|
|
|
private static final Random RANDOM = Utils.getRandomInstance();
|
|
|
|
|
|
|
|
static {
|
|
|
|
VM_OPTIONS.add("-Xmixed");
|
|
|
|
VM_OPTIONS.add("-XX:+UnlockDiagnosticVMOptions");
|
|
|
|
VM_OPTIONS.add("-XX:+LogCompilation");
|
|
|
|
VM_OPTIONS.add("-XX:CompilerDirectivesLimit=1001");
|
|
|
|
}
|
2015-11-24 17:52:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Performs test
|
|
|
|
*/
|
|
|
|
public void test() {
|
2016-03-01 17:17:27 +00:00
|
|
|
HugeDirectiveUtil.createHugeFile(DESCRIPTORS, DIRECTIVE_FILE,
|
|
|
|
DIRECTIVES_AMOUNT);
|
|
|
|
Executor executor = new TimeLimitedExecutor();
|
2015-11-24 17:55:46 +00:00
|
|
|
List<OutputAnalyzer> outputAnalyzers = executor.execute();
|
|
|
|
outputAnalyzers.get(0).shouldHaveExitValue(0);
|
2015-11-24 17:52:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-03-01 17:17:27 +00:00
|
|
|
* Makes connection to the test VM and performs a diagnostic command
|
2015-11-24 17:52:15 +00:00
|
|
|
*
|
2016-03-01 17:17:27 +00:00
|
|
|
* @param pid a pid of the VM under test
|
2015-11-24 17:52:15 +00:00
|
|
|
* @return true if the test should continue invocation of this method
|
|
|
|
*/
|
2016-03-01 17:17:27 +00:00
|
|
|
protected abstract boolean makeConnection(int pid);
|
2015-11-24 17:52:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Finish test executions
|
|
|
|
*/
|
|
|
|
protected void finish() { }
|
|
|
|
|
2016-03-01 17:17:27 +00:00
|
|
|
protected String nextCommand() {
|
|
|
|
int i = RANDOM.nextInt(JcmdCommand.values().length);
|
|
|
|
JcmdCommand jcmdCommand = JcmdCommand.values()[i];
|
|
|
|
switch (jcmdCommand) {
|
|
|
|
case ADD:
|
|
|
|
return jcmdCommand.command + " " + DIRECTIVE_FILE;
|
|
|
|
case PRINT:
|
|
|
|
case CLEAR:
|
|
|
|
case REMOVE:
|
|
|
|
return jcmdCommand.command;
|
|
|
|
default:
|
|
|
|
throw new Error("TESTBUG: incorrect command: " + jcmdCommand);
|
2015-11-24 17:52:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-03-01 17:17:27 +00:00
|
|
|
private enum JcmdCommand {
|
|
|
|
ADD("Compiler.directives_add"),
|
|
|
|
PRINT("Compiler.directives_print"),
|
|
|
|
CLEAR("Compiler.directives_clear"),
|
|
|
|
REMOVE("Compiler.directives_remove");
|
|
|
|
|
|
|
|
public final String command;
|
2015-11-24 17:52:15 +00:00
|
|
|
|
2016-03-01 17:17:27 +00:00
|
|
|
JcmdCommand(String command) {
|
|
|
|
this.command = command;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private class TimeLimitedExecutor extends Executor {
|
|
|
|
public TimeLimitedExecutor() {
|
2015-11-24 17:52:15 +00:00
|
|
|
/* There are no need to check the state */
|
2023-06-21 07:05:41 +00:00
|
|
|
super(VM_OPTIONS, null, null);
|
2015-11-24 17:52:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2015-11-24 17:55:46 +00:00
|
|
|
protected OutputAnalyzer[] executeJCMD(int pid) {
|
2015-11-24 17:52:15 +00:00
|
|
|
TimeLimitedRunner runner = new TimeLimitedRunner(
|
2016-03-01 17:17:27 +00:00
|
|
|
TimeUnit.SECONDS.toMillis(TIMEOUT),
|
2015-11-24 17:52:15 +00:00
|
|
|
Utils.TIMEOUT_FACTOR,
|
2016-03-01 17:17:27 +00:00
|
|
|
() -> makeConnection(pid));
|
2015-11-24 17:52:15 +00:00
|
|
|
try {
|
|
|
|
runner.call();
|
|
|
|
} catch (Exception e) {
|
|
|
|
throw new Error("Exception during the execution: " + e, e);
|
|
|
|
}
|
|
|
|
finish();
|
2015-11-24 17:55:46 +00:00
|
|
|
return new OutputAnalyzer[0];
|
2015-11-24 17:52:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|