Skip to content

Commit

Permalink
Merge d1a01f0 into b68821f
Browse files Browse the repository at this point in the history
  • Loading branch information
swinslow committed May 10, 2020
2 parents b68821f + d1a01f0 commit a4abd2f
Show file tree
Hide file tree
Showing 60 changed files with 1,675 additions and 1,063 deletions.
2 changes: 1 addition & 1 deletion builder/build.go
Expand Up @@ -64,7 +64,7 @@ func Build2_1(packageName string, dirRoot string, config *Config2_1) (*spdx.Docu

doc := &spdx.Document2_1{
CreationInfo: ci,
Packages: []*spdx.Package2_1{pkg},
Packages: map[spdx.ElementID]*spdx.Package2_1{pkg.PackageSPDXIdentifier: pkg},
Relationships: []*spdx.Relationship2_1{rln},
}

Expand Down
72 changes: 39 additions & 33 deletions builder/build_test.go
Expand Up @@ -5,6 +5,8 @@ package builder
import (
"fmt"
"testing"

"github.com/spdx/tools-golang/spdx"
)

// ===== Builder top-level Document test =====
Expand Down Expand Up @@ -39,8 +41,8 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
if doc.CreationInfo.DataLicense != "CC0-1.0" {
t.Errorf("expected %s, got %s", "CC0-1.0", doc.CreationInfo.DataLicense)
}
if doc.CreationInfo.SPDXIdentifier != "SPDXRef-DOCUMENT" {
t.Errorf("expected %s, got %s", "SPDXRef-DOCUMENT", doc.CreationInfo.SPDXIdentifier)
if doc.CreationInfo.SPDXIdentifier != spdx.ElementID("DOCUMENT") {
t.Errorf("expected %s, got %v", "DOCUMENT", doc.CreationInfo.SPDXIdentifier)
}
if doc.CreationInfo.DocumentName != "project1" {
t.Errorf("expected %s, got %s", "project1", doc.CreationInfo.DocumentName)
Expand Down Expand Up @@ -72,15 +74,15 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
if len(doc.Packages) != 1 {
t.Fatalf("expected %d, got %d", 1, len(doc.Packages))
}
pkg := doc.Packages[0]
if pkg.IsUnpackaged {
t.Errorf("expected %v, got %v", false, pkg.IsUnpackaged)
pkg := doc.Packages[spdx.ElementID("Package-project1")]
if pkg == nil {
t.Fatalf("expected non-nil pkg, got nil")
}
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)
Expand Down Expand Up @@ -112,19 +114,20 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
t.Fatalf("expected %d, got %d", 5, len(pkg.Files))
}

// files should be in alphabetical order:
// files should be in order of identifier, which is numeric,
// created based on alphabetical order of files:
// emptyfile, file1, file3, folder/file4, lastfile

// check emptyfile.testdata.txt
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)
Expand All @@ -146,15 +149,15 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
}

// check file1.testdata.txt
file1 := pkg.Files[1]
file1 := pkg.Files[spdx.ElementID("File1")]
if file1 == nil {
t.Fatalf("expected non-nil file, got nil")
}
if file1.FileName != "/file1.testdata.txt" {
t.Errorf("expected %v, got %v", "/file1.testdata.txt", file1.FileName)
}
if file1.FileSPDXIdentifier != "SPDXRef-File1" {
t.Errorf("expected %v, got %v", "SPDXRef-File1", file1.FileSPDXIdentifier)
if file1.FileSPDXIdentifier != spdx.ElementID("File1") {
t.Errorf("expected %v, got %v", "File1", file1.FileSPDXIdentifier)
}
if file1.FileChecksumSHA1 != "024f870eb6323f532515f7a09d5646a97083b819" {
t.Errorf("expected %v, got %v", "024f870eb6323f532515f7a09d5646a97083b819", file1.FileChecksumSHA1)
Expand All @@ -176,15 +179,15 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
}

// check file3.testdata.txt
file3 := pkg.Files[2]
file3 := pkg.Files[spdx.ElementID("File2")]
if file3 == nil {
t.Fatalf("expected non-nil file, got nil")
}
if file3.FileName != "/file3.testdata.txt" {
t.Errorf("expected %v, got %v", "/file3.testdata.txt", file3.FileName)
}
if file3.FileSPDXIdentifier != "SPDXRef-File2" {
t.Errorf("expected %v, got %v", "SPDXRef-File2", file3.FileSPDXIdentifier)
if file3.FileSPDXIdentifier != spdx.ElementID("File2") {
t.Errorf("expected %v, got %v", "File2", file3.FileSPDXIdentifier)
}
if file3.FileChecksumSHA1 != "a46114b70e163614f01c64adf44cdd438f158fce" {
t.Errorf("expected %v, got %v", "a46114b70e163614f01c64adf44cdd438f158fce", file3.FileChecksumSHA1)
Expand All @@ -206,15 +209,15 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
}

// check folder1/file4.testdata.txt
file4 := pkg.Files[3]
file4 := pkg.Files[spdx.ElementID("File3")]
if file4 == nil {
t.Fatalf("expected non-nil file, got nil")
}
if file4.FileName != "/folder1/file4.testdata.txt" {
t.Errorf("expected %v, got %v", "folder1/file4.testdata.txt", file4.FileName)
}
if file4.FileSPDXIdentifier != "SPDXRef-File3" {
t.Errorf("expected %v, got %v", "SPDXRef-File3", file4.FileSPDXIdentifier)
if file4.FileSPDXIdentifier != spdx.ElementID("File3") {
t.Errorf("expected %v, got %v", "File3", file4.FileSPDXIdentifier)
}
if file4.FileChecksumSHA1 != "e623d7d7d782a7c8323c4d436acee4afab34320f" {
t.Errorf("expected %v, got %v", "e623d7d7d782a7c8323c4d436acee4afab34320f", file4.FileChecksumSHA1)
Expand All @@ -236,15 +239,15 @@ func TestBuild2_1CreatesDocument(t *testing.T) {
}

// check lastfile.testdata.txt
lastfile := pkg.Files[4]
lastfile := pkg.Files[spdx.ElementID("File4")]
if lastfile == nil {
t.Fatalf("expected non-nil file, got nil")
}
if lastfile.FileName != "/lastfile.testdata.txt" {
t.Errorf("expected %v, got %v", "/lastfile.testdata.txt", lastfile.FileName)
}
if lastfile.FileSPDXIdentifier != "SPDXRef-File4" {
t.Errorf("expected %v, got %v", "SPDXRef-File4", lastfile.FileSPDXIdentifier)
if lastfile.FileSPDXIdentifier != spdx.ElementID("File4") {
t.Errorf("expected %v, got %v", "File4", lastfile.FileSPDXIdentifier)
}
if lastfile.FileChecksumSHA1 != "26d6221d682d9ba59116f9753a701f34271c8ce1" {
t.Errorf("expected %v, got %v", "26d6221d682d9ba59116f9753a701f34271c8ce1", lastfile.FileChecksumSHA1)
Expand Down Expand Up @@ -276,11 +279,11 @@ func TestBuild2_1CreatesDocument(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-project1" {
t.Errorf("expected %v, got %v", "SPDXRef-Package-project1", rln.RefB)
if rln.RefB != spdx.MakeDocElementID("", "Package-project1") {
t.Errorf("expected %v, got %v", "Package-project1", rln.RefB)
}
if rln.Relationship != "DESCRIBES" {
t.Errorf("expected %v, got %v", "DESCRIBES", rln.Relationship)
Expand Down Expand Up @@ -320,37 +323,40 @@ func TestBuild2_1CanIgnoreFiles(t *testing.T) {
if err != nil {
t.Errorf("expected nil error, got %v", err)
}
pkg := doc.Packages[0]
pkg := doc.Packages[spdx.ElementID("Package-project1")]
if pkg == nil {
t.Fatalf("expected non-nil pkg, got nil")
}
if len(pkg.Files) != 5 {
t.Fatalf("expected len %d, got %d", 5, len(pkg.Files))
}

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)
}
Expand Down
2 changes: 1 addition & 1 deletion builder/builder2v1/build_creation_info.go
Expand Up @@ -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,
Expand Down
6 changes: 4 additions & 2 deletions builder/builder2v1/build_creation_info_test.go
Expand Up @@ -5,6 +5,8 @@ package builder2v1
import (
"fmt"
"testing"

"github.com/spdx/tools-golang/spdx"
)

// ===== CreationInfo section builder tests =====
Expand Down Expand Up @@ -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)
Expand Down
4 changes: 2 additions & 2 deletions builder/builder2v1/build_file.go
Expand Up @@ -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,
Expand Down
6 changes: 4 additions & 2 deletions builder/builder2v1/build_file_test.go
Expand Up @@ -4,6 +4,8 @@ package builder2v1

import (
"testing"

"github.com/spdx/tools-golang/spdx"
)

// ===== File section builder tests =====
Expand All @@ -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)
Expand Down
7 changes: 3 additions & 4 deletions builder/builder2v1/build_package.go
Expand Up @@ -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++
}

Expand All @@ -41,9 +41,8 @@ func BuildPackageSection2_1(packageName string, dirRoot string, pathsIgnore []st

// now build the package section
pkg := &spdx.Package2_1{
IsUnpackaged: false,
PackageName: packageName,
PackageSPDXIdentifier: fmt.Sprintf("SPDXRef-Package-%s", packageName),
PackageSPDXIdentifier: spdx.ElementID(fmt.Sprintf("Package-%s", packageName)),
PackageDownloadLocation: "NOASSERTION",
FilesAnalyzed: true,
IsFilesAnalyzedTagPresent: true,
Expand Down
25 changes: 12 additions & 13 deletions builder/builder2v1/build_package_test.go
Expand Up @@ -4,6 +4,8 @@ package builder2v1

import (
"testing"

"github.com/spdx/tools-golang/spdx"
)

// ===== Package section builder tests =====
Expand All @@ -21,14 +23,11 @@ func TestBuilder2_1CanBuildPackageSection(t *testing.T) {
if pkg == nil {
t.Fatalf("expected non-nil Package, got nil")
}
if pkg.IsUnpackaged {
t.Errorf("expected %v, got %v", false, pkg.IsUnpackaged)
}
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)
Expand Down Expand Up @@ -62,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)
Expand Down Expand Up @@ -115,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)
}
Expand Down
4 changes: 2 additions & 2 deletions builder/builder2v1/build_relationship.go
Expand Up @@ -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",
}

Expand Down

0 comments on commit a4abd2f

Please sign in to comment.