diff options
| author | Alex Brainman <alex.brainman@gmail.com> | 2017-04-04 17:09:17 +1000 |
|---|---|---|
| committer | Alex Brainman <alex.brainman@gmail.com> | 2017-04-25 03:04:46 +0000 |
| commit | cf3a28124b199d15b7e968327ba07d45f2f24a88 (patch) | |
| tree | 5b2b953e8df6df2cb63f42a26c0ca1806034b2b4 /src | |
| parent | 4ee934ad27dcd2fb0c28798cb329841a2a444fb1 (diff) | |
| download | go-cf3a28124b199d15b7e968327ba07d45f2f24a88.tar.xz | |
archive/tar: extend TestFileInfoHeaderSymlink
For #17541.
Change-Id: I524ab194f32b8b061ce1c9c3e0cd34cc5539358e
Reviewed-on: https://go-review.googlesource.com/39410
Run-TryBot: Alex Brainman <alex.brainman@gmail.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
Diffstat (limited to 'src')
| -rw-r--r-- | src/archive/tar/tar_test.go | 43 |
1 files changed, 31 insertions, 12 deletions
diff --git a/src/archive/tar/tar_test.go b/src/archive/tar/tar_test.go index 1b211f8bd2..10a16dd5d0 100644 --- a/src/archive/tar/tar_test.go +++ b/src/archive/tar/tar_test.go @@ -6,10 +6,13 @@ package tar import ( "bytes" + "internal/testenv" "io/ioutil" "os" "path" + "path/filepath" "reflect" + "runtime" "strings" "testing" "time" @@ -67,27 +70,43 @@ func TestFileInfoHeaderDir(t *testing.T) { } func TestFileInfoHeaderSymlink(t *testing.T) { - h, err := FileInfoHeader(symlink{}, "some-target") + testenv.MustHaveSymlink(t) + + if runtime.GOOS == "windows" { + t.Skip("skipping broken test: see issue 17541") + } + tmpdir, err := ioutil.TempDir("", "TestFileInfoHeaderSymlink") + if err != nil { + t.Fatal(err) + } + defer os.RemoveAll(tmpdir) + + link := filepath.Join(tmpdir, "link") + target := tmpdir + err = os.Symlink(target, link) + if err != nil { + t.Fatal(err) + } + fi, err := os.Lstat(link) + if err != nil { + t.Fatal(err) + } + + h, err := FileInfoHeader(fi, target) if err != nil { t.Fatal(err) } - if g, e := h.Name, "some-symlink"; g != e { + if g, e := h.Name, fi.Name(); g != e { t.Errorf("Name = %q; want %q", g, e) } - if g, e := h.Linkname, "some-target"; g != e { + if g, e := h.Linkname, target; g != e { t.Errorf("Linkname = %q; want %q", g, e) } + if g, e := h.Typeflag, byte(TypeSymlink); g != e { + t.Errorf("Typeflag = %v; want %v", g, e) + } } -type symlink struct{} - -func (symlink) Name() string { return "some-symlink" } -func (symlink) Size() int64 { return 0 } -func (symlink) Mode() os.FileMode { return os.ModeSymlink } -func (symlink) ModTime() time.Time { return time.Time{} } -func (symlink) IsDir() bool { return false } -func (symlink) Sys() interface{} { return nil } - func TestRoundTrip(t *testing.T) { data := []byte("some file contents") |
