aboutsummaryrefslogtreecommitdiff
path: root/builder/builder2v1
diff options
context:
space:
mode:
authorSteve Winslow <steve@swinslow.net>2020-05-10 11:53:35 -0400
committerSteve Winslow <steve@swinslow.net>2020-05-10 11:53:35 -0400
commit458285e4e88c92e6bb8b61afad0e66fb0a051f95 (patch)
treeb3e4b220a11f4b2a95257fbdb0a2eaecede44555 /builder/builder2v1
parentacc6f35a32e34bdb94c30eb83cb97fcec1b0858d (diff)
downloadspdx-tools-458285e4e88c92e6bb8b61afad0e66fb0a051f95.tar.gz
Refactor builder to handler element ID maps
Signed-off-by: Steve Winslow <steve@swinslow.net>
Diffstat (limited to 'builder/builder2v1')
-rw-r--r--builder/builder2v1/build_creation_info.go2
-rw-r--r--builder/builder2v1/build_creation_info_test.go6
-rw-r--r--builder/builder2v1/build_file.go4
-rw-r--r--builder/builder2v1/build_file_test.go6
-rw-r--r--builder/builder2v1/build_package.go6
-rw-r--r--builder/builder2v1/build_package_test.go22
-rw-r--r--builder/builder2v1/build_relationship.go4
-rw-r--r--builder/builder2v1/build_relationship_test.go10
8 files changed, 34 insertions, 26 deletions
diff --git a/builder/builder2v1/build_creation_info.go b/builder/builder2v1/build_creation_info.go
index 3a01528..1d8c77f 100644
--- a/builder/builder2v1/build_creation_info.go
+++ b/builder/builder2v1/build_creation_info.go
@@ -47,7 +47,7 @@ func BuildCreationInfoSection2_1(packageName string, code string, namespacePrefi
ci := &spdx.CreationInfo2_1{
SPDXVersion: "SPDX-2.1",
DataLicense: "CC0-1.0",
- SPDXIdentifier: "SPDXRef-DOCUMENT",
+ SPDXIdentifier: spdx.ElementID("DOCUMENT"),
DocumentName: packageName,
DocumentNamespace: fmt.Sprintf("%s%s-%s", namespacePrefix, packageName, code),
CreatorPersons: cPersons,
diff --git a/builder/builder2v1/build_creation_info_test.go b/builder/builder2v1/build_creation_info_test.go
index 3cdfe83..b45f2f0 100644
--- a/builder/builder2v1/build_creation_info_test.go
+++ b/builder/builder2v1/build_creation_info_test.go
@@ -5,6 +5,8 @@ package builder2v1
import (
"fmt"
"testing"
+
+ "github.com/spdx/tools-golang/spdx"
)
// ===== CreationInfo section builder tests =====
@@ -32,8 +34,8 @@ func TestBuilder2_1CanBuildCreationInfoSection(t *testing.T) {
if ci.DataLicense != "CC0-1.0" {
t.Errorf("expected %s, got %s", "CC0-1.0", ci.DataLicense)
}
- if ci.SPDXIdentifier != "SPDXRef-DOCUMENT" {
- t.Errorf("expected %s, got %s", "SPDXRef-DOCUMENT", ci.SPDXIdentifier)
+ if ci.SPDXIdentifier != spdx.ElementID("DOCUMENT") {
+ t.Errorf("expected %s, got %v", "DOCUMENT", ci.SPDXIdentifier)
}
if ci.DocumentName != "project1" {
t.Errorf("expected %s, got %s", "project1", ci.DocumentName)
diff --git a/builder/builder2v1/build_file.go b/builder/builder2v1/build_file.go
index c7cc6be..28bb555 100644
--- a/builder/builder2v1/build_file.go
+++ b/builder/builder2v1/build_file.go
@@ -26,12 +26,12 @@ func BuildFileSection2_1(filePath string, prefix string, fileNumber int) (*spdx.
}
// build the identifier
- i := fmt.Sprintf("SPDXRef-File%d", fileNumber)
+ i := fmt.Sprintf("File%d", fileNumber)
// now build the File section
f := &spdx.File2_1{
FileName: filePath,
- FileSPDXIdentifier: i,
+ FileSPDXIdentifier: spdx.ElementID(i),
FileChecksumSHA1: ssha1,
FileChecksumSHA256: ssha256,
FileChecksumMD5: smd5,
diff --git a/builder/builder2v1/build_file_test.go b/builder/builder2v1/build_file_test.go
index 66816ba..1bdafd3 100644
--- a/builder/builder2v1/build_file_test.go
+++ b/builder/builder2v1/build_file_test.go
@@ -4,6 +4,8 @@ package builder2v1
import (
"testing"
+
+ "github.com/spdx/tools-golang/spdx"
)
// ===== File section builder tests =====
@@ -23,8 +25,8 @@ func TestBuilder2_1CanBuildFileSection(t *testing.T) {
if file1.FileName != "/file1.testdata.txt" {
t.Errorf("expected %v, got %v", "/file1.testdata.txt", file1.FileName)
}
- if file1.FileSPDXIdentifier != "SPDXRef-File17" {
- t.Errorf("expected %v, got %v", "SPDXRef-File17", file1.FileSPDXIdentifier)
+ if file1.FileSPDXIdentifier != spdx.ElementID("File17") {
+ t.Errorf("expected %v, got %v", "File17", file1.FileSPDXIdentifier)
}
if file1.FileChecksumSHA1 != "024f870eb6323f532515f7a09d5646a97083b819" {
t.Errorf("expected %v, got %v", "024f870eb6323f532515f7a09d5646a97083b819", file1.FileChecksumSHA1)
diff --git a/builder/builder2v1/build_package.go b/builder/builder2v1/build_package.go
index 3cefe5c..1dd66b6 100644
--- a/builder/builder2v1/build_package.go
+++ b/builder/builder2v1/build_package.go
@@ -22,14 +22,14 @@ func BuildPackageSection2_1(packageName string, dirRoot string, pathsIgnore []st
return nil, err
}
- files := []*spdx.File2_1{}
+ files := map[spdx.ElementID]*spdx.File2_1{}
fileNumber := 0
for _, fp := range filepaths {
newFile, err := BuildFileSection2_1(fp, dirRoot, fileNumber)
if err != nil {
return nil, err
}
- files = append(files, newFile)
+ files[newFile.FileSPDXIdentifier] = newFile
fileNumber++
}
@@ -42,7 +42,7 @@ func BuildPackageSection2_1(packageName string, dirRoot string, pathsIgnore []st
// now build the package section
pkg := &spdx.Package2_1{
PackageName: packageName,
- PackageSPDXIdentifier: fmt.Sprintf("SPDXRef-Package-%s", packageName),
+ PackageSPDXIdentifier: spdx.ElementID(fmt.Sprintf("Package-%s", packageName)),
PackageDownloadLocation: "NOASSERTION",
FilesAnalyzed: true,
IsFilesAnalyzedTagPresent: true,
diff --git a/builder/builder2v1/build_package_test.go b/builder/builder2v1/build_package_test.go
index 42e4e47..8902932 100644
--- a/builder/builder2v1/build_package_test.go
+++ b/builder/builder2v1/build_package_test.go
@@ -4,6 +4,8 @@ package builder2v1
import (
"testing"
+
+ "github.com/spdx/tools-golang/spdx"
)
// ===== Package section builder tests =====
@@ -24,8 +26,8 @@ func TestBuilder2_1CanBuildPackageSection(t *testing.T) {
if pkg.PackageName != "project1" {
t.Errorf("expected %v, got %v", "project1", pkg.PackageName)
}
- if pkg.PackageSPDXIdentifier != "SPDXRef-Package-project1" {
- t.Errorf("expected %v, got %v", "SPDXRef-Package-project1", pkg.PackageSPDXIdentifier)
+ if pkg.PackageSPDXIdentifier != spdx.ElementID("Package-project1") {
+ t.Errorf("expected %v, got %v", "Package-project1", pkg.PackageSPDXIdentifier)
}
if pkg.PackageDownloadLocation != "NOASSERTION" {
t.Errorf("expected %v, got %v", "NOASSERTION", pkg.PackageDownloadLocation)
@@ -59,15 +61,15 @@ func TestBuilder2_1CanBuildPackageSection(t *testing.T) {
if len(pkg.Files) != 5 {
t.Fatalf("expected %d, got %d", 5, len(pkg.Files))
}
- fileEmpty := pkg.Files[0]
+ fileEmpty := pkg.Files[spdx.ElementID("File0")]
if fileEmpty == nil {
t.Fatalf("expected non-nil file, got nil")
}
if fileEmpty.FileName != "/emptyfile.testdata.txt" {
t.Errorf("expected %v, got %v", "/emptyfile.testdata.txt", fileEmpty.FileName)
}
- if fileEmpty.FileSPDXIdentifier != "SPDXRef-File0" {
- t.Errorf("expected %v, got %v", "SPDXRef-File0", fileEmpty.FileSPDXIdentifier)
+ if fileEmpty.FileSPDXIdentifier != spdx.ElementID("File0") {
+ t.Errorf("expected %v, got %v", "File0", fileEmpty.FileSPDXIdentifier)
}
if fileEmpty.FileChecksumSHA1 != "da39a3ee5e6b4b0d3255bfef95601890afd80709" {
t.Errorf("expected %v, got %v", "da39a3ee5e6b4b0d3255bfef95601890afd80709", fileEmpty.FileChecksumSHA1)
@@ -112,31 +114,31 @@ func TestBuilder2_1CanIgnoreFiles(t *testing.T) {
}
want := "/dontscan.txt"
- got := pkg.Files[0].FileName
+ got := pkg.Files[spdx.ElementID("File0")].FileName
if want != got {
t.Errorf("expected %v, got %v", want, got)
}
want = "/keep/keep.txt"
- got = pkg.Files[1].FileName
+ got = pkg.Files[spdx.ElementID("File1")].FileName
if want != got {
t.Errorf("expected %v, got %v", want, got)
}
want = "/keep.txt"
- got = pkg.Files[2].FileName
+ got = pkg.Files[spdx.ElementID("File2")].FileName
if want != got {
t.Errorf("expected %v, got %v", want, got)
}
want = "/subdir/keep/dontscan.txt"
- got = pkg.Files[3].FileName
+ got = pkg.Files[spdx.ElementID("File3")].FileName
if want != got {
t.Errorf("expected %v, got %v", want, got)
}
want = "/subdir/keep/keep.txt"
- got = pkg.Files[4].FileName
+ got = pkg.Files[spdx.ElementID("File4")].FileName
if want != got {
t.Errorf("expected %v, got %v", want, got)
}
diff --git a/builder/builder2v1/build_relationship.go b/builder/builder2v1/build_relationship.go
index 2215581..7c780e6 100644
--- a/builder/builder2v1/build_relationship.go
+++ b/builder/builder2v1/build_relationship.go
@@ -14,8 +14,8 @@ import (
// - packageName: name of package / directory
func BuildRelationshipSection2_1(packageName string) (*spdx.Relationship2_1, error) {
rln := &spdx.Relationship2_1{
- RefA: "SPDXRef-DOCUMENT",
- RefB: fmt.Sprintf("SPDXRef-Package-%s", packageName),
+ RefA: spdx.MakeDocElementID("", "DOCUMENT"),
+ RefB: spdx.MakeDocElementID("", fmt.Sprintf("Package-%s", packageName)),
Relationship: "DESCRIBES",
}
diff --git a/builder/builder2v1/build_relationship_test.go b/builder/builder2v1/build_relationship_test.go
index c8a2dac..384f5b3 100644
--- a/builder/builder2v1/build_relationship_test.go
+++ b/builder/builder2v1/build_relationship_test.go
@@ -4,6 +4,8 @@ package builder2v1
import (
"testing"
+
+ "github.com/spdx/tools-golang/spdx"
)
// ===== Relationship section builder tests =====
@@ -18,11 +20,11 @@ func TestBuilder2_1CanBuildRelationshipSection(t *testing.T) {
if rln == nil {
t.Fatalf("expected non-nil relationship, got nil")
}
- if rln.RefA != "SPDXRef-DOCUMENT" {
- t.Errorf("expected %v, got %v", "SPDXRef-DOCUMENT", rln.RefA)
+ if rln.RefA != spdx.MakeDocElementID("", "DOCUMENT") {
+ t.Errorf("expected %v, got %v", "DOCUMENT", rln.RefA)
}
- if rln.RefB != "SPDXRef-Package-project17" {
- t.Errorf("expected %v, got %v", "SPDXRef-Package-project17", rln.RefB)
+ if rln.RefB != spdx.MakeDocElementID("", "Package-project17") {
+ t.Errorf("expected %v, got %v", "Package-project17", rln.RefB)
}
if rln.Relationship != "DESCRIBES" {
t.Errorf("expected %v, got %v", "DESCRIBES", rln.Relationship)