ref: 19d9a46f63a24b65c041be3f95053c154c78fd92
parent: 0602135fd44b0cfa0a51b0ec6e451ae58ac95666
author: Bjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
date: Thu Feb 22 12:16:42 EST 2018
Properly handle -DEV suffix when comparing Hugo versions See #4443
--- a/helpers/hugo.go
+++ b/helpers/hugo.go
@@ -14,7 +14,6 @@
package helpers
import (
- "errors"
"fmt"
"strings"
@@ -57,7 +56,7 @@
// Implements compare.Comparer
func (h HugoVersionString) Compare(other interface{}) int {v := MustParseHugoVersion(h.String())
- return compareVersions(v.Number, v.PatchLevel, other)
+ return compareVersionsWithSuffix(v.Number, v.PatchLevel, v.Suffix, other)
}
// Implements compare.Eqer
@@ -69,18 +68,18 @@
return s == h.String()
}
+var versionSuffixes = []string{"-test", "-DEV"}+
// ParseHugoVersion parses a version string.
func ParseHugoVersion(s string) (HugoVersion, error) {var vv HugoVersion
- if strings.HasSuffix(s, "-test") {- vv.Suffix = "-test"
- s = strings.TrimSuffix(s, "-test")
+ for _, suffix := range versionSuffixes {+ if strings.HasSuffix(s, suffix) {+ vv.Suffix = suffix
+ s = strings.TrimSuffix(s, suffix)
+ }
}
- if strings.Contains(s, "DEV") {- return vv, errors.New("DEV versions not supported by parse")- }
-
v, p := parseVersion(s)
vv.Number = v
@@ -141,21 +140,26 @@
// It returns -1 if the given version is less than, 0 if equal and 1 if greater than
// the running version.
func CompareVersion(version interface{}) int {- return compareVersions(CurrentHugoVersion.Number, CurrentHugoVersion.PatchLevel, version)
+ return compareVersionsWithSuffix(CurrentHugoVersion.Number, CurrentHugoVersion.PatchLevel, CurrentHugoVersion.Suffix, version)
}
func compareVersions(inVersion float32, inPatchVersion int, in interface{}) int {+ return compareVersionsWithSuffix(inVersion, inPatchVersion, "", in)
+}
+
+func compareVersionsWithSuffix(inVersion float32, inPatchVersion int, suffix string, in interface{}) int {+ var c int
switch d := in.(type) {case float64:
- return compareFloatVersions(inVersion, float32(d))
+ c = compareFloatVersions(inVersion, float32(d))
case float32:
- return compareFloatVersions(inVersion, d)
+ c = compareFloatVersions(inVersion, d)
case int:
- return compareFloatVersions(inVersion, float32(d))
+ c = compareFloatVersions(inVersion, float32(d))
case int32:
- return compareFloatVersions(inVersion, float32(d))
+ c = compareFloatVersions(inVersion, float32(d))
case int64:
- return compareFloatVersions(inVersion, float32(d))
+ c = compareFloatVersions(inVersion, float32(d))
default:
s, err := cast.ToStringE(in)
if err != nil {@@ -162,18 +166,27 @@
return -1
}
- v, p := parseVersion(s)
+ v, err := ParseHugoVersion(s)
+ if err != nil {+ return -1
+ }
- if v == inVersion && p == inPatchVersion {- return 0
+ if v.Number == inVersion && v.PatchLevel == inPatchVersion {+ return strings.Compare(suffix, v.Suffix)
}
- if v < inVersion || (v == inVersion && p < inPatchVersion) {+ if v.Number < inVersion || (v.Number == inVersion && v.PatchLevel < inPatchVersion) {return -1
}
return 1
}
+
+ if c == 0 && suffix != "" {+ return 1
+ }
+
+ return c
}
func parseVersion(s string) (float32, int) {--- a/helpers/hugo_test.go
+++ b/helpers/hugo_test.go
@@ -53,6 +53,12 @@
require.Equal(t, 1, compareVersions(0.20, 0, "0.20.1"))
require.Equal(t, 1, compareVersions(0.20, 1, "0.20.2"))
require.Equal(t, 1, compareVersions(0.21, 1, "0.22.1"))
+ require.Equal(t, -1, compareVersions(0.22, 0, "0.22-DEV"))
+ require.Equal(t, 1, compareVersions(0.22, 0, "0.22.1-DEV"))
+ require.Equal(t, 1, compareVersionsWithSuffix(0.22, 0, "-DEV", "0.22"))
+ require.Equal(t, -1, compareVersionsWithSuffix(0.22, 1, "-DEV", "0.22"))
+ require.Equal(t, 0, compareVersionsWithSuffix(0.22, 1, "-DEV", "0.22.1-DEV"))
+
}
func TestParseHugoVersion(t *testing.T) {@@ -59,6 +65,6 @@
require.Equal(t, "0.25", MustParseHugoVersion("0.25").String()) require.Equal(t, "0.25.2", MustParseHugoVersion("0.25.2").String()) require.Equal(t, "0.25-test", MustParseHugoVersion("0.25-test").String())- _, err := ParseHugoVersion("0.25-DEV")- require.Error(t, err)
+ require.Equal(t, "0.25-DEV", MustParseHugoVersion("0.25-DEV").String())+
}
--- a/tpl/compare/compare_test.go
+++ b/tpl/compare/compare_test.go
@@ -180,6 +180,10 @@
{helpers.MustParseHugoVersion("0.32").Version(), "0.36", -1}, {"0.36", helpers.MustParseHugoVersion("0.32").Version(), 1}, {"0.36", helpers.MustParseHugoVersion("0.36").Version(), 0},+ {"0.37", helpers.MustParseHugoVersion("0.37-DEV").Version(), 1},+ {"0.37-DEV", helpers.MustParseHugoVersion("0.37").Version(), -1},+ {"0.36", helpers.MustParseHugoVersion("0.37-DEV").Version(), -1},+ {"0.37-DEV", helpers.MustParseHugoVersion("0.37-DEV").Version(), 0}, } {result := funcUnderTest(test.left, test.right)
success := false
--
⑨