From 1b9eb2eddf322560c37efa2ef2eb63d5ab661be8 Mon Sep 17 00:00:00 2001 From: Paul Duncan Date: Wed, 2 Feb 2022 01:54:19 -0500 Subject: internal/feed: add Vector#MarshalJSON and tests --- internal/feed/vector_test.go | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) (limited to 'internal/feed/vector_test.go') diff --git a/internal/feed/vector_test.go b/internal/feed/vector_test.go index e956884..5dee8ba 100644 --- a/internal/feed/vector_test.go +++ b/internal/feed/vector_test.go @@ -2,6 +2,7 @@ package feed import ( "encoding/json" + "nvd/internal/cvss" "testing" ) @@ -61,3 +62,38 @@ func TestVectorUnmarshalJSON(t *testing.T) { }) } } + +func TestVectorMarshalJSON(t *testing.T) { + tests := []string { + "AV:N/AC:M/Au:S/C:P/I:P/A:P", + "CVSS:3.0/AV:A/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:H", + "CVSS:3.1/AV:A/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H", + } + + for _, val := range(tests) { + t.Run(val, func(t *testing.T) { + // get expected string + exp := "\"" + val + "\"" + + // create inner vector + vec, err := cvss.NewVector(val) + if err != nil { + t.Error(err) + return + } + + // serialize as json + buf, err := json.Marshal(Vector { vec }) + if err != nil { + t.Error(err) + return + } + + // check result + got := string(buf) + if got != exp { + t.Errorf("got \"%s\", exp \"%s\"", got, exp) + } + }) + } +} -- cgit v1.2.3