refactor compare versions
This commit is contained in:
@@ -24,9 +24,10 @@ func BenchmarkOnce(b *testing.B) {
|
|||||||
add := Once(func() {
|
add := Once(func() {
|
||||||
v++
|
v++
|
||||||
})
|
})
|
||||||
|
|
||||||
b.ResetTimer()
|
b.ResetTimer()
|
||||||
for i:=0;i<b.N;i++{
|
for i := 0; i < b.N; i++ {
|
||||||
add()
|
add()
|
||||||
}
|
}
|
||||||
assert.Equal(b, 1, v)
|
assert.Equal(b, 1, v)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,92 +3,75 @@ package utils
|
|||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
"github.com/tal-tech/go-zero/core/mathx"
|
||||||
|
"github.com/tal-tech/go-zero/core/stringx"
|
||||||
)
|
)
|
||||||
|
|
||||||
//return 0 if they are equal,and 1 if v1>2,and 2 if v1<v2
|
var replacer = stringx.NewReplacer(map[string]string{
|
||||||
func Compare(v1, v2 string) int {
|
"V": "",
|
||||||
replaceMap := map[string]string{"V": "", "v": "", "-": "."}
|
"v": "",
|
||||||
for k, v := range replaceMap {
|
"-": ".",
|
||||||
if strings.Contains(v1, k) {
|
})
|
||||||
v1 = strings.Replace(v1, k, v, -1)
|
|
||||||
}
|
|
||||||
if strings.Contains(v2, k) {
|
|
||||||
v2 = strings.Replace(v2, k, v, -1)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
verStr1 := strings.Split(v1, ".")
|
|
||||||
verStr2 := strings.Split(v2, ".")
|
|
||||||
|
|
||||||
ver1 := strSlice2IntSlice(verStr1)
|
// operator compare returns true if the first field and the third field equation holds else false
|
||||||
ver2 := strSlice2IntSlice(verStr2)
|
func CompareVersions(v1, op, v2 string) bool {
|
||||||
|
result := compare(v1, v2)
|
||||||
var shorter int
|
switch op {
|
||||||
if len(ver1) > len(ver2) {
|
case "=", "==":
|
||||||
shorter = len(ver2)
|
return result == 0
|
||||||
} else {
|
case "<":
|
||||||
shorter = len(ver1)
|
return result == -1
|
||||||
|
case ">":
|
||||||
|
return result == 1
|
||||||
|
case "<=":
|
||||||
|
return result == -1 || result == 0
|
||||||
|
case ">=":
|
||||||
|
return result == 0 || result == 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
// return -1 if v1<v2, 0 if they are equal, and 1 if v1>v2
|
||||||
|
func compare(v1, v2 string) int {
|
||||||
|
v1 = replacer.Replace(v1)
|
||||||
|
v2 = replacer.Replace(v2)
|
||||||
|
fields1 := strings.Split(v1, ".")
|
||||||
|
fields2 := strings.Split(v2, ".")
|
||||||
|
ver1 := strsToInts(fields1)
|
||||||
|
ver2 := strsToInts(fields2)
|
||||||
|
shorter := mathx.MinInt(len(ver1), len(ver2))
|
||||||
|
|
||||||
for i := 0; i < shorter; i++ {
|
for i := 0; i < shorter; i++ {
|
||||||
if ver1[i] == ver2[i] {
|
if ver1[i] == ver2[i] {
|
||||||
if shorter-1 == i {
|
continue
|
||||||
if len(ver1) == len(ver2) {
|
} else if ver1[i] < ver2[i] {
|
||||||
return 0
|
return -1
|
||||||
} else {
|
|
||||||
if len(ver1) > len(ver2) {
|
|
||||||
return 1
|
|
||||||
} else {
|
|
||||||
return 2
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if ver1[i] > ver2[i] {
|
|
||||||
return 1
|
|
||||||
} else {
|
} else {
|
||||||
return 2
|
return 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return -1
|
|
||||||
|
if len(ver1) < len(ver2) {
|
||||||
|
return -1
|
||||||
|
} else if len(ver1) == len(ver2) {
|
||||||
|
return 0
|
||||||
|
} else {
|
||||||
|
return 1
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func strSlice2IntSlice(strs []string) []int64 {
|
func strsToInts(strs []string) []int64 {
|
||||||
if len(strs) == 0 {
|
if len(strs) == 0 {
|
||||||
return []int64{}
|
return nil
|
||||||
}
|
}
|
||||||
retInt := make([]int64, 0, len(strs))
|
|
||||||
for _, str := range strs {
|
|
||||||
i, err := strconv.ParseInt(str, 10, 64)
|
|
||||||
if err == nil {
|
|
||||||
retInt = append(retInt, i)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return retInt
|
|
||||||
}
|
|
||||||
|
|
||||||
//operator compare returns true if the first field and the third field equation holds else false
|
ret := make([]int64, 0, len(strs))
|
||||||
func CompareVersions(v1, operator, v2 string) bool {
|
for _, str := range strs {
|
||||||
com := Compare(v1, v2)
|
i, _ := strconv.ParseInt(str, 10, 64)
|
||||||
switch operator {
|
ret = append(ret, i)
|
||||||
case "==":
|
|
||||||
if com == 0 {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
case "<":
|
|
||||||
if com == 2 {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
case ">":
|
|
||||||
if com == 1 {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
case "<=":
|
|
||||||
if com == 0 || com == 2 {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
case ">=":
|
|
||||||
if com == 0 || com == 1 {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false
|
|
||||||
|
return ret
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
@@ -31,7 +32,7 @@ func TestCustomCompareVersions(t *testing.T) {
|
|||||||
for _, each := range cases {
|
for _, each := range cases {
|
||||||
t.Run(each.ver1, func(t *testing.T) {
|
t.Run(each.ver1, func(t *testing.T) {
|
||||||
actual := CompareVersions(each.ver1, each.operator, each.ver2)
|
actual := CompareVersions(each.ver1, each.operator, each.ver2)
|
||||||
assert.Equal(t, each.out, actual)
|
assert.Equal(t, each.out, actual, fmt.Sprintf("%s vs %s", each.ver1, each.ver2))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user