mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #7140 from proppy/more-addtar-tests
integration-cli: add more tests for BuildAddTar
This commit is contained in:
commit
030676444a
5 changed files with 47 additions and 30 deletions
|
@ -1,3 +0,0 @@
|
|||
FROM busybox
|
||||
ADD test.tar /test.tar
|
||||
RUN cat /test.tar/test/foo
|
Binary file not shown.
|
@ -1,3 +0,0 @@
|
|||
FROM busybox
|
||||
ADD test.tar /
|
||||
RUN cat /test/foo
|
Binary file not shown.
|
@ -1,7 +1,9 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"archive/tar"
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"os/exec"
|
||||
"path/filepath"
|
||||
|
@ -1770,34 +1772,55 @@ RUN [ "$(cat /testfile)" = 'test!' ]`
|
|||
func TestBuildAddTar(t *testing.T) {
|
||||
name := "testbuildaddtar"
|
||||
defer deleteImages(name)
|
||||
checkOutput := func(out string) {
|
||||
n := -1
|
||||
x := ""
|
||||
for i, line := range strings.Split(out, "\n") {
|
||||
if strings.HasPrefix(line, "Step 2") {
|
||||
n = i + 2
|
||||
x = line[strings.Index(line, "cat ")+4:]
|
||||
|
||||
ctx := func() *FakeContext {
|
||||
dockerfile := `
|
||||
FROM busybox
|
||||
ADD test.tar /
|
||||
RUN cat /test/foo | grep Hi
|
||||
ADD test.tar /test.tar
|
||||
RUN cat /test.tar/test/foo | grep Hi
|
||||
ADD test.tar /unlikely-to-exist
|
||||
RUN cat /unlikely-to-exist/test/foo | grep Hi
|
||||
ADD test.tar /unlikely-to-exist-trailing-slash/
|
||||
RUN cat /unlikely-to-exist-trailing-slash/test/foo | grep Hi
|
||||
RUN mkdir /existing-directory
|
||||
ADD test.tar /existing-directory
|
||||
RUN cat /existing-directory/test/foo | grep Hi
|
||||
ADD test.tar /existing-directory-trailing-slash/
|
||||
RUN cat /existing-directory-trailing-slash/test/foo | grep Hi`
|
||||
tmpDir, err := ioutil.TempDir("", "fake-context")
|
||||
testTar, err := os.Create(filepath.Join(tmpDir, "test.tar"))
|
||||
if err != nil {
|
||||
t.Fatalf("failed to create test.tar archive: %v", err)
|
||||
}
|
||||
if i == n {
|
||||
if line != "Hi" {
|
||||
t.Fatalf("Could not find contents of %s (expected 'Hi' got '%s'", x, line)
|
||||
defer testTar.Close()
|
||||
|
||||
tw := tar.NewWriter(testTar)
|
||||
|
||||
if err := tw.WriteHeader(&tar.Header{
|
||||
Name: "test/foo",
|
||||
Size: 2,
|
||||
}); err != nil {
|
||||
t.Fatalf("failed to write tar file header: %v", err)
|
||||
}
|
||||
n = -2
|
||||
}
|
||||
}
|
||||
if n > -2 {
|
||||
t.Fatalf("Could not find contents of %s in build output", x)
|
||||
if _, err := tw.Write([]byte("Hi")); err != nil {
|
||||
t.Fatalf("failed to write tar file content: %v", err)
|
||||
}
|
||||
if err := tw.Close(); err != nil {
|
||||
t.Fatalf("failed to close tar archive: %v", err)
|
||||
}
|
||||
|
||||
for _, n := range []string{"1", "2"} {
|
||||
buildDirectory := filepath.Join(workingDirectory, "build_tests", "TestBuildAddTar", n)
|
||||
buildCmd := exec.Command(dockerBinary, "build", "-t", name, ".")
|
||||
buildCmd.Dir = buildDirectory
|
||||
out, _, err := runCommandWithOutput(buildCmd)
|
||||
errorOut(err, t, fmt.Sprintf("build failed to complete for TestBuildAddTar/%s: %v", n, err))
|
||||
checkOutput(out)
|
||||
if err := ioutil.WriteFile(filepath.Join(tmpDir, "Dockerfile"), []byte(dockerfile), 0644); err != nil {
|
||||
t.Fatalf("failed to open destination dockerfile: %v", err)
|
||||
}
|
||||
return &FakeContext{Dir: tmpDir}
|
||||
}()
|
||||
|
||||
if _, err := buildImageFromContext(name, ctx, true); err != nil {
|
||||
t.Fatalf("build failed to complete for TestBuildAddTar: %v", err)
|
||||
}
|
||||
|
||||
logDone("build - ADD tar")
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue