2017-11-16 19:01:01 -08:00
|
|
|
/*
|
2024-10-12 03:25:42 +00:00
|
|
|
* Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved.
|
2017-11-16 19:01:01 -08: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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @test
|
|
|
|
* @summary Test miscellanous functionality related to JVM running in docker container
|
2024-10-12 03:25:42 +00:00
|
|
|
* @requires container.support
|
2017-11-16 19:01:01 -08:00
|
|
|
* @library /test/lib
|
|
|
|
* @modules java.base/jdk.internal.misc
|
|
|
|
* java.management
|
|
|
|
* jdk.jartool/sun.tools.jar
|
2022-07-08 15:55:14 +00:00
|
|
|
* @build CheckContainerized jdk.test.whitebox.WhiteBox PrintContainerInfo
|
|
|
|
* @run driver jdk.test.lib.helpers.ClassFileInstaller -jar whitebox.jar jdk.test.whitebox.WhiteBox
|
2017-11-16 19:01:01 -08:00
|
|
|
* @run driver TestMisc
|
|
|
|
*/
|
2018-06-12 18:51:45 -04:00
|
|
|
import jdk.test.lib.containers.docker.Common;
|
2017-11-16 19:01:01 -08:00
|
|
|
import jdk.test.lib.containers.docker.DockerTestUtils;
|
2018-06-12 18:51:45 -04:00
|
|
|
import jdk.test.lib.containers.docker.DockerRunOptions;
|
2017-11-16 19:01:01 -08:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
|
|
|
import jdk.test.lib.process.ProcessTools;
|
|
|
|
|
|
|
|
|
|
|
|
public class TestMisc {
|
|
|
|
private static final String imageName = Common.imageName("misc");
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
if (!DockerTestUtils.canTestDocker()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Common.prepareWhiteBox();
|
2021-08-17 23:22:44 +00:00
|
|
|
DockerTestUtils.buildJdkContainerImage(imageName);
|
2017-11-16 19:01:01 -08:00
|
|
|
|
|
|
|
try {
|
|
|
|
testMinusContainerSupport();
|
|
|
|
testIsContainerized();
|
|
|
|
testPrintContainerInfo();
|
2022-02-09 11:33:16 +00:00
|
|
|
testPrintContainerInfoActiveProcessorCount();
|
2017-11-16 19:01:01 -08:00
|
|
|
} finally {
|
|
|
|
DockerTestUtils.removeDockerImage(imageName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static void testMinusContainerSupport() throws Exception {
|
|
|
|
Common.logNewTestCase("Test related flags: '-UseContainerSupport'");
|
|
|
|
DockerRunOptions opts = new DockerRunOptions(imageName, "/jdk/bin/java", "-version");
|
|
|
|
opts.addJavaOpts("-XX:-UseContainerSupport", "-Xlog:os+container=trace");
|
|
|
|
|
|
|
|
Common.run(opts)
|
|
|
|
.shouldContain("Container Support not enabled");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static void testIsContainerized() throws Exception {
|
|
|
|
Common.logNewTestCase("Test is_containerized() inside a docker container");
|
|
|
|
|
|
|
|
DockerRunOptions opts = Common.newOpts(imageName, "CheckContainerized");
|
|
|
|
Common.addWhiteBoxOpts(opts);
|
|
|
|
|
|
|
|
Common.run(opts)
|
|
|
|
.shouldContain(CheckContainerized.INSIDE_A_CONTAINER);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static void testPrintContainerInfo() throws Exception {
|
|
|
|
Common.logNewTestCase("Test print_container_info()");
|
|
|
|
|
|
|
|
DockerRunOptions opts = Common.newOpts(imageName, "PrintContainerInfo");
|
|
|
|
Common.addWhiteBoxOpts(opts);
|
|
|
|
|
|
|
|
checkContainerInfo(Common.run(opts));
|
|
|
|
}
|
|
|
|
|
2022-02-09 11:33:16 +00:00
|
|
|
private static void testPrintContainerInfoActiveProcessorCount() throws Exception {
|
|
|
|
Common.logNewTestCase("Test print_container_info()");
|
|
|
|
|
|
|
|
DockerRunOptions opts = Common.newOpts(imageName, "PrintContainerInfo").addJavaOpts("-XX:ActiveProcessorCount=2");
|
|
|
|
Common.addWhiteBoxOpts(opts);
|
|
|
|
|
|
|
|
OutputAnalyzer out = Common.run(opts);
|
|
|
|
out.shouldContain("but overridden by -XX:ActiveProcessorCount 2");
|
|
|
|
}
|
2017-11-16 19:01:01 -08:00
|
|
|
|
|
|
|
private static void checkContainerInfo(OutputAnalyzer out) throws Exception {
|
|
|
|
String[] expectedToContain = new String[] {
|
|
|
|
"cpuset.cpus",
|
|
|
|
"cpuset.mems",
|
|
|
|
"CPU Shares",
|
|
|
|
"CPU Quota",
|
|
|
|
"CPU Period",
|
|
|
|
"OSContainer::active_processor_count",
|
|
|
|
"Memory Limit",
|
|
|
|
"Memory Soft Limit",
|
|
|
|
"Memory Usage",
|
|
|
|
"Maximum Memory Usage",
|
2021-08-10 07:40:21 +00:00
|
|
|
"memory_max_usage_in_bytes",
|
2021-09-16 07:08:19 +00:00
|
|
|
"maximum number of tasks",
|
2024-01-10 17:29:55 +00:00
|
|
|
"current number of tasks",
|
|
|
|
"rss_usage_in_bytes",
|
|
|
|
"cache_usage_in_bytes"
|
2017-11-16 19:01:01 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
for (String s : expectedToContain) {
|
|
|
|
out.shouldContain(s);
|
|
|
|
}
|
2022-06-22 10:36:16 +00:00
|
|
|
String str = out.getOutput();
|
|
|
|
if (str.contains("cgroupv1")) {
|
|
|
|
out.shouldContain("kernel_memory_usage_in_bytes");
|
|
|
|
out.shouldContain("kernel_memory_max_usage_in_bytes");
|
|
|
|
out.shouldContain("kernel_memory_limit_in_bytes");
|
|
|
|
} else {
|
|
|
|
if (str.contains("cgroupv2")) {
|
|
|
|
out.shouldContain("memory_swap_current_in_bytes");
|
|
|
|
out.shouldContain("memory_swap_max_limit_in_bytes");
|
|
|
|
} else {
|
|
|
|
throw new RuntimeException("Output has to contain information about cgroupv1 or cgroupv2");
|
|
|
|
}
|
|
|
|
}
|
2017-11-16 19:01:01 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|