Skip to content

Commit

Permalink
Merge pull request moby#37770 from Microsoft/jjh/TestBuildSymlinkBrea…
Browse files Browse the repository at this point in the history
…kout

Windows: Go1.11: Use long path in TestBuildSymlinkBreakout
  • Loading branch information
cpuguy83 authored Sep 6, 2018
2 parents f94eec2 + b1b9937 commit 7aa797f
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 0 deletions.
6 changes: 6 additions & 0 deletions integration-cli/docker_cli_build_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import (
"github.com/docker/docker/internal/test/fakestorage"
"github.com/docker/docker/internal/testutil"
"github.com/docker/docker/pkg/archive"
"github.com/docker/docker/pkg/system"
"github.com/go-check/check"
"github.com/moby/buildkit/frontend/dockerfile/command"
"github.com/opencontainers/go-digest"
Expand Down Expand Up @@ -3601,6 +3602,11 @@ func (s *DockerSuite) TestBuildSymlinkBreakout(c *check.C) {
name := "testbuildsymlinkbreakout"
tmpdir, err := ioutil.TempDir("", name)
c.Assert(err, check.IsNil)

// See https://github.com/moby/moby/pull/37770 for reason for next line.
tmpdir, err = system.GetLongPathName(tmpdir)
c.Assert(err, check.IsNil)

defer os.RemoveAll(tmpdir)
ctx := filepath.Join(tmpdir, "context")
if err := os.MkdirAll(ctx, 0755); err != nil {
Expand Down
10 changes: 10 additions & 0 deletions pkg/system/path_unix.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
// +build !windows

package system // import "github.com/docker/docker/pkg/system"

// GetLongPathName converts Windows short pathnames to full pathnames.
// For example C:\Users\ADMIN~1 --> C:\Users\Administrator.
// It is a no-op on non-Windows platforms
func GetLongPathName(path string) (string, error) {
return path, nil
}
24 changes: 24 additions & 0 deletions pkg/system/path_windows.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package system // import "github.com/docker/docker/pkg/system"

import "syscall"

// GetLongPathName converts Windows short pathnames to full pathnames.
// For example C:\Users\ADMIN~1 --> C:\Users\Administrator.
// It is a no-op on non-Windows platforms
func GetLongPathName(path string) (string, error) {
// See https://groups.google.com/forum/#!topic/golang-dev/1tufzkruoTg
p := syscall.StringToUTF16(path)
b := p // GetLongPathName says we can reuse buffer
n, err := syscall.GetLongPathName(&p[0], &b[0], uint32(len(b)))
if err != nil {
return "", err
}
if n > uint32(len(b)) {
b = make([]uint16, n)
_, err = syscall.GetLongPathName(&p[0], &b[0], uint32(len(b)))
if err != nil {
return "", err
}
}
return syscall.UTF16ToString(b), nil
}

0 comments on commit 7aa797f

Please sign in to comment.