From 441ff8e5c8c464b3b1090ea5300a8e0fc4287e6f Mon Sep 17 00:00:00 2001 From: Knut Zuidema Date: Fri, 28 Jul 2023 12:07:58 +0200 Subject: [PATCH] feat: nil version equality This changes the Equal method to return true for 2 nil values and false if any one of the values is nil. Previously passing a nil value would have resulted in a panic. --- version.go | 6 ++++++ version_test.go | 27 ++++++++++----------------- 2 files changed, 16 insertions(+), 17 deletions(-) diff --git a/version.go b/version.go index 7c4bed3..3acbe5b 100644 --- a/version.go +++ b/version.go @@ -390,6 +390,12 @@ func (v *Version) GreaterThan(o *Version) bool { // Note, versions can be equal with different metadata since metadata // is not considered part of the comparable version. func (v *Version) Equal(o *Version) bool { + if v == o { + return true + } + if v == nil || o == nil { + return false + } return v.Compare(o) == 0 } diff --git a/version_test.go b/version_test.go index 16156dd..be8f609 100644 --- a/version_test.go +++ b/version_test.go @@ -343,28 +343,21 @@ func TestGreaterThan(t *testing.T) { func TestEqual(t *testing.T) { tests := []struct { - v1 string - v2 string + v1 *Version + v2 *Version expected bool }{ - {"1.2.3", "1.5.1", false}, - {"2.2.3", "1.5.1", false}, - {"3.2-beta", "3.2-beta", true}, - {"3.2-beta+foo", "3.2-beta+bar", true}, + {MustParse("1.2.3"), MustParse("1.5.1"), false}, + {MustParse("2.2.3"), MustParse("1.5.1"), false}, + {MustParse("3.2-beta"), MustParse("3.2-beta"), true}, + {MustParse("3.2-beta+foo"), MustParse("3.2-beta+bar"), true}, + {nil, nil, true}, + {nil, MustParse("1.2.3"), false}, + {MustParse("1.2.3"), nil, false}, } for _, tc := range tests { - v1, err := NewVersion(tc.v1) - if err != nil { - t.Errorf("Error parsing version: %s", err) - } - - v2, err := NewVersion(tc.v2) - if err != nil { - t.Errorf("Error parsing version: %s", err) - } - - a := v1.Equal(v2) + a := tc.v1.Equal(tc.v2) e := tc.expected if a != e { t.Errorf(