Skip to content

Commit

Permalink
paths: do not include directories in formatting (#64)
Browse files Browse the repository at this point in the history
If a directory was named such that it matched the include pattern (in
most circumstances, if it was named ending in `.yml`/`.yaml`) then
yamlfmt would try to read it and format it which would fail because it's
a directory. This PR adds a stat check to ignore all directories. Also
adds tests for this package which did not previously exist.

Signed-off-by: braydonk <braydonk@google.com>

Signed-off-by: braydonk <braydonk@google.com>
  • Loading branch information
braydonk authored Nov 1, 2022
1 parent c31ff16 commit 811c650
Show file tree
Hide file tree
Showing 2 changed files with 144 additions and 0 deletions.
6 changes: 6 additions & 0 deletions internal/paths/paths.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@
package paths

import (
"os"

"github.com/bmatcuk/doublestar/v4"
)

Expand Down Expand Up @@ -50,6 +52,10 @@ func CollectPathsToFormat(include, exclude []string) ([]string, error) {
}
pathsToFormat := []string{}
for path := range pathsToFormatSet {
info, err := os.Stat(path)
if err != nil || info.IsDir() {
continue
}
pathsToFormat = append(pathsToFormat, path)
}
return pathsToFormat, nil
Expand Down
138 changes: 138 additions & 0 deletions internal/paths/paths_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
package paths_test

import (
"fmt"
"os"
"path/filepath"
"reflect"
"testing"

"github.com/google/yamlfmt/internal/paths"
)

type dummyPath struct {
path string
filename string
isDir bool
}

func (p *dummyPath) Create() error {
file := p.fullPath()
var err error
if p.isDir {
err = os.Mkdir(file, 0x0700)
} else {
err = os.WriteFile(file, []byte{}, 0x0700)
}
return err
}

func (p *dummyPath) fullPath() string {
return filepath.Join(p.path, p.filename)
}

func TestCollectPathsToFormat(t *testing.T) {
testCases := []struct {
name string
files []dummyPath
includePatterns []string
excludePatterns []string
expectedFiles map[string]struct{}
}{
{
name: "no excludes",
files: []dummyPath{
{filename: "x.yaml"},
{filename: "y.yaml"},
{filename: "z.yaml"},
},
expectedFiles: map[string]struct{}{
"x.yaml": {},
"y.yaml": {},
"z.yaml": {},
},
},
{
name: "does not include directories",
files: []dummyPath{
{filename: "x.yaml"},
{filename: "y", isDir: true},
},
expectedFiles: map[string]struct{}{
"x.yaml": {},
},
},
{
name: "only include what is asked",
files: []dummyPath{
{filename: "x.yaml"},
{filename: "y.yaml"},
},
includePatterns: []string{
"y.yaml",
},
expectedFiles: map[string]struct{}{
"y.yaml": {},
},
},
{
name: "exclude what is asked",
files: []dummyPath{
{filename: "x.yaml"},
{filename: "y.yaml"},
},
excludePatterns: []string{
"y.yaml",
},
expectedFiles: map[string]struct{}{
"x.yaml": {},
},
},
}

for _, tc := range testCases {
tc := tc
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
tempPath := t.TempDir()

for _, file := range tc.files {
file.path = tempPath
if err := file.Create(); err != nil {
t.Fatalf("Failed to create file")
}
}

includePaths := formatTempPaths(tempPath, tc.includePatterns)
if len(includePaths) == 0 {
includePaths = []string{fmt.Sprintf("%s/**", tempPath)}
}
excludePaths := formatTempPaths(tempPath, tc.excludePatterns)
if len(excludePaths) == 0 {
excludePaths = []string{}
}

paths, err := paths.CollectPathsToFormat(includePaths, excludePaths)
if err != nil {
t.Fatalf("CollectPathsToFormat failed: %v", err)
}

filesToFormat := map[string]struct{}{}
for _, path := range paths {
_, filename := filepath.Split(path)
filesToFormat[filename] = struct{}{}
}
if !reflect.DeepEqual(filesToFormat, tc.expectedFiles) {
t.Fatalf("Expected to receive paths %v but got %v", tc.expectedFiles, filesToFormat)
}
})
}
}

func formatTempPaths(tempPath string, patterns []string) []string {
formatted := make([]string, len(patterns))
for i, pattern := range patterns {
formatted[i] = fmt.Sprintf("%s/%s", tempPath, pattern)
}
return formatted
}

0 comments on commit 811c650

Please sign in to comment.