From 7a25fb0e7bea1ba6fd099c5ebabe0a8aa0eed9b5 Mon Sep 17 00:00:00 2001 From: Daniel Githinji Date: Tue, 15 Oct 2024 09:41:21 +0300 Subject: [PATCH] tests: frontend/dockerfile: update integration tests for windows/wcow - [x] `testCopyThroughSymlinkContext` - [x] `testIgnoreEntrypoint` - [x] `testQuotedMetaArgs` - [x] `testDockerfileCheckHostname` - [x] `testEmptyStages` - [x] `testNamedImageContextScratch` - [x] `testNamedImageContextPlatform` Signed-off-by: Daniel Githinji --- frontend/dockerfile/dockerfile_test.go | 94 +++++++++++++++++++------- 1 file changed, 70 insertions(+), 24 deletions(-) diff --git a/frontend/dockerfile/dockerfile_test.go b/frontend/dockerfile/dockerfile_test.go index 2647826444371..c858490da0aba 100644 --- a/frontend/dockerfile/dockerfile_test.go +++ b/frontend/dockerfile/dockerfile_test.go @@ -1356,13 +1356,18 @@ RUN [ "$(stat -c "%U %G" /dest01)" == "user01 user" ] } func testCopyThroughSymlinkContext(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") f := getFrontend(t, sb) - dockerfile := []byte(` + dockerfile := []byte(integration.UnixOrWindows( + ` FROM scratch COPY link/foo . -`) +`, + ` +FROM nanoserver AS build +COPY link/foo . +`, + )) dir := integration.Tmpdir( t, @@ -1481,14 +1486,20 @@ COPY . / } func testIgnoreEntrypoint(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") f := getFrontend(t, sb) - dockerfile := []byte(` + dockerfile := []byte(integration.UnixOrWindows( + ` FROM busybox ENTRYPOINT ["/nosuchcmd"] RUN ["ls"] -`) +`, + ` +FROM nanoserver AS build +ENTRYPOINT ["nosuchcmd.exe"] +RUN dir +`, + )) dir := integration.Tmpdir( t, @@ -1509,10 +1520,10 @@ RUN ["ls"] } func testQuotedMetaArgs(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") f := getFrontend(t, sb) - dockerfile := []byte(` + dockerfile := []byte(integration.UnixOrWindows( + ` ARG a1="box" ARG a2="$a1-foo" FROM busy$a1 AS build @@ -1521,7 +1532,18 @@ ARG a3="bar-$a2" RUN echo -n $a3 > /out FROM scratch COPY --from=build /out . -`) +`, + ` +ARG a1="server" +ARG a2="$a1-foo" +FROM nano$a1 AS build +ARG a2 +ARG a3="bar-$a2" +RUN echo %a3% > /out +FROM nanoserver +COPY --from=build /out . +`, + )) dir := integration.Tmpdir( t, @@ -1550,7 +1572,12 @@ COPY --from=build /out . dt, err := os.ReadFile(filepath.Join(destDir, "out")) require.NoError(t, err) - require.Equal(t, "bar-box-foo", string(dt)) + + // create a variable that holds a string depending on the OS platform. + // The string will be used to test against the string returned from the created out file + testString := string([]byte(integration.UnixOrWindows("bar-box-foo", "bar-server-foo \r\n"))) + + require.Equal(t, testString, string(dt)) } func testGlobalArgErrors(t *testing.T, sb integration.Sandbox) { @@ -6312,14 +6339,19 @@ COPY Dockerfile Dockerfile // moby/buildkit#1301 func testDockerfileCheckHostname(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") f := getFrontend(t, sb) - dockerfile := []byte(` + dockerfile := []byte(integration.UnixOrWindows( + ` FROM busybox RUN cat /etc/hosts | grep foo RUN echo $HOSTNAME | grep foo RUN echo $(hostname) | grep foo -`) +`, + ` +FROM nanoserver +RUN reg query "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters" /v Hostname| findstr "foo" +`, + )) dir := integration.Tmpdir( t, @@ -6370,11 +6402,15 @@ RUN echo $(hostname) | grep foo } func testEmptyStages(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") f := getFrontend(t, sb) - dockerfile := []byte(` + dockerfile := []byte(integration.UnixOrWindows( + ` ARG foo=bar -`) +`, + ` +ARG foo=bar +`, + )) dir := integration.Tmpdir( t, @@ -6693,7 +6729,6 @@ COPY --from=base /env_foobar / } func testNamedImageContextPlatform(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") workers.CheckFeatureCompat(t, sb, workers.FeatureDirectPush) ctx := sb.Context() @@ -6708,7 +6743,8 @@ func testNamedImageContextPlatform(t *testing.T, sb integration.Sandbox) { require.NoError(t, err) // Build a base image and force buildkit to generate a manifest list. - dockerfile := []byte(`FROM --platform=$BUILDPLATFORM alpine:latest`) + dockerfile := []byte(integration.UnixOrWindows(`FROM --platform=$BUILDPLATFORM alpine:latest`, + `FROM --platform=$BUILDPLATFORM nanoserver:latest`)) target := registry + "/buildkit/testnamedimagecontextplatform:latest" dir := integration.Tmpdir( @@ -6738,10 +6774,12 @@ func testNamedImageContextPlatform(t *testing.T, sb integration.Sandbox) { }, nil) require.NoError(t, err) - dockerfile = []byte(` + dockerfile = []byte(integration.UnixOrWindows(` FROM --platform=$BUILDPLATFORM busybox AS target -RUN echo hello -`) +RUN echo hello`, + ` +FROM --platform=$BUILDPLATFORM nanoserver AS target +RUN echo hello`)) dir = integration.Tmpdir( t, @@ -6852,19 +6890,27 @@ RUN echo foo >> /test } func testNamedImageContextScratch(t *testing.T, sb integration.Sandbox) { - integration.SkipOnPlatform(t, "windows") ctx := sb.Context() c, err := client.New(ctx, sb.Address()) require.NoError(t, err) defer c.Close() - dockerfile := []byte(` + dockerfile := []byte(integration.UnixOrWindows( + ` FROM busybox COPY <