mirror of
https://github.com/anchore/syft.git
synced 2025-11-18 00:43:20 +01:00
195 lines
4.3 KiB
Go
195 lines
4.3 KiB
Go
package cyclonedx
|
|
|
|
import (
|
|
"bytes"
|
|
"flag"
|
|
"regexp"
|
|
"testing"
|
|
|
|
"github.com/anchore/stereoscope/pkg/imagetest"
|
|
"github.com/anchore/syft/syft/distro"
|
|
|
|
"github.com/anchore/go-testutils"
|
|
"github.com/anchore/stereoscope/pkg/file"
|
|
"github.com/anchore/syft/syft/pkg"
|
|
"github.com/anchore/syft/syft/source"
|
|
"github.com/sergi/go-diff/diffmatchpatch"
|
|
)
|
|
|
|
var update = flag.Bool("update", false, "update the *.golden files for json presenters")
|
|
|
|
func TestCycloneDxDirsPresenter(t *testing.T) {
|
|
var buffer bytes.Buffer
|
|
|
|
catalog := pkg.NewCatalog()
|
|
|
|
// populate catalog with test data
|
|
catalog.Add(pkg.Package{
|
|
Name: "package1",
|
|
Version: "1.0.1",
|
|
Type: pkg.DebPkg,
|
|
FoundBy: "the-cataloger-1",
|
|
Source: []file.Reference{
|
|
{Path: "/some/path/pkg1"},
|
|
},
|
|
Metadata: pkg.DpkgMetadata{
|
|
Package: "package1",
|
|
Version: "1.0.1",
|
|
Architecture: "amd64",
|
|
},
|
|
})
|
|
catalog.Add(pkg.Package{
|
|
Name: "package2",
|
|
Version: "2.0.1",
|
|
Type: pkg.DebPkg,
|
|
FoundBy: "the-cataloger-2",
|
|
Source: []file.Reference{
|
|
{Path: "/some/path/pkg1"},
|
|
},
|
|
Licenses: []string{
|
|
"MIT",
|
|
"Apache-v2",
|
|
},
|
|
Metadata: pkg.DpkgMetadata{
|
|
Package: "package2",
|
|
Version: "1.0.2",
|
|
Architecture: "amd64",
|
|
},
|
|
})
|
|
|
|
s, err := source.NewFromDirectory("/some/path")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
d, err := distro.NewDistro(distro.Ubuntu, "20.04", "debian")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
pres := NewPresenter(catalog, s, d)
|
|
|
|
// run presenter
|
|
err = pres.Present(&buffer)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
actual := buffer.Bytes()
|
|
|
|
if *update {
|
|
testutils.UpdateGoldenFileContents(t, actual)
|
|
}
|
|
|
|
var expected = testutils.GetGoldenFileContents(t)
|
|
|
|
// remove dynamic values, which are tested independently
|
|
actual = redact(actual)
|
|
expected = redact(expected)
|
|
|
|
if !bytes.Equal(expected, actual) {
|
|
dmp := diffmatchpatch.New()
|
|
diffs := dmp.DiffMain(string(actual), string(expected), true)
|
|
t.Errorf("mismatched output:\n%s", dmp.DiffPrettyText(diffs))
|
|
}
|
|
|
|
}
|
|
|
|
func TestCycloneDxImgsPresenter(t *testing.T) {
|
|
var buffer bytes.Buffer
|
|
|
|
catalog := pkg.NewCatalog()
|
|
img, cleanup := imagetest.GetFixtureImage(t, "docker-archive", "image-simple")
|
|
defer cleanup()
|
|
|
|
// populate catalog with test data
|
|
catalog.Add(pkg.Package{
|
|
Name: "package1",
|
|
Version: "1.0.1",
|
|
Source: []file.Reference{
|
|
*img.SquashedTree().File("/somefile-1.txt"),
|
|
},
|
|
Type: pkg.RpmPkg,
|
|
FoundBy: "the-cataloger-1",
|
|
Metadata: pkg.RpmdbMetadata{
|
|
Name: "package1",
|
|
Epoch: 0,
|
|
Arch: "x86_64",
|
|
Release: "1",
|
|
Version: "1.0.1",
|
|
SourceRpm: "package1-1.0.1-1.src.rpm",
|
|
Size: 12406784,
|
|
License: "MIT",
|
|
Vendor: "",
|
|
},
|
|
})
|
|
catalog.Add(pkg.Package{
|
|
Name: "package2",
|
|
Version: "2.0.1",
|
|
Source: []file.Reference{
|
|
*img.SquashedTree().File("/somefile-2.txt"),
|
|
},
|
|
Type: pkg.RpmPkg,
|
|
FoundBy: "the-cataloger-2",
|
|
Licenses: []string{
|
|
"MIT",
|
|
"Apache-v2",
|
|
},
|
|
Metadata: pkg.RpmdbMetadata{
|
|
Name: "package2",
|
|
Epoch: 0,
|
|
Arch: "x86_64",
|
|
Release: "1",
|
|
Version: "1.0.2",
|
|
SourceRpm: "package2-1.0.2-1.src.rpm",
|
|
Size: 12406784,
|
|
License: "MIT",
|
|
Vendor: "",
|
|
},
|
|
})
|
|
|
|
s, err := source.NewFromImage(img, source.AllLayersScope)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
d, err := distro.NewDistro(distro.RedHat, "8", "")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
pres := NewPresenter(catalog, s, d)
|
|
|
|
// run presenter
|
|
err = pres.Present(&buffer)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
actual := buffer.Bytes()
|
|
|
|
if *update {
|
|
testutils.UpdateGoldenFileContents(t, actual)
|
|
}
|
|
|
|
var expected = testutils.GetGoldenFileContents(t)
|
|
|
|
// remove dynamic values, which are tested independently
|
|
actual = redact(actual)
|
|
expected = redact(expected)
|
|
|
|
if !bytes.Equal(expected, actual) {
|
|
dmp := diffmatchpatch.New()
|
|
diffs := dmp.DiffMain(string(actual), string(expected), true)
|
|
t.Errorf("mismatched output:\n%s", dmp.DiffPrettyText(diffs))
|
|
}
|
|
}
|
|
|
|
func redact(s []byte) []byte {
|
|
serialPattern := regexp.MustCompile(`serialNumber="[a-zA-Z0-9\-:]+"`)
|
|
rfc3339Pattern := regexp.MustCompile(`([0-9]+)-(0[1-9]|1[012])-(0[1-9]|[12][0-9]|3[01])[Tt]([01][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9]|60)(\.[0-9]+)?(([Zz])|([\+|\-]([01][0-9]|2[0-3]):[0-5][0-9]))`)
|
|
|
|
for _, pattern := range []*regexp.Regexp{serialPattern, rfc3339Pattern} {
|
|
s = pattern.ReplaceAll(s, []byte("redacted"))
|
|
}
|
|
return s
|
|
}
|