diff options
Diffstat (limited to 'tvloader/parser2v1/parse_annotation_test.go')
-rw-r--r-- | tvloader/parser2v1/parse_annotation_test.go | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/tvloader/parser2v1/parse_annotation_test.go b/tvloader/parser2v1/parse_annotation_test.go new file mode 100644 index 0000000..9e53b2d --- /dev/null +++ b/tvloader/parser2v1/parse_annotation_test.go @@ -0,0 +1,102 @@ +// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later +package parser2v1 + +import ( + "testing" + + "github.com/spdx/tools-golang/spdx" +) + +// ===== Annotation section tests ===== +func TestParser2_1FailsIfAnnotationNotSet(t *testing.T) { + parser := tvParser2_1{ + doc: &spdx.Document2_1{}, + st: psCreationInfo2_1, + } + err := parser.parsePairForAnnotation2_1("Annotator", "Person: John Doe (jdoe@example.com)") + if err == nil { + t.Errorf("expected error when calling parsePairFromAnnotation2_1 without setting ann pointer") + } +} + +func TestParser2_1FailsIfAnnotationFieldsWithoutAnnotation(t *testing.T) { + parser := tvParser2_1{ + doc: &spdx.Document2_1{}, + st: psCreationInfo2_1, + } + err := parser.parsePair2_1("AnnotationDate", "2018-09-15T17:25:00Z") + if err == nil { + t.Errorf("expected error when calling parsePair2_1 for AnnotationDate without Annotator first") + } + err = parser.parsePair2_1("AnnotationType", "REVIEW") + if err == nil { + t.Errorf("expected error when calling parsePair2_1 for AnnotationType without Annotator first") + } + err = parser.parsePair2_1("SPDXREF", "SPDXRef-45") + if err == nil { + t.Errorf("expected error when calling parsePair2_1 for SPDXREF without Annotator first") + } + err = parser.parsePair2_1("AnnotationComment", "comment whatever") + if err == nil { + t.Errorf("expected error when calling parsePair2_1 for AnnotationComment without Annotator first") + } +} + +func TestParser2_1CanParseAnnotationTags(t *testing.T) { + parser := tvParser2_1{ + doc: &spdx.Document2_1{}, + st: psCreationInfo2_1, + } + + // Annotator without email address + err := parser.parsePair2_1("Annotator", "Person: John Doe") + if err != nil { + t.Errorf("expected nil error, got %v", err) + } + if parser.ann.Annotator != "John Doe" { + t.Errorf("got %v for Annotator, expected John Doe", parser.ann.Annotator) + } + if parser.ann.AnnotatorType != "Person" { + t.Errorf("got %v for AnnotatorType, expected Person", parser.ann.AnnotatorType) + } + + // Annotation Date + dt := "2018-09-15T17:32:00Z" + err = parser.parsePair2_1("AnnotationDate", dt) + if err != nil { + t.Errorf("expected nil error, got %v", err) + } + if parser.ann.AnnotationDate != dt { + t.Errorf("got %v for AnnotationDate, expected %v", parser.ann.AnnotationDate, dt) + } + + // Annotation type + aType := "REVIEW" + err = parser.parsePair2_1("AnnotationType", aType) + if err != nil { + t.Errorf("expected nil error, got %v", err) + } + if parser.ann.AnnotationType != aType { + t.Errorf("got %v for AnnotationType, expected %v", parser.ann.AnnotationType, aType) + } + + // SPDX Identifier Reference + ref := "SPDXRef-30" + err = parser.parsePair2_1("SPDXREF", ref) + if err != nil { + t.Errorf("expected nil error, got %v", err) + } + if parser.ann.AnnotationSPDXIdentifier != ref { + t.Errorf("got %v for SPDXREF, expected %v", parser.ann.AnnotationSPDXIdentifier, ref) + } + + // Annotation Comment + cmt := "this is a comment" + err = parser.parsePair2_1("AnnotationComment", cmt) + if err != nil { + t.Errorf("expected nil error, got %v", err) + } + if parser.ann.AnnotationComment != cmt { + t.Errorf("got %v for AnnotationComment, expected %v", parser.ann.AnnotationComment, cmt) + } +} |