357afc54d8
* initial commit * chore(mod): update * test(gemnasium): add tests * feat(main): add target * change(GitLab Advisories Database) gemnasium to advisories community * fix(GitLab Advisory Database) Identifer to upper case * test(GitLab Advisory Database) add lower case identifer test * fix(GitLab Advisory Database) no newline at end of file * fix(GitLab Advisory Database) fix test use JSONEq * fix(GitLab Advisory Database) fix clone community advisory branch name * change(git) CloneOrPull use default branch * refactor(glad) Co-authored-by: masahiro331 <mur4m4s4.331@gmail.com>
91 lines
1.9 KiB
Go
91 lines
1.9 KiB
Go
package glad
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/spf13/afero"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var update = flag.Bool("update", false, "update golden files")
|
|
|
|
func TestUpdater_WalkDir(t *testing.T) {
|
|
testCases := []struct {
|
|
name string
|
|
appFs afero.Fs
|
|
rootDir string
|
|
wantFileCount int
|
|
wantErr string
|
|
}{
|
|
{
|
|
name: "happy path",
|
|
rootDir: "testdata/happy",
|
|
wantFileCount: 4,
|
|
},
|
|
{
|
|
name: "sad path",
|
|
rootDir: "testdata/sad",
|
|
wantErr: "yaml: unmarshal errors",
|
|
},
|
|
}
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
base := afero.NewOsFs()
|
|
roBase := afero.NewReadOnlyFs(base)
|
|
ufs := afero.NewCopyOnWriteFs(roBase, afero.NewMemMapFs())
|
|
|
|
c := Updater{
|
|
vulnListDir: "./tmp",
|
|
cacheDir: "./cache",
|
|
appFs: ufs,
|
|
}
|
|
|
|
err := c.walkDir(tc.rootDir)
|
|
if tc.wantErr != "" {
|
|
require.NotNil(t, err)
|
|
assert.Contains(t, err.Error(), tc.wantErr, tc.name)
|
|
return
|
|
}
|
|
assert.NoError(t, err)
|
|
|
|
fileCount := 0
|
|
err = afero.Walk(c.appFs, "./tmp", func(path string, info os.FileInfo, err error) error {
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if info.IsDir() {
|
|
return nil
|
|
}
|
|
fileCount += 1
|
|
|
|
got, err := afero.ReadFile(c.appFs, path)
|
|
assert.NoError(t, err, path)
|
|
|
|
relPath, err := filepath.Rel(c.vulnListDir, path)
|
|
require.NoError(t, err, path)
|
|
|
|
goldenPath := filepath.Join("testdata", "golden", relPath)
|
|
if *update {
|
|
fmt.Println(goldenPath)
|
|
err = ioutil.WriteFile(goldenPath, got, 0666)
|
|
assert.NoError(t, err, tc.name)
|
|
}
|
|
|
|
want, err := ioutil.ReadFile(goldenPath)
|
|
assert.NoError(t, err, goldenPath)
|
|
|
|
assert.JSONEq(t, string(want), string(got), tc.name)
|
|
|
|
return nil
|
|
})
|
|
assert.Equal(t, tc.wantFileCount, fileCount)
|
|
assert.NoError(t, err, tc.name)
|
|
})
|
|
}
|
|
} |