Skip to content

Commit

Permalink
Allow underscores at the start of directories in file backend.
Browse files Browse the repository at this point in the history
Fixes #3476
  • Loading branch information
jefferai committed Oct 19, 2017
1 parent 07ea7ba commit ca1e9fd
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 3 deletions.
12 changes: 9 additions & 3 deletions physical/file/file.go
Original file line number Diff line number Diff line change
Expand Up @@ -247,10 +247,16 @@ func (b *FileBackend) ListInternal(prefix string) ([]string, error) {
}

for i, name := range names {
if name[0] == '_' {
names[i] = name[1:]
} else {
fi, err := os.Stat(filepath.Join(path, name))
if err != nil {
return nil, err
}
if fi.IsDir() {
names[i] = name + "/"
} else {
if name[0] == '_' {
names[i] = name[1:]
}
}
}

Expand Down
39 changes: 39 additions & 0 deletions physical/testing.go
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,45 @@ func ExerciseBackend(t *testing.T, b Backend) {
if len(keys) != 0 {
t.Fatalf("bad: %v", keys)
}

// Underscores should not trip things up; ref GH-3476
e = &Entry{Key: "_zip/_zap", Value: []byte("foobar")}
err = b.Put(e)
if err != nil {
t.Fatalf("err: %v", err)
}
e, err = b.Get("_zip/_zap")
if err != nil {
t.Fatalf("err: %v", err)
}
if e == nil {
t.Fatal("got nil entry")
}
vals, err := b.List("")
if err != nil {
t.Fatal(err)
}
if len(vals) != 1 || vals[0] != "_zip/" {
t.Fatalf("bad: %v", vals)
}
vals, err = b.List("_zip/")
if err != nil {
t.Fatal(err)
}
if len(vals) != 1 || vals[0] != "_zap" {
t.Fatalf("bad: %v", vals)
}
err = b.Delete("_zip/_zap")
if err != nil {
t.Fatal(err)
}
vals, err = b.List("")
if err != nil {
t.Fatal(err)
}
if len(vals) != 0 {
t.Fatalf("bad: %v", vals)
}
}

func ExerciseBackend_ListPrefix(t *testing.T, b Backend) {
Expand Down

0 comments on commit ca1e9fd

Please sign in to comment.