mirror of
https://github.com/anchore/syft
synced 2024-11-13 23:57:07 +00:00
7018573bf7
* remove internal string set Signed-off-by: Alex Goodman <wagoodman@users.noreply.github.com> * incorporate changes from #2227 Signed-off-by: Alex Goodman <wagoodman@users.noreply.github.com> * beef up the pkg.License.Merg() doc string Signed-off-by: Alex Goodman <wagoodman@users.noreply.github.com> --------- Signed-off-by: Alex Goodman <wagoodman@users.noreply.github.com>
55 lines
2 KiB
Go
55 lines
2 KiB
Go
package integration
|
|
|
|
import (
|
|
"reflect"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/scylladb/go-set/strset"
|
|
|
|
"github.com/anchore/syft/syft/pkg"
|
|
)
|
|
|
|
func TestNpmPackageLockDirectory(t *testing.T) {
|
|
sbom, _ := catalogDirectory(t, "test-fixtures/npm-lock")
|
|
|
|
foundPackages := strset.New()
|
|
|
|
for actualPkg := range sbom.Artifacts.Packages.Enumerate(pkg.NpmPkg) {
|
|
for _, actualLocation := range actualPkg.Locations.ToSlice() {
|
|
if strings.Contains(actualLocation.RealPath, "node_modules") {
|
|
t.Errorf("found packages from package-lock.json in node_modules: %s", actualLocation)
|
|
}
|
|
}
|
|
foundPackages.Add(actualPkg.Name)
|
|
}
|
|
|
|
// ensure that integration test commonTestCases stay in sync with the available catalogers
|
|
const expectedPackageCount = 6
|
|
if foundPackages.Size() != expectedPackageCount {
|
|
t.Errorf("found the wrong set of npm package-lock.json packages (expected: %d, actual: %d)", expectedPackageCount, foundPackages.Size())
|
|
}
|
|
}
|
|
|
|
func TestYarnPackageLockDirectory(t *testing.T) {
|
|
sbom, _ := catalogDirectory(t, "test-fixtures/yarn-lock")
|
|
|
|
foundPackages := strset.New()
|
|
expectedPackages := strset.New("async@0.9.2", "async@3.2.3", "merge-objects@1.0.5", "should-type@1.3.0", "@4lolo/resize-observer-polyfill@1.5.2")
|
|
|
|
for actualPkg := range sbom.Artifacts.Packages.Enumerate(pkg.NpmPkg) {
|
|
for _, actualLocation := range actualPkg.Locations.ToSlice() {
|
|
if strings.Contains(actualLocation.RealPath, "node_modules") {
|
|
t.Errorf("found packages from yarn.lock in node_modules: %s", actualLocation)
|
|
}
|
|
}
|
|
foundPackages.Add(actualPkg.Name + "@" + actualPkg.Version)
|
|
}
|
|
|
|
// ensure that integration test commonTestCases stay in sync with the available catalogers
|
|
if foundPackages.Size() != expectedPackages.Size() {
|
|
t.Errorf("found the wrong set of yarn.lock packages (expected: %d, actual: %d)", expectedPackages.Size(), foundPackages.Size())
|
|
} else if !reflect.DeepEqual(foundPackages, expectedPackages) {
|
|
t.Errorf("found the wrong set of yarn.lock packages (expected: %+q, actual: %+q)", expectedPackages.List(), foundPackages.List())
|
|
}
|
|
}
|