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

@ -22,6 +22,7 @@ Changelog [format](http://keepachangelog.com/en/1.0.0/)
* GODT-698 Use correct package type for signed PGP/Inline messages. * GODT-698 Use correct package type for signed PGP/Inline messages.
* Generic bug report window title. * Generic bug report window title.
* Fix missing check for unencrypted recipients during sending. * Fix missing check for unencrypted recipients during sending.
* Version checking for catalina.
## [IE 1.0.x] Congo (v1.0.0 live 2020-09-08) ## [IE 1.0.x] Congo (v1.0.0 live 2020-09-08)

1
go.mod
View File

@ -13,6 +13,7 @@ require (
require ( require (
github.com/0xAX/notificator v0.0.0-20191016112426-3962a5ea8da1 github.com/0xAX/notificator v0.0.0-20191016112426-3962a5ea8da1
github.com/Masterminds/semver/v3 v3.1.0
github.com/ProtonMail/go-appdir v1.1.0 github.com/ProtonMail/go-appdir v1.1.0
github.com/ProtonMail/go-apple-mobileconfig v0.0.0-20160701194735-7ea9927a11f6 github.com/ProtonMail/go-apple-mobileconfig v0.0.0-20160701194735-7ea9927a11f6
github.com/ProtonMail/go-autostart v0.0.0-20181114175602-c5272053443a github.com/ProtonMail/go-autostart v0.0.0-20181114175602-c5272053443a

3
go.sum
View File

@ -1,6 +1,9 @@
github.com/0xAX/notificator v0.0.0-20191016112426-3962a5ea8da1 h1:j9HaafapDbPbGRDku6e/HRs6KBMcKHiWcm1/9Sbxnl4= github.com/0xAX/notificator v0.0.0-20191016112426-3962a5ea8da1 h1:j9HaafapDbPbGRDku6e/HRs6KBMcKHiWcm1/9Sbxnl4=
github.com/0xAX/notificator v0.0.0-20191016112426-3962a5ea8da1/go.mod h1:NtXa9WwQsukMHZpjNakTTz0LArxvGYdPA9CjIcUSZ6s= github.com/0xAX/notificator v0.0.0-20191016112426-3962a5ea8da1/go.mod h1:NtXa9WwQsukMHZpjNakTTz0LArxvGYdPA9CjIcUSZ6s=
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
github.com/Masterminds/semver v1.5.0 h1:H65muMkzWKEuNDnfl9d70GUjFniHKHRbFPGBuZ3QEww=
github.com/Masterminds/semver/v3 v3.1.0 h1:Y2lUDsFKVRSYGojLJ1yLxSXdMmMYTYls0rCvoqmMUQk=
github.com/Masterminds/semver/v3 v3.1.0/go.mod h1:VPu/7SZ7ePZ3QOrcuXROw5FAcLl4a0cBrbBpGY/8hQs=
github.com/ProtonMail/bcrypt v0.0.0-20170924085257-7509ea014998 h1:YT2uVwQiRQZxCaaahwfcgTq2j3j66w00n/27gb/zubs= github.com/ProtonMail/bcrypt v0.0.0-20170924085257-7509ea014998 h1:YT2uVwQiRQZxCaaahwfcgTq2j3j66w00n/27gb/zubs=
github.com/ProtonMail/bcrypt v0.0.0-20170924085257-7509ea014998/go.mod h1:HecWFHognK8GfRDGnFQbW/LiV7A3MX3gZVs45vk5h8I= github.com/ProtonMail/bcrypt v0.0.0-20170924085257-7509ea014998/go.mod h1:HecWFHognK8GfRDGnFQbW/LiV7A3MX3gZVs45vk5h8I=
github.com/ProtonMail/crypto v0.0.0-20200416114516-1fa7f403fb9c h1:DAvlgde2Stu18slmjwikiMPs/CKPV35wSvmJS34z0FU= github.com/ProtonMail/crypto v0.0.0-20200416114516-1fa7f403fb9c h1:DAvlgde2Stu18slmjwikiMPs/CKPV35wSvmJS34z0FU=

View File

@ -18,40 +18,35 @@
package useragent package useragent
import ( import (
"fmt"
"os/exec" "os/exec"
"runtime" "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 { func IsCatalinaOrNewer() bool {
if runtime.GOOS != "darwin" { if runtime.GOOS != "darwin" {
return false return false
} }
major, minor, _ := getMacVersion() return isVersionCatalinaOrNewer(getMacVersion())
return isVersionCatalinaOrNewer(major, minor)
} }
func getMacVersion() (major, minor, tiny int) { func getMacVersion() string {
major, minor, tiny = 10, 0, 0
out, err := exec.Command("sw_vers", "-productVersion").Output() out, err := exec.Command("sw_vers", "-productVersion").Output()
if err != nil { if err != nil {
return return ""
} }
return parseMacVersion(string(out))
return string(out)
} }
func parseMacVersion(version string) (major, minor, tiny int) { func isVersionCatalinaOrNewer(version string) bool {
_, _ = fmt.Sscanf(version, "%d.%d.%d", &major, &minor, &tiny) v, err := semver.StrictNewVersion(version)
return if err != nil {
} return false
}
func isVersionCatalinaOrNewer(major, minor int) bool { catalina := semver.MustParse("10.15.0")
if major != 10 { return v.GreaterThan(catalina) || v.Equal(catalina)
return false
}
if minor < 15 {
return false
}
return true
} }

View File

@ -23,35 +23,21 @@ import (
"github.com/stretchr/testify/assert" "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) { func TestIsVersionCatalinaOrNewer(t *testing.T) {
testData := map[struct{ major, minor int }]bool{ testData := map[struct{ version string }]bool{
{9, 0}: false, {""}: false,
{9, 15}: false, {"9.0.0"}: false,
{10, 13}: false, {"9.15.0"}: false,
{10, 14}: false, {"10.13.0"}: false,
{10, 15}: true, {"10.14.0"}: false,
{10, 16}: true, {"10.14.99"}: false,
{"10.15.0"}: true,
{"10.16.0"}: true,
{"11.0.0"}: true,
} }
for args, exp := range testData { for args, exp := range testData {
got := isVersionCatalinaOrNewer(args.major, args.minor) got := isVersionCatalinaOrNewer(args.version)
assert.Equal(t, exp, got, "version %q.%q", args.major, args.minor) assert.Equal(t, exp, got, "version %v", args.version)
} }
} }