RFR: 8221221: [testbug] make test TEST="jtreg:test/hotspot/jtreg/runtime/containers" failed on Ubuntu 18.04

Jie Fu fujie at loongson.cn
Fri Mar 22 02:57:37 UTC 2019


Hi Misha,

Sorry for my late reply. I didn't receive the email until just now.
Your suggestions are of great help to me.
Thanks a lot.

Best regards,
Jie


On 2019/3/22 上午6:37, mikhailo.seledtsov at oracle.com wrote:
> Hi Jie,
>
>     In general I agree its time to make the docker file in HotSpot 
> tests more dynamic. When the tests were originally created, there was 
> no need to make them dynamic, and possibly dockerfile did not support 
> the build args (do not remember for sure).
>
> I was the original author of runtime Docker tests, and would like to 
> provide additional suggestion. I like the idea of using the build args 
> in the docker file. In general in hotspot testing we usually use 
> properties in such situations to parameterize the tests. I propose the 
> following properties:
>
> - jdk.test.docker.image.name for image name
>
> - jdk.test.docker.image.version for image version
>
>
> Here are the proposed prototype code changes to implement this:
> ======================================
> --- a/test/hotspot/jtreg/runtime/containers/docker/Dockerfile-BasicTest
> +++ b/test/hotspot/jtreg/runtime/containers/docker/Dockerfile-BasicTest
> @@ -1,4 +1,7 @@
> -FROM oraclelinux:7.6
> +ARG IMAGE_NAME=oraclelinux
> +ARG IMAGE_VERSION=7.6
> +
> +FROM $IMAGE_NAME:$IMAGE_VERSION
>
>
> --- a/test/lib/jdk/test/lib/containers/docker/DockerTestUtils.java
> +++ b/test/lib/jdk/test/lib/containers/docker/DockerTestUtils.java
> @@ -46,6 +46,10 @@
>      private static boolean isDockerEngineAvailable = false;
>      private static boolean wasDockerEngineChecked = false;
>
> +    // Image name and version
> +    private static final String IMAGE_NAME = 
> System.getProperty("jdk.test.docker.image.name", "oraclelinux");
> +    private static final String IMAGE_VERSION = 
> System.getProperty("jdk.test.docker.image.version", "7.6");
> +
>      // Diagnostics: set to true to enable more diagnostic info
>      private static final boolean DEBUG = false;
>
> @@ -162,7 +166,10 @@
>          Files.copy(dockerfile, buildDir.resolve("Dockerfile"));
>
>          // Build the docker
> -        execute("docker", "build", "--no-cache", "--tag", imageName, 
> buildDir.toString())
> +        execute("docker", "build", "--no-cache",
> +                "--build-arg", "IMAGE_NAME=" + IMAGE_NAME,
> +                "--build-arg", "IMAGE_VERSION=" + IMAGE_VERSION,
> +                "--tag", imageName, buildDir.toString())
>              .shouldHaveExitValue(0)
>              .shouldContain("Successfully built");
>      }
>
> ======================================
>
> Please let me know if this works for you, and if you have any 
> questions or comments.
>
>
> Best regards,
> Misha
>
>
> On 3/21/19 2:50 AM, Jie Fu wrote:
>> Good suggestions!
>>
>> Thanks Severin.
>>
>>
>> On 2019/3/21 下午4:57, Severin Gehwolf wrote:
>>> Hi,
>>>
>>> On Thu, 2019-03-21 at 16:23 +0800, Jie Fu wrote:
>>>> Hi all,
>>>>
>>>> Bug: https://bugs.openjdk.java.net/browse/JDK-8221221
>>>>
>>>> make test TEST="jtreg:test/hotspot/jtreg/runtime/containers" failed on
>>>> Ubuntu 18.04.
>>>>
>>>> The issue can be fixed by
>>>> -----------------------------------------------
>>>> diff -r ce78fac1f6d5
>>>> test/hotspot/jtreg/runtime/containers/docker/Dockerfile-BasicTest
>>>> --- 
>>>> a/test/hotspot/jtreg/runtime/containers/docker/Dockerfile-BasicTest
>>>> Thu Mar 21 01:49:27 2019 +0100
>>>> +++ 
>>>> b/test/hotspot/jtreg/runtime/containers/docker/Dockerfile-BasicTest
>>>> Thu Mar 21 15:44:39 2019 +0800
>>>> @@ -1,4 +1,4 @@
>>>> -FROM oraclelinux:7.6
>>>> +FROM fedora:29
>>>>    MAINTAINER mikhailo.seledtsov at oracle.com
>>>>
>>>>    COPY /jdk /jdk
>>>> -----------------------------------------------
>>>>
>>>> The change has been tested with
>>>> -----------------------------------------------
>>>> make test TEST="test/jdk/jdk/modules/scenarios/container
>>>> test/hotspot/jtreg/vmTestbase/vm/gc/containers
>>>> test/hotspot/jtreg/runtime/containers"
>>>> -----------------------------------------------
>>>> on Linux/x86-64 (Ubuntu 18.04).
>>>>
>>>> Could you please review it?
>>>> Thanks a lot.
>>>>
>>>> Best regards,
>>>> Jie
>>> This fix will be inadequate as the expectation is to have the
>>> (reasonably?) same base image as the build platform. If you had built
>>> the JDK on say, centos 7, then the test would likely work.
>>>
>>> So if anything, I agree with David who commented on the bug, there
>>> should be a way to set the to-be-used base image via some option in the
>>> test using the current value as a default.
>>>
>>> Here is what AdoptOpenJDK does:
>>>
>>> ARG IMAGE_NAME=adoptopenjdk/openjdk8
>>> ARG IMAGE_VERSION=latest
>>>
>>> FROM $IMAGE_NAME:$IMAGE_VERSION
>>>
>>> Example usage:
>>> docker build --build-arg IMAGE_NAME=fedora --build-arg 
>>> IMAGE_VERSION=29 [...]
>>>
>>> Thanks,
>>> Severin
>>>
>>
>



More information about the hotspot-runtime-dev mailing list