fix: version check for catalina

This commit is contained in:
James Houlahan
2020-09-17 13:11:10 +02:00
parent 60b7d980f4
commit b3ed8d51a7
5 changed files with 32 additions and 46 deletions

View File

@ -18,40 +18,35 @@
package useragent
import (
"fmt"
"os/exec"
"runtime"
"github.com/Masterminds/semver/v3"
)
// IsCatalinaOrNewer checks that host is MacOS Catalina 10.14.xx or higher.
// IsCatalinaOrNewer checks that host is MacOS Catalina 10.15.x or higher.
func IsCatalinaOrNewer() bool {
if runtime.GOOS != "darwin" {
return false
}
major, minor, _ := getMacVersion()
return isVersionCatalinaOrNewer(major, minor)
return isVersionCatalinaOrNewer(getMacVersion())
}
func getMacVersion() (major, minor, tiny int) {
major, minor, tiny = 10, 0, 0
func getMacVersion() string {
out, err := exec.Command("sw_vers", "-productVersion").Output()
if err != nil {
return
return ""
}
return parseMacVersion(string(out))
return string(out)
}
func parseMacVersion(version string) (major, minor, tiny int) {
_, _ = fmt.Sscanf(version, "%d.%d.%d", &major, &minor, &tiny)
return
}
func isVersionCatalinaOrNewer(version string) bool {
v, err := semver.StrictNewVersion(version)
if err != nil {
return false
}
func isVersionCatalinaOrNewer(major, minor int) bool {
if major != 10 {
return false
}
if minor < 15 {
return false
}
return true
catalina := semver.MustParse("10.15.0")
return v.GreaterThan(catalina) || v.Equal(catalina)
}

View File

@ -23,35 +23,21 @@ import (
"github.com/stretchr/testify/assert"
)
func TestGetMacVersion(t *testing.T) {
testData := map[string]struct{ major, minor, tiny int }{
"10.14.4": {10, 14, 4},
"10.14.4\r\n": {10, 14, 4},
"10.14.0": {10, 14, 0},
"10.14": {10, 14, 0},
"10": {10, 0, 0},
}
for arg, exp := range testData {
gotMajor, gotMinor, gotTiny := parseMacVersion(arg)
assert.Equal(t, exp.major, gotMajor, "arg %q", arg)
assert.Equal(t, exp.minor, gotMinor, "arg %q", arg)
assert.Equal(t, exp.tiny, gotTiny, "arg %q", arg)
}
}
func TestIsVersionCatalinaOrNewer(t *testing.T) {
testData := map[struct{ major, minor int }]bool{
{9, 0}: false,
{9, 15}: false,
{10, 13}: false,
{10, 14}: false,
{10, 15}: true,
{10, 16}: true,
testData := map[struct{ version string }]bool{
{""}: false,
{"9.0.0"}: false,
{"9.15.0"}: false,
{"10.13.0"}: false,
{"10.14.0"}: false,
{"10.14.99"}: false,
{"10.15.0"}: true,
{"10.16.0"}: true,
{"11.0.0"}: true,
}
for args, exp := range testData {
got := isVersionCatalinaOrNewer(args.major, args.minor)
assert.Equal(t, exp, got, "version %q.%q", args.major, args.minor)
got := isVersionCatalinaOrNewer(args.version)
assert.Equal(t, exp, got, "version %v", args.version)
}
}