Exit codes for -upgrade and -upgrade-check (fixes #194)

This commit is contained in:
Jakob Borg
2014-07-31 10:26:45 +02:00
parent 86b3ff3099
commit 7b8c126aa1
3 changed files with 41 additions and 9 deletions

View File

@@ -26,6 +26,11 @@ import (
var GoArchExtra string // "", "v5", "v6", "v7"
var (
errVersionUpToDate = errors.New("current version is up to date")
errVersionUnknown = errors.New("couldn't fetch release information")
)
func upgrade() error {
if runtime.GOOS == "windows" {
return errors.New("Upgrade currently unsupported on Windows")
@@ -44,10 +49,10 @@ func upgrade() error {
switch compareVersions(rel.Tag, Version) {
case -1:
l.Okf("Current version %s is newer than latest release %s. Not upgrading.", Version, rel.Tag)
return nil
return errVersionUpToDate
case 0:
l.Okf("Already running the latest version, %s. Not upgrading.", Version)
return nil
return errVersionUpToDate
default:
l.Infof("Attempting upgrade to %s...", rel.Tag)
}
@@ -80,7 +85,7 @@ func upgrade() error {
}
}
return fmt.Errorf("Found no asset for %q", expectedRelease)
return errVersionUnknown
}
func currentRelease() (githubRelease, error) {
@@ -88,13 +93,16 @@ func currentRelease() (githubRelease, error) {
if err != nil {
return githubRelease{}, err
}
if resp.StatusCode > 299 {
return githubRelease{}, fmt.Errorf("API call returned HTTP error: %s", resp.Status)
}
var rels []githubRelease
json.NewDecoder(resp.Body).Decode(&rels)
resp.Body.Close()
if len(rels) == 0 {
return githubRelease{}, errors.New("no releases found")
return githubRelease{}, errVersionUnknown
}
if strings.Contains(Version, "-beta") {
@@ -113,7 +121,7 @@ func currentRelease() (githubRelease, error) {
return rel, nil
}
}
return githubRelease{}, errors.New("no suitable release found")
return githubRelease{}, errVersionUnknown
}
}