mirror of
https://github.com/ProtonMail/proton-bridge.git
synced 2025-12-17 23:56:56 +00:00
fix: version check for catalina
This commit is contained in:
@ -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)
|
||||
}
|
||||
|
||||
@ -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)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user