mirror of
https://github.com/anchore/syft.git
synced 2025-11-17 16:33:21 +01:00
* migrate pkg.ID and pkg.Relationship to artifact package Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * return relationships from tasks Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * fix more tests Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add artifact.Identifiable by Identity() method Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * fix linting Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * remove catalog ID assignment Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * adjust spdx helpers to use copy of packages Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * stabilize package ID relative to encode-decode format cycles Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * rename Identity() to ID() Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * use zero value for nils in ID generation Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * enable source.Location to be identifiable Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * hoist up package relationship discovery to analysis stage Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * update ownership-by-file-overlap relationship description Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add test reminders to put new relationships under test Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * adjust PHP composer.lock parser function to return relationships Signed-off-by: Alex Goodman <alex.goodman@anchore.com>
115 lines
2.1 KiB
Go
115 lines
2.1 KiB
Go
package spdxhelpers
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/anchore/syft/syft/pkg"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func Test_Originator(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
input pkg.Package
|
|
expected string
|
|
}{
|
|
{
|
|
// note: since this is an optional field, no value is preferred over NONE or NOASSERTION
|
|
name: "no metadata",
|
|
input: pkg.Package{},
|
|
expected: "",
|
|
},
|
|
{
|
|
name: "from gem",
|
|
input: pkg.Package{
|
|
Metadata: pkg.GemMetadata{
|
|
Authors: []string{
|
|
"auth1",
|
|
"auth2",
|
|
},
|
|
},
|
|
},
|
|
expected: "auth1",
|
|
},
|
|
{
|
|
name: "from npm",
|
|
input: pkg.Package{
|
|
Metadata: pkg.NpmPackageJSONMetadata{
|
|
Author: "auth",
|
|
},
|
|
},
|
|
expected: "auth",
|
|
},
|
|
{
|
|
name: "from apk",
|
|
input: pkg.Package{
|
|
Metadata: pkg.ApkMetadata{
|
|
Maintainer: "auth",
|
|
},
|
|
},
|
|
expected: "auth",
|
|
},
|
|
{
|
|
name: "from python - just name",
|
|
input: pkg.Package{
|
|
Metadata: pkg.PythonPackageMetadata{
|
|
Author: "auth",
|
|
},
|
|
},
|
|
expected: "auth",
|
|
},
|
|
{
|
|
name: "from python - just email",
|
|
input: pkg.Package{
|
|
Metadata: pkg.PythonPackageMetadata{
|
|
AuthorEmail: "auth@auth.gov",
|
|
},
|
|
},
|
|
expected: "auth@auth.gov",
|
|
},
|
|
{
|
|
name: "from python - both name and email",
|
|
input: pkg.Package{
|
|
Metadata: pkg.PythonPackageMetadata{
|
|
Author: "auth",
|
|
AuthorEmail: "auth@auth.gov",
|
|
},
|
|
},
|
|
expected: "auth <auth@auth.gov>",
|
|
},
|
|
{
|
|
name: "from rpm",
|
|
input: pkg.Package{
|
|
Metadata: pkg.RpmdbMetadata{
|
|
Vendor: "auth",
|
|
},
|
|
},
|
|
expected: "auth",
|
|
},
|
|
{
|
|
name: "from dpkg",
|
|
input: pkg.Package{
|
|
Metadata: pkg.DpkgMetadata{
|
|
Maintainer: "auth",
|
|
},
|
|
},
|
|
expected: "auth",
|
|
},
|
|
{
|
|
// note: since this is an optional field, no value is preferred over NONE or NOASSERTION
|
|
name: "empty",
|
|
input: pkg.Package{
|
|
Metadata: pkg.NpmPackageJSONMetadata{
|
|
Author: "",
|
|
},
|
|
},
|
|
expected: "",
|
|
},
|
|
}
|
|
for _, test := range tests {
|
|
t.Run(test.name, func(t *testing.T) {
|
|
assert.Equal(t, test.expected, Originator(test.input))
|
|
})
|
|
}
|
|
}
|