mirror of
https://github.com/Syngnat/GoNavi.git
synced 2026-05-11 17:49:46 +08:00
161 lines
4.1 KiB
Go
161 lines
4.1 KiB
Go
package app
|
|
|
|
import (
|
|
"errors"
|
|
stdRuntime "runtime"
|
|
"testing"
|
|
)
|
|
|
|
func TestFetchLatestUpdateInfoSkipsChecksumWhenCurrentVersionIsAlreadyLatest(t *testing.T) {
|
|
assetName, err := expectedAssetName(stdRuntime.GOOS, stdRuntime.GOARCH, "v0.6.5")
|
|
if err != nil {
|
|
t.Fatalf("expectedAssetName returned error: %v", err)
|
|
}
|
|
|
|
originalVersion := AppVersion
|
|
AppVersion = "0.6.5"
|
|
defer func() {
|
|
AppVersion = originalVersion
|
|
}()
|
|
|
|
releaseCalled := false
|
|
restoreRelease := swapUpdateFetchLatestRelease(func() (*githubRelease, error) {
|
|
releaseCalled = true
|
|
return &githubRelease{
|
|
TagName: "v0.6.5",
|
|
Name: "v0.6.5",
|
|
HTMLURL: "https://github.com/Syngnat/GoNavi/releases/tag/v0.6.5",
|
|
Assets: []githubAsset{
|
|
{
|
|
Name: assetName,
|
|
BrowserDownloadURL: "https://example.com/" + assetName,
|
|
Size: 1024,
|
|
},
|
|
},
|
|
}, nil
|
|
})
|
|
defer restoreRelease()
|
|
|
|
checksumCalled := false
|
|
restoreChecksum := swapUpdateFetchReleaseSHA256(func([]githubAsset) (map[string]string, error) {
|
|
checksumCalled = true
|
|
return nil, errors.New("checksum should not be fetched when no update is needed")
|
|
})
|
|
defer restoreChecksum()
|
|
|
|
info, err := fetchLatestUpdateInfo()
|
|
if err != nil {
|
|
t.Fatalf("fetchLatestUpdateInfo returned error: %v", err)
|
|
}
|
|
if !releaseCalled {
|
|
t.Fatal("expected latest release metadata to be fetched")
|
|
}
|
|
if checksumCalled {
|
|
t.Fatal("expected SHA256SUMS fetch to be skipped when current version is already latest")
|
|
}
|
|
if info.HasUpdate {
|
|
t.Fatalf("expected HasUpdate=false, got %#v", info)
|
|
}
|
|
if info.LatestVersion != "0.6.5" || info.CurrentVersion != "0.6.5" {
|
|
t.Fatalf("unexpected version info: %#v", info)
|
|
}
|
|
}
|
|
|
|
func TestFetchLatestUpdateInfoFetchesChecksumWhenUpdateIsAvailable(t *testing.T) {
|
|
assetName, err := expectedAssetName(stdRuntime.GOOS, stdRuntime.GOARCH, "v0.6.5")
|
|
if err != nil {
|
|
t.Fatalf("expectedAssetName returned error: %v", err)
|
|
}
|
|
|
|
originalVersion := AppVersion
|
|
AppVersion = "0.6.4"
|
|
defer func() {
|
|
AppVersion = originalVersion
|
|
}()
|
|
|
|
restoreRelease := swapUpdateFetchLatestRelease(func() (*githubRelease, error) {
|
|
return &githubRelease{
|
|
TagName: "v0.6.5",
|
|
Name: "v0.6.5",
|
|
HTMLURL: "https://github.com/Syngnat/GoNavi/releases/tag/v0.6.5",
|
|
Assets: []githubAsset{
|
|
{
|
|
Name: assetName,
|
|
BrowserDownloadURL: "https://example.com/" + assetName,
|
|
Size: 4096,
|
|
},
|
|
},
|
|
}, nil
|
|
})
|
|
defer restoreRelease()
|
|
|
|
checksumCalled := false
|
|
restoreChecksum := swapUpdateFetchReleaseSHA256(func([]githubAsset) (map[string]string, error) {
|
|
checksumCalled = true
|
|
return map[string]string{
|
|
assetName: "abc123",
|
|
}, nil
|
|
})
|
|
defer restoreChecksum()
|
|
|
|
info, err := fetchLatestUpdateInfo()
|
|
if err != nil {
|
|
t.Fatalf("fetchLatestUpdateInfo returned error: %v", err)
|
|
}
|
|
if !checksumCalled {
|
|
t.Fatal("expected SHA256SUMS fetch when update is available")
|
|
}
|
|
if !info.HasUpdate {
|
|
t.Fatalf("expected HasUpdate=true, got %#v", info)
|
|
}
|
|
if info.SHA256 != "abc123" || info.AssetName != assetName {
|
|
t.Fatalf("unexpected update info: %#v", info)
|
|
}
|
|
}
|
|
|
|
func TestCheckForUpdatesLogsFailuresForManualChecks(t *testing.T) {
|
|
app := &App{}
|
|
|
|
restoreRelease := swapUpdateFetchLatestRelease(func() (*githubRelease, error) {
|
|
return nil, errors.New("request timed out")
|
|
})
|
|
defer restoreRelease()
|
|
|
|
logged := 0
|
|
restoreLogger := swapUpdateCheckErrorLogger(func(error) {
|
|
logged++
|
|
})
|
|
defer restoreLogger()
|
|
|
|
result := app.CheckForUpdates()
|
|
if result.Success {
|
|
t.Fatalf("expected failure result, got %#v", result)
|
|
}
|
|
if logged != 1 {
|
|
t.Fatalf("expected manual check to log once, got %d", logged)
|
|
}
|
|
}
|
|
|
|
func TestCheckForUpdatesSilentlySkipsFailureLogs(t *testing.T) {
|
|
app := &App{}
|
|
|
|
restoreRelease := swapUpdateFetchLatestRelease(func() (*githubRelease, error) {
|
|
return nil, errors.New("request timed out")
|
|
})
|
|
defer restoreRelease()
|
|
|
|
logged := 0
|
|
restoreLogger := swapUpdateCheckErrorLogger(func(error) {
|
|
logged++
|
|
})
|
|
defer restoreLogger()
|
|
|
|
result := app.CheckForUpdatesSilently()
|
|
if result.Success {
|
|
t.Fatalf("expected failure result, got %#v", result)
|
|
}
|
|
if logged != 0 {
|
|
t.Fatalf("expected silent check to skip error logging, got %d", logged)
|
|
}
|
|
}
|