2014-06-02 21:36:59 -04:00
|
|
|
/*
|
2016-03-03 12:44:34 -08:00
|
|
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
2014-06-02 21:36:59 -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.
|
|
|
|
*/
|
|
|
|
|
2014-07-31 11:56:59 -07:00
|
|
|
/* @test LimitSharedSizes
|
2014-06-02 21:36:59 -04:00
|
|
|
* @summary Test handling of limits on shared space size
|
2015-11-19 16:32:41 -06:00
|
|
|
* @library /testlibrary /runtime/CommandLine/OptionsValidation/common
|
2016-04-09 23:03:39 +01:00
|
|
|
* @modules java.base/jdk.internal.misc
|
2015-03-26 16:36:56 +01:00
|
|
|
* java.management
|
2016-03-03 12:44:34 -08:00
|
|
|
* jdk.attach/sun.tools.attach
|
2014-06-02 21:36:59 -04:00
|
|
|
* @run main LimitSharedSizes
|
|
|
|
*/
|
|
|
|
|
2015-05-04 16:30:07 +02:00
|
|
|
import jdk.test.lib.*;
|
2015-11-19 16:32:41 -06:00
|
|
|
import optionsvalidation.JVMOptionsUtils;
|
2014-06-02 21:36:59 -04:00
|
|
|
|
|
|
|
public class LimitSharedSizes {
|
2015-11-19 16:32:41 -06:00
|
|
|
static enum Result {
|
|
|
|
OUT_OF_RANGE,
|
|
|
|
TOO_SMALL,
|
|
|
|
VALID,
|
|
|
|
VALID_ARCHIVE
|
|
|
|
}
|
|
|
|
|
2014-12-05 12:24:10 -08:00
|
|
|
static enum Region {
|
|
|
|
RO, RW, MD, MC
|
|
|
|
}
|
|
|
|
|
2015-11-19 16:32:41 -06:00
|
|
|
private static final boolean fitsRange(String name, String value) throws RuntimeException {
|
|
|
|
boolean fits = true;
|
|
|
|
try {
|
|
|
|
fits = JVMOptionsUtils.fitsRange(name, value);
|
|
|
|
} catch (Exception e) {
|
|
|
|
throw new RuntimeException(e.getMessage());
|
|
|
|
}
|
|
|
|
return fits;
|
|
|
|
}
|
|
|
|
|
2014-06-02 21:36:59 -04:00
|
|
|
private static class SharedSizeTestData {
|
|
|
|
public String optionName;
|
|
|
|
public String optionValue;
|
2015-11-19 16:32:41 -06:00
|
|
|
public Result optionResult;
|
2014-06-02 21:36:59 -04:00
|
|
|
|
2015-11-19 16:32:41 -06:00
|
|
|
public SharedSizeTestData(Region region, String value) {
|
|
|
|
optionName = "-XX:"+getName(region);
|
2014-06-02 21:36:59 -04:00
|
|
|
optionValue = value;
|
2015-11-19 16:32:41 -06:00
|
|
|
if (fitsRange(getName(region), value) == false) {
|
|
|
|
optionResult = Result.OUT_OF_RANGE;
|
|
|
|
} else {
|
|
|
|
optionResult = Result.TOO_SMALL;
|
|
|
|
}
|
2014-06-02 21:36:59 -04:00
|
|
|
}
|
|
|
|
|
2015-11-19 16:32:41 -06:00
|
|
|
public SharedSizeTestData(Region region, String value, Result result) {
|
|
|
|
optionName = "-XX:"+getName(region);
|
|
|
|
optionValue = value;
|
|
|
|
optionResult = result;
|
2014-12-05 12:24:10 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
private String getName(Region region) {
|
|
|
|
String name;
|
|
|
|
switch (region) {
|
|
|
|
case RO:
|
2015-11-19 16:32:41 -06:00
|
|
|
name = "SharedReadOnlySize";
|
2014-12-05 12:24:10 -08:00
|
|
|
break;
|
|
|
|
case RW:
|
2015-11-19 16:32:41 -06:00
|
|
|
name = "SharedReadWriteSize";
|
2014-12-05 12:24:10 -08:00
|
|
|
break;
|
|
|
|
case MD:
|
2015-11-19 16:32:41 -06:00
|
|
|
name = "SharedMiscDataSize";
|
2014-12-05 12:24:10 -08:00
|
|
|
break;
|
|
|
|
case MC:
|
2015-11-19 16:32:41 -06:00
|
|
|
name = "SharedMiscCodeSize";
|
2014-12-05 12:24:10 -08:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
name = "Unknown";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return name;
|
|
|
|
}
|
2014-06-02 21:36:59 -04:00
|
|
|
|
2015-11-19 16:32:41 -06:00
|
|
|
public Result getResult() {
|
|
|
|
return optionResult;
|
2014-12-05 12:24:10 -08:00
|
|
|
}
|
|
|
|
}
|
2014-06-02 21:36:59 -04:00
|
|
|
|
2014-12-05 12:24:10 -08:00
|
|
|
private static final SharedSizeTestData[] testTable = {
|
|
|
|
// Too small of a region size should not cause a vm crash.
|
2015-11-19 16:32:41 -06:00
|
|
|
// It should result in an error message either like the following #1:
|
2014-10-23 10:08:02 -07:00
|
|
|
// The shared miscellaneous code space is not large enough
|
|
|
|
// to preload requested classes. Use -XX:SharedMiscCodeSize=
|
|
|
|
// to increase the initial size of shared miscellaneous code space.
|
2015-11-19 16:32:41 -06:00
|
|
|
// or #2:
|
|
|
|
// The shared miscellaneous code space is outside the allowed range
|
|
|
|
new SharedSizeTestData(Region.RO, "4M"),
|
|
|
|
new SharedSizeTestData(Region.RW, "4M"),
|
|
|
|
new SharedSizeTestData(Region.MD, "50k"),
|
|
|
|
new SharedSizeTestData(Region.MC, "20k"),
|
|
|
|
|
|
|
|
// these values are larger than default ones, and should
|
2014-06-02 21:36:59 -04:00
|
|
|
// be acceptable and not cause failure
|
2015-11-19 16:32:41 -06:00
|
|
|
new SharedSizeTestData(Region.RO, "20M", Result.VALID),
|
|
|
|
new SharedSizeTestData(Region.RW, "20M", Result.VALID),
|
|
|
|
new SharedSizeTestData(Region.MD, "20M", Result.VALID),
|
|
|
|
new SharedSizeTestData(Region.MC, "20M", Result.VALID),
|
2014-12-05 12:24:10 -08:00
|
|
|
|
|
|
|
// test with sizes which just meet the minimum required sizes
|
|
|
|
// the following tests also attempt to use the shared archive
|
2015-11-19 16:32:41 -06:00
|
|
|
new SharedSizeTestData(Region.RO, Platform.is64bit() ? "9M":"8M", Result.VALID_ARCHIVE),
|
|
|
|
new SharedSizeTestData(Region.RW, Platform.is64bit() ? "12M":"7M", Result.VALID_ARCHIVE),
|
|
|
|
new SharedSizeTestData(Region.MD, Platform.is64bit() ? "4M":"2M", Result.VALID_ARCHIVE),
|
|
|
|
new SharedSizeTestData(Region.MC, "120k", Result.VALID_ARCHIVE),
|
2014-06-02 21:36:59 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
2015-03-30 08:28:07 -07:00
|
|
|
int counter = 0;
|
2014-06-02 21:36:59 -04:00
|
|
|
for (SharedSizeTestData td : testTable) {
|
2015-03-30 08:28:07 -07:00
|
|
|
String fileName = "LimitSharedSizes" + counter + ".jsa";
|
|
|
|
counter++;
|
|
|
|
|
2014-06-02 21:36:59 -04:00
|
|
|
String option = td.optionName + "=" + td.optionValue;
|
2015-11-19 16:32:41 -06:00
|
|
|
System.out.println("testing option number <" + counter + ">");
|
2014-06-02 21:36:59 -04:00
|
|
|
System.out.println("testing option <" + option + ">");
|
|
|
|
|
|
|
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
|
|
|
"-XX:+UnlockDiagnosticVMOptions",
|
|
|
|
"-XX:SharedArchiveFile=./" + fileName,
|
|
|
|
option,
|
|
|
|
"-Xshare:dump");
|
|
|
|
|
|
|
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
|
|
|
|
2015-11-19 16:32:41 -06:00
|
|
|
switch (td.getResult()) {
|
|
|
|
case VALID:
|
|
|
|
case VALID_ARCHIVE:
|
|
|
|
{
|
|
|
|
output.shouldNotContain("space is not large enough");
|
|
|
|
output.shouldHaveExitValue(0);
|
|
|
|
|
|
|
|
if (td.getResult() == Result.VALID_ARCHIVE) {
|
|
|
|
// try to use the archive
|
|
|
|
pb = ProcessTools.createJavaProcessBuilder(
|
|
|
|
"-XX:+UnlockDiagnosticVMOptions",
|
|
|
|
"-XX:SharedArchiveFile=./" + fileName,
|
|
|
|
"-XX:+PrintSharedArchiveAndExit",
|
|
|
|
"-version");
|
|
|
|
|
|
|
|
try {
|
|
|
|
output = new OutputAnalyzer(pb.start());
|
|
|
|
output.shouldContain("archive is valid");
|
|
|
|
} catch (RuntimeException e) {
|
|
|
|
// if sharing failed due to ASLR or similar reasons,
|
|
|
|
// check whether sharing was attempted at all (UseSharedSpaces)
|
|
|
|
if ((output.getOutput().contains("Unable to use shared archive") ||
|
|
|
|
output.getOutput().contains("Unable to map ReadOnly shared space at required address.") ||
|
|
|
|
output.getOutput().contains("Unable to map ReadWrite shared space at required address.") ||
|
|
|
|
output.getOutput().contains("Unable to reserve shared space at required address")) &&
|
|
|
|
output.getExitValue() == 1) {
|
|
|
|
System.out.println("Unable to use shared archive: test not executed; assumed passed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
output.shouldHaveExitValue(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case TOO_SMALL:
|
|
|
|
{
|
|
|
|
output.shouldContain("space is not large enough");
|
2014-12-05 12:24:10 -08:00
|
|
|
output.shouldHaveExitValue(2);
|
|
|
|
}
|
2015-11-19 16:32:41 -06:00
|
|
|
break;
|
|
|
|
case OUT_OF_RANGE:
|
|
|
|
{
|
|
|
|
output.shouldContain("outside the allowed range");
|
|
|
|
output.shouldHaveExitValue(1);
|
|
|
|
}
|
|
|
|
break;
|
2014-06-02 21:36:59 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|