diff options
Diffstat (limited to 'tvloader/parser2v1/parser_test.go')
-rw-r--r-- | tvloader/parser2v1/parser_test.go | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/tvloader/parser2v1/parser_test.go b/tvloader/parser2v1/parser_test.go index 4a61828..0678fd7 100644 --- a/tvloader/parser2v1/parser_test.go +++ b/tvloader/parser2v1/parser_test.go @@ -77,3 +77,33 @@ func TestParser2_1StartFailsToParseIfInInvalidState(t *testing.T) { t.Errorf("expected non-nil error, got nil") } } + +func TestParser2_1FilesWithoutSpdxIdThrowErrorAtCompleteParse(t *testing.T) { + // case + // Last unpackaged file no packages in doc + // Last file of last package in the doc + tvPairs := []reader.TagValuePair{ + {Tag: "SPDXVersion", Value: "SPDX-2.1"}, + {Tag: "DataLicense", Value: "CC0-1.0"}, + {Tag: "SPDXID", Value: "SPDXRef-DOCUMENT"}, + {Tag: "FileName", Value: "f1"}, + } + _, err := ParseTagValues(tvPairs) + if err == nil { + t.Errorf("files withoutSpdx Identifiers getting accepted") + } +} + +func TestParser2_1PackageWithoutSpdxIdThrowErrorAtCompleteParse(t *testing.T) { + // case : Checks the last package + tvPairs := []reader.TagValuePair{ + {Tag: "SPDXVersion", Value: "SPDX-2.1"}, + {Tag: "DataLicense", Value: "CC0-1.0"}, + {Tag: "SPDXID", Value: "SPDXRef-DOCUMENT"}, + {Tag: "PackageName", Value: "p1"}, + } + _, err := ParseTagValues(tvPairs) + if err == nil { + t.Errorf("packages withoutSpdx Identifiers getting accepted") + } +} |