diff options
author | Paul Duncan <pabs@pablotron.org> | 2022-02-01 14:42:44 -0500 |
---|---|---|
committer | Paul Duncan <pabs@pablotron.org> | 2022-02-01 14:42:44 -0500 |
commit | 3044aef20f4aecb7963e826b976c6d72a970cda1 (patch) | |
tree | 114295370dc27f17d5115f9cf4634e5e01fad20b /internal/feed/v3version_test.go | |
parent | 68714974f6d2887f66101aa020e25faea1631467 (diff) | |
download | cvez-3044aef20f4aecb7963e826b976c6d72a970cda1.tar.bz2 cvez-3044aef20f4aecb7963e826b976c6d72a970cda1.zip |
internal/feed: add v2version, v3version, tests
Diffstat (limited to 'internal/feed/v3version_test.go')
-rw-r--r-- | internal/feed/v3version_test.go | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/internal/feed/v3version_test.go b/internal/feed/v3version_test.go new file mode 100644 index 0000000..89cc6ed --- /dev/null +++ b/internal/feed/v3version_test.go @@ -0,0 +1,75 @@ +package feed + +import ( + "encoding/json" + "testing" +) + +func TestV3VersionUnmarshalInvalidData(t *testing.T) { + test := []byte(`{}`) + var val V3Version + + if err := json.Unmarshal(test, &val); err == nil { + t.Errorf("got \"%s\", exp error", val) + } +} + +func TestV3VersionUnmarshalUnknown(t *testing.T) { + test := []byte(`"foo"`) + exp := "unknown CVSS version: foo" + var val V3Version + + err := json.Unmarshal(test, &val) + if err == nil { + t.Errorf("got \"%s\", exp error", val) + return + } + + if err.Error() != exp { + t.Errorf("got \"%s\", exp \"%s\"", err.Error(), exp) + } +} + +func TestV3VersionUnmarshalValid(t *testing.T) { + tests := []struct { + val string + exp V3Version + } { + { "\"3.1\"", V31 }, + } + + for _, test := range(tests) { + t.Run(test.val, func(t *testing.T) { + var got V3Version + if err := json.Unmarshal([]byte(test.val), &got); err != nil { + t.Error(err) + return + } + + if got != test.exp { + t.Errorf("got \"%s\", exp \"%s\"", got, test.exp) + } + }) + } +} + +func TestV3VersionString(t *testing.T) { + tests := []struct { + val V3Version + exp string + } { + { V31, "3.1" }, + + { V3Version(255), "V3Version(255)" }, + } + + for _, test := range(tests) { + t.Run(test.exp, func(t *testing.T) { + got := test.val.String() + + if got != test.exp { + t.Errorf("got \"%s\", exp \"%s\"", got, test.exp) + } + }) + } +} |