From ec63957f9d103e86d3b8e235e79cabb8992cb3ca Mon Sep 17 00:00:00 2001 From: Mikhailo Seledtsov Date: Tue, 17 Aug 2021 23:22:44 +0000 Subject: [PATCH] 8272398: Update DockerTestUtils.buildJdkDockerImage() Reviewed-by: iignatyev, hseigel --- .../containers/docker/DockerBasicTest.java | 2 +- .../containers/docker/TestCPUAwareness.java | 2 +- .../jtreg/containers/docker/TestCPUSets.java | 2 +- .../containers/docker/TestJFREvents.java | 2 +- .../docker/TestJFRNetworkEvents.java | 2 +- .../containers/docker/TestJFRWithJMX.java | 2 +- .../docker/TestJcmdWithSideCar.java | 2 +- .../docker/TestMemoryAwareness.java | 2 +- .../jtreg/containers/docker/TestMisc.java | 2 +- .../jtreg/containers/docker/TestPids.java | 2 +- .../platform/docker/TestDockerCpuMetrics.java | 2 +- .../docker/TestDockerMemoryMetrics.java | 2 +- .../docker/TestGetFreeSwapSpaceSize.java | 2 +- .../platform/docker/TestPidsLimit.java | 2 +- .../platform/docker/TestSystemMetrics.java | 2 +- .../docker/TestUseContainerSupport.java | 2 +- .../containers/docker/DockerTestUtils.java | 73 ++++++++++--------- 17 files changed, 56 insertions(+), 49 deletions(-) diff --git a/test/hotspot/jtreg/containers/docker/DockerBasicTest.java b/test/hotspot/jtreg/containers/docker/DockerBasicTest.java index 792418f074d..bcbd2ffa21d 100644 --- a/test/hotspot/jtreg/containers/docker/DockerBasicTest.java +++ b/test/hotspot/jtreg/containers/docker/DockerBasicTest.java @@ -48,7 +48,7 @@ public class DockerBasicTest { return; } - DockerTestUtils.buildJdkDockerImage(imageNameAndTag, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageNameAndTag); try { testJavaVersion(); diff --git a/test/hotspot/jtreg/containers/docker/TestCPUAwareness.java b/test/hotspot/jtreg/containers/docker/TestCPUAwareness.java index c29181e8b36..d8246bfc2c5 100644 --- a/test/hotspot/jtreg/containers/docker/TestCPUAwareness.java +++ b/test/hotspot/jtreg/containers/docker/TestCPUAwareness.java @@ -52,7 +52,7 @@ public class TestCPUAwareness { } System.out.println("Test Environment: detected availableCPUs = " + availableCPUs); - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { // cpuset, period, shares, expected Active Processor Count diff --git a/test/hotspot/jtreg/containers/docker/TestCPUSets.java b/test/hotspot/jtreg/containers/docker/TestCPUSets.java index f00fb42dbd1..c2bf6ac6446 100644 --- a/test/hotspot/jtreg/containers/docker/TestCPUSets.java +++ b/test/hotspot/jtreg/containers/docker/TestCPUSets.java @@ -57,7 +57,7 @@ public class TestCPUSets { Common.prepareWhiteBox(); - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { // Sanity test the cpu sets reader and parser diff --git a/test/hotspot/jtreg/containers/docker/TestJFREvents.java b/test/hotspot/jtreg/containers/docker/TestJFREvents.java index 8e252d16d25..787a05ebbdb 100644 --- a/test/hotspot/jtreg/containers/docker/TestJFREvents.java +++ b/test/hotspot/jtreg/containers/docker/TestJFREvents.java @@ -58,7 +58,7 @@ public class TestJFREvents { return; } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { diff --git a/test/hotspot/jtreg/containers/docker/TestJFRNetworkEvents.java b/test/hotspot/jtreg/containers/docker/TestJFRNetworkEvents.java index 2f9f6305a00..54ffff4e60e 100644 --- a/test/hotspot/jtreg/containers/docker/TestJFRNetworkEvents.java +++ b/test/hotspot/jtreg/containers/docker/TestJFRNetworkEvents.java @@ -51,7 +51,7 @@ public class TestJFRNetworkEvents { return; } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { runTest("jdk.SocketWrite"); diff --git a/test/hotspot/jtreg/containers/docker/TestJFRWithJMX.java b/test/hotspot/jtreg/containers/docker/TestJFRWithJMX.java index bb31d448afc..61fad4f86be 100644 --- a/test/hotspot/jtreg/containers/docker/TestJFRWithJMX.java +++ b/test/hotspot/jtreg/containers/docker/TestJFRWithJMX.java @@ -80,7 +80,7 @@ public class TestJFRWithJMX { throw new SkippedException("test cannot be run under rootless podman configuration"); } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { test(); diff --git a/test/hotspot/jtreg/containers/docker/TestJcmdWithSideCar.java b/test/hotspot/jtreg/containers/docker/TestJcmdWithSideCar.java index 5fb106516f0..6d48811b7e8 100644 --- a/test/hotspot/jtreg/containers/docker/TestJcmdWithSideCar.java +++ b/test/hotspot/jtreg/containers/docker/TestJcmdWithSideCar.java @@ -65,7 +65,7 @@ public class TestJcmdWithSideCar { return; } - DockerTestUtils.buildJdkDockerImage(IMAGE_NAME, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(IMAGE_NAME); try { // Start the loop process in the "main" container, then run test cases diff --git a/test/hotspot/jtreg/containers/docker/TestMemoryAwareness.java b/test/hotspot/jtreg/containers/docker/TestMemoryAwareness.java index 8e217c5e6f3..f40963c9420 100644 --- a/test/hotspot/jtreg/containers/docker/TestMemoryAwareness.java +++ b/test/hotspot/jtreg/containers/docker/TestMemoryAwareness.java @@ -50,7 +50,7 @@ public class TestMemoryAwareness { } Common.prepareWhiteBox(); - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testMemoryLimit("100m", "104857600"); diff --git a/test/hotspot/jtreg/containers/docker/TestMisc.java b/test/hotspot/jtreg/containers/docker/TestMisc.java index c82cf29c190..dfb95dfdd05 100644 --- a/test/hotspot/jtreg/containers/docker/TestMisc.java +++ b/test/hotspot/jtreg/containers/docker/TestMisc.java @@ -50,7 +50,7 @@ public class TestMisc { } Common.prepareWhiteBox(); - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testMinusContainerSupport(); diff --git a/test/hotspot/jtreg/containers/docker/TestPids.java b/test/hotspot/jtreg/containers/docker/TestPids.java index 3beef9ebaed..df31b2ad091 100644 --- a/test/hotspot/jtreg/containers/docker/TestPids.java +++ b/test/hotspot/jtreg/containers/docker/TestPids.java @@ -52,7 +52,7 @@ public class TestPids { } Common.prepareWhiteBox(); - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testPids(); diff --git a/test/jdk/jdk/internal/platform/docker/TestDockerCpuMetrics.java b/test/jdk/jdk/internal/platform/docker/TestDockerCpuMetrics.java index 54d495684b0..52f6787a12c 100644 --- a/test/jdk/jdk/internal/platform/docker/TestDockerCpuMetrics.java +++ b/test/jdk/jdk/internal/platform/docker/TestDockerCpuMetrics.java @@ -54,7 +54,7 @@ public class TestDockerCpuMetrics { // container include the Java test class to be run along with the // resource to be examined and expected result. - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { int numCpus = CPUSetsReader.getNumCpus(); diff --git a/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java b/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java index 3f4ad371669..ca75aa745e0 100644 --- a/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java +++ b/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java @@ -52,7 +52,7 @@ public class TestDockerMemoryMetrics { // container include the Java test class to be run along with the // resource to be examined and expected result. - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testMemoryLimit("200m"); testMemoryLimit("1g"); diff --git a/test/jdk/jdk/internal/platform/docker/TestGetFreeSwapSpaceSize.java b/test/jdk/jdk/internal/platform/docker/TestGetFreeSwapSpaceSize.java index 180da101cdf..319c55ab518 100644 --- a/test/jdk/jdk/internal/platform/docker/TestGetFreeSwapSpaceSize.java +++ b/test/jdk/jdk/internal/platform/docker/TestGetFreeSwapSpaceSize.java @@ -43,7 +43,7 @@ public class TestGetFreeSwapSpaceSize { return; } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testGetFreeSwapSpaceSize( diff --git a/test/jdk/jdk/internal/platform/docker/TestPidsLimit.java b/test/jdk/jdk/internal/platform/docker/TestPidsLimit.java index 89d35eedfe3..99ef9d0cf8c 100644 --- a/test/jdk/jdk/internal/platform/docker/TestPidsLimit.java +++ b/test/jdk/jdk/internal/platform/docker/TestPidsLimit.java @@ -48,7 +48,7 @@ public class TestPidsLimit { return; } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testPidsLimit("1000"); diff --git a/test/jdk/jdk/internal/platform/docker/TestSystemMetrics.java b/test/jdk/jdk/internal/platform/docker/TestSystemMetrics.java index a54299f794d..f1fc22e5e9b 100644 --- a/test/jdk/jdk/internal/platform/docker/TestSystemMetrics.java +++ b/test/jdk/jdk/internal/platform/docker/TestSystemMetrics.java @@ -45,7 +45,7 @@ public class TestSystemMetrics { return; } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { Common.logNewTestCase("Test SystemMetrics"); diff --git a/test/jdk/jdk/internal/platform/docker/TestUseContainerSupport.java b/test/jdk/jdk/internal/platform/docker/TestUseContainerSupport.java index a2719ebccc1..7a2f77b3ce4 100644 --- a/test/jdk/jdk/internal/platform/docker/TestUseContainerSupport.java +++ b/test/jdk/jdk/internal/platform/docker/TestUseContainerSupport.java @@ -44,7 +44,7 @@ public class TestUseContainerSupport { return; } - DockerTestUtils.buildJdkDockerImage(imageName, "Dockerfile-BasicTest", "jdk-docker"); + DockerTestUtils.buildJdkContainerImage(imageName); try { testUseContainerSupport(true); diff --git a/test/lib/jdk/test/lib/containers/docker/DockerTestUtils.java b/test/lib/jdk/test/lib/containers/docker/DockerTestUtils.java index 46619538f22..8e381180dfb 100644 --- a/test/lib/jdk/test/lib/containers/docker/DockerTestUtils.java +++ b/test/lib/jdk/test/lib/containers/docker/DockerTestUtils.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -120,59 +120,66 @@ public class DockerTestUtils { return true; } - - /** - * Build a docker image that contains JDK under test. - * The jdk will be placed under the "/jdk/" folder inside the docker file system. + /** + * Build a container image that contains JDK under test. + * The jdk will be placed under the "/jdk/" folder inside the image/container file system. * - * @param imageName name of the image to be created, including version tag - * @param dockerfile name of the dockerfile residing in the test source; - * we check for a platform specific dockerfile as well - * and use this one in case it exists - * @param buildDirName name of the docker build/staging directory, which will - * be created in the jtreg's scratch folder + * @param imageName name of the image to be created, including version tag * @throws Exception */ - public static void - buildJdkDockerImage(String imageName, String dockerfile, String buildDirName) - throws Exception { + public static void buildJdkContainerImage(String imageName) throws Exception { + buildJdkContainerImage(imageName, null); + } - Path buildDir = Paths.get(".", buildDirName); + /** + * Build a container image that contains JDK under test. + * The jdk will be placed under the "/jdk/" folder inside the image/container file system. + * + * @param imageName name of the image to be created, including version tag + * @param dockerfileContent content of the Dockerfile; use null to generate default content + * @throws Exception + */ + public static void buildJdkContainerImage(String imageName, String dockerfileContent) throws Exception { + // image name may contain tag, hence replace ':' + String imageDirName = imageName.replace(":", "-"); + + // Create an image build/staging directory + Path buildDir = Paths.get(imageDirName); if (Files.exists(buildDir)) { throw new RuntimeException("The docker build directory already exists: " + buildDir); } + Files.createDirectories(buildDir); - Path jdkSrcDir = Paths.get(JDK_UNDER_TEST); - Path jdkDstDir = buildDir.resolve("jdk"); - - Files.createDirectories(jdkDstDir); + // Generate Dockerfile + if (dockerfileContent != null) { + Files.writeString(buildDir.resolve("Dockerfile"), dockerfileContent); + } else { + generateDockerFile(buildDir.resolve("Dockerfile"), + DockerfileConfig.getBaseImageName(), + DockerfileConfig.getBaseImageVersion()); + } // Copy JDK-under-test tree to the docker build directory. // This step is required for building a docker image. + Path jdkSrcDir = Paths.get(JDK_UNDER_TEST); + Path jdkDstDir = buildDir.resolve("jdk"); + Files.createDirectories(jdkDstDir); Files.walkFileTree(jdkSrcDir, new CopyFileVisitor(jdkSrcDir, jdkDstDir)); - buildDockerImage(imageName, Paths.get(Utils.TEST_SRC, dockerfile), buildDir); + + buildImage(imageName, buildDir); } /** - * Build a docker image based on given docker file and docker build directory. + * Build a container image based on image build directory. * * @param imageName name of the image to be created, including version tag - * @param dockerfile path to the Dockerfile to be used for building the docker - * image. The specified dockerfile will be copied to the docker build - * directory as 'Dockerfile' - * @param buildDir build directory; it should already contain all the content - * needed to build the docker image. + * @param buildDir build directory; it should already contain all the content + * needed to build the image. * @throws Exception */ - public static void - buildDockerImage(String imageName, Path dockerfile, Path buildDir) throws Exception { - - generateDockerFile(buildDir.resolve("Dockerfile"), - DockerfileConfig.getBaseImageName(), - DockerfileConfig.getBaseImageVersion()); + private static void buildImage(String imageName, Path buildDir) throws Exception { try { - // Build the docker execute(Container.ENGINE_COMMAND, "build", "--no-cache", "--tag", imageName, buildDir.toString()) .shouldHaveExitValue(0); } catch (Exception e) {