123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- // +build windows
- package archive
- import (
- "io/ioutil"
- "os"
- "path/filepath"
- "testing"
- )
- func TestCopyFileWithInvalidDest(t *testing.T) {
- // TODO Windows: This is currently failing. Not sure what has
- // recently changed in CopyWithTar as used to pass. Further investigation
- // is required.
- t.Skip("Currently fails")
- folder, err := ioutil.TempDir("", "docker-archive-test")
- if err != nil {
- t.Fatal(err)
- }
- defer os.RemoveAll(folder)
- dest := "c:dest"
- srcFolder := filepath.Join(folder, "src")
- src := filepath.Join(folder, "src", "src")
- err = os.MkdirAll(srcFolder, 0740)
- if err != nil {
- t.Fatal(err)
- }
- ioutil.WriteFile(src, []byte("content"), 0777)
- err = CopyWithTar(src, dest)
- if err == nil {
- t.Fatalf("archiver.CopyWithTar should throw an error on invalid dest.")
- }
- }
- func TestCanonicalTarNameForPath(t *testing.T) {
- cases := []struct {
- in, expected string
- shouldFail bool
- }{
- {"foo", "foo", false},
- {"foo/bar", "___", true}, // unix-styled windows path must fail
- {`foo\bar`, "foo/bar", false},
- }
- for _, v := range cases {
- if out, err := CanonicalTarNameForPath(v.in); err != nil && !v.shouldFail {
- t.Fatalf("cannot get canonical name for path: %s: %v", v.in, err)
- } else if v.shouldFail && err == nil {
- t.Fatalf("canonical path call should have failed with error. in=%s out=%s", v.in, out)
- } else if !v.shouldFail && out != v.expected {
- t.Fatalf("wrong canonical tar name. expected:%s got:%s", v.expected, out)
- }
- }
- }
- func TestCanonicalTarName(t *testing.T) {
- cases := []struct {
- in string
- isDir bool
- expected string
- }{
- {"foo", false, "foo"},
- {"foo", true, "foo/"},
- {`foo\bar`, false, "foo/bar"},
- {`foo\bar`, true, "foo/bar/"},
- }
- for _, v := range cases {
- if out, err := canonicalTarName(v.in, v.isDir); err != nil {
- t.Fatalf("cannot get canonical name for path: %s: %v", v.in, err)
- } else if out != v.expected {
- t.Fatalf("wrong canonical tar name. expected:%s got:%s", v.expected, out)
- }
- }
- }
- func TestChmodTarEntry(t *testing.T) {
- cases := []struct {
- in, expected os.FileMode
- }{
- {0000, 0111},
- {0777, 0755},
- {0644, 0755},
- {0755, 0755},
- {0444, 0555},
- {0755 | os.ModeDir, 0755 | os.ModeDir},
- {0755 | os.ModeSymlink, 0755 | os.ModeSymlink},
- }
- for _, v := range cases {
- if out := chmodTarEntry(v.in); out != v.expected {
- t.Fatalf("wrong chmod. expected:%v got:%v", v.expected, out)
- }
- }
- }
|