aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlex Brainman <alex.brainman@gmail.com>2017-04-04 17:09:17 +1000
committerAlex Brainman <alex.brainman@gmail.com>2017-04-25 03:04:46 +0000
commitcf3a28124b199d15b7e968327ba07d45f2f24a88 (patch)
tree5b2b953e8df6df2cb63f42a26c0ca1806034b2b4 /src
parent4ee934ad27dcd2fb0c28798cb329841a2a444fb1 (diff)
downloadgo-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.go43
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")