mirror of
https://github.com/aquasecurity/trivy.git
synced 2025-12-22 15:16:33 -08:00
Signed-off-by: knqyf263 <knqyf263@gmail.com> Co-authored-by: DmitriyLewen <91113035+DmitriyLewen@users.noreply.github.com> Co-authored-by: DmitriyLewen <dmitriy.lewen@smartforce.io>
75 lines
1.5 KiB
Go
75 lines
1.5 KiB
Go
package lock
|
|
|
|
import (
|
|
"os"
|
|
"path"
|
|
"sort"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
ftypes "github.com/aquasecurity/trivy/pkg/fanal/types"
|
|
)
|
|
|
|
func TestParse(t *testing.T) {
|
|
vectors := []struct {
|
|
file string // Test input file
|
|
want []ftypes.Package
|
|
wantDeps []ftypes.Dependency
|
|
}{
|
|
{
|
|
file: "testdata/packages_lock_simple.json",
|
|
want: nuGetSimple,
|
|
wantDeps: nuGetSimpleDeps,
|
|
},
|
|
{
|
|
file: "testdata/packages_lock_subdependencies.json",
|
|
want: nuGetSubDependencies,
|
|
wantDeps: nuGetSubDependenciesDeps,
|
|
},
|
|
{
|
|
file: "testdata/packages_lock_multi.json",
|
|
want: nuGetMultiTarget,
|
|
wantDeps: nuGetMultiTargetDeps,
|
|
},
|
|
{
|
|
file: "testdata/packages_lock_legacy.json",
|
|
want: nuGetLegacy,
|
|
wantDeps: nuGetLegacyDeps,
|
|
},
|
|
}
|
|
|
|
for _, v := range vectors {
|
|
t.Run(path.Base(v.file), func(t *testing.T) {
|
|
f, err := os.Open(v.file)
|
|
require.NoError(t, err)
|
|
|
|
got, deps, err := NewParser().Parse(f)
|
|
require.NoError(t, err)
|
|
|
|
sort.Sort(ftypes.Packages(got))
|
|
sort.Sort(ftypes.Packages(v.want))
|
|
|
|
assert.Equal(t, v.want, got)
|
|
|
|
if v.wantDeps != nil {
|
|
sortDeps(deps)
|
|
sortDeps(v.wantDeps)
|
|
assert.Equal(t, v.wantDeps, deps)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func sortDeps(deps []ftypes.Dependency) {
|
|
sort.Slice(deps, func(i, j int) bool {
|
|
return strings.Compare(deps[i].ID, deps[j].ID) < 0
|
|
})
|
|
|
|
for i := range deps {
|
|
sort.Strings(deps[i].DependsOn)
|
|
}
|
|
}
|