Merge pull request #15794 from spowelljr/getCommit

CI: return commit when getting GitHub releases
pull/15799/head
Steven Powell 2023-02-07 11:10:15 -08:00 committed by GitHub
commit fb74fcbb81
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 82 additions and 36 deletions

View File

@ -50,11 +50,11 @@ func main() {
} }
// docsyVersion returns stable version in semver format. // docsyVersion returns stable version in semver format.
func docsyVersion(ctx context.Context, owner, repo string) (stable string, err error) { func docsyVersion(ctx context.Context, owner, repo string) (string, error) {
// get Docsy version from GitHub Releases // get Docsy version from GitHub Releases
stable, _, _, err = update.GHReleases(ctx, owner, repo) stable, _, _, err := update.GHReleases(ctx, owner, repo)
if err != nil || !semver.IsValid(stable) { if err != nil || !semver.IsValid(stable.Tag) {
return "", err return "", err
} }
return stable, nil return stable.Tag, nil
} }

View File

@ -64,11 +64,11 @@ func main() {
} }
// ghVersion returns stable version in semver format. // ghVersion returns stable version in semver format.
func ghVersion(ctx context.Context, owner, repo string) (stable string, err error) { func ghVersion(ctx context.Context, owner, repo string) (string, error) {
// get gh version from GitHub Releases // get gh version from GitHub Releases
stable, _, _, err = update.GHReleases(ctx, owner, repo) stable, _, _, err := update.GHReleases(ctx, owner, repo)
if err != nil || !semver.IsValid(stable) { if err != nil || !semver.IsValid(stable.Tag) {
return "", err return "", err
} }
return strings.TrimPrefix(stable, "v"), nil return strings.TrimPrefix(stable.Tag, "v"), nil
} }

View File

@ -18,6 +18,7 @@ package update
import ( import (
"context" "context"
"fmt"
"strings" "strings"
"golang.org/x/mod/semver" "golang.org/x/mod/semver"
@ -34,9 +35,14 @@ const (
ghSearchLimit = 300 ghSearchLimit = 300
) )
type Release struct {
Tag string
Commit string
}
// GHReleases returns greatest current stable release and greatest latest rc or beta pre-release from GitHub owner/repo repository, and any error occurred. // GHReleases returns greatest current stable release and greatest latest rc or beta pre-release from GitHub owner/repo repository, and any error occurred.
// If latest pre-release version is lower than the current stable release, then it will return current stable release for both. // If latest pre-release version is lower than the current stable release, then it will return current stable release for both.
func GHReleases(ctx context.Context, owner, repo string) (stable, latest, edge string, err error) { func GHReleases(ctx context.Context, owner, repo string) (stable, latest, edge Release, err error) {
ghc := github.NewClient(nil) ghc := github.NewClient(nil)
// walk through the paginated list of up to ghSearchLimit newest releases // walk through the paginated list of up to ghSearchLimit newest releases
@ -44,7 +50,7 @@ func GHReleases(ctx context.Context, owner, repo string) (stable, latest, edge s
for (opts.Page+1)*ghListPerPage <= ghSearchLimit { for (opts.Page+1)*ghListPerPage <= ghSearchLimit {
rls, resp, err := ghc.Repositories.ListReleases(ctx, owner, repo, opts) rls, resp, err := ghc.Repositories.ListReleases(ctx, owner, repo, opts)
if err != nil { if err != nil {
return "", "", "", err return stable, latest, edge, err
} }
for _, rl := range rls { for _, rl := range rls {
ver := rl.GetTagName() ver := rl.GetTagName()
@ -54,22 +60,26 @@ func GHReleases(ctx context.Context, owner, repo string) (stable, latest, edge s
// check if ver version is release (ie, 'v1.19.2') or pre-release (ie, 'v1.19.3-rc.0' or 'v1.19.0-beta.2') // check if ver version is release (ie, 'v1.19.2') or pre-release (ie, 'v1.19.3-rc.0' or 'v1.19.0-beta.2')
prerls := semver.Prerelease(ver) prerls := semver.Prerelease(ver)
if prerls == "" { if prerls == "" {
if semver.Compare(ver, stable) == 1 { if semver.Compare(ver, stable.Tag) == 1 {
stable = ver stable.Tag = ver
} }
} else if strings.HasPrefix(prerls, "-rc") || strings.HasPrefix(prerls, "-beta") { } else if strings.HasPrefix(prerls, "-rc") || strings.HasPrefix(prerls, "-beta") {
if semver.Compare(ver, latest) == 1 { if semver.Compare(ver, latest.Tag) == 1 {
latest = ver latest.Tag = ver
} }
} else if strings.Contains(prerls, "-alpha") { } else if strings.Contains(prerls, "-alpha") {
if semver.Compare(ver, edge) == 1 { if semver.Compare(ver, edge.Tag) == 1 {
edge = ver edge.Tag = ver
} }
} }
// make sure that latest >= stable // make sure that latest >= stable
if semver.Compare(latest, stable) == -1 { if semver.Compare(latest.Tag, stable.Tag) == -1 {
latest = stable latest.Tag = stable.Tag
}
// make sure that edge >= latest
if semver.Compare(edge.Tag, latest.Tag) == -1 {
edge.Tag = latest.Tag
} }
} }
if resp.NextPage == 0 { if resp.NextPage == 0 {
@ -77,5 +87,39 @@ func GHReleases(ctx context.Context, owner, repo string) (stable, latest, edge s
} }
opts.Page = resp.NextPage opts.Page = resp.NextPage
} }
return stable, latest, edge, nil // create a map where the key is the tag and the values is an array of releases (stable, latest, edge) that match the tag
releasesWithoutCommits := map[string][]*Release{}
for _, rl := range []*Release{&stable, &latest, &edge} {
releasesWithoutCommits[rl.Tag] = append(releasesWithoutCommits[rl.Tag], rl)
}
// run though the releases to find ones that don't yet have a commit and assign it
opts = &github.ListOptions{PerPage: ghListPerPage}
for (opts.Page+1)*ghListPerPage <= ghSearchLimit {
tags, resp, err := ghc.Repositories.ListTags(ctx, owner, repo, opts)
if err != nil {
return stable, latest, edge, err
}
for _, tag := range tags {
rls, ok := releasesWithoutCommits[*tag.Name]
if !ok {
continue
}
for _, rl := range rls {
rl.Commit = *tag.Commit.SHA
}
delete(releasesWithoutCommits, *tag.Name)
if len(releasesWithoutCommits) == 0 {
return stable, latest, edge, nil
}
}
if len(releasesWithoutCommits) == 0 {
break
}
if resp.NextPage == 0 {
break
}
opts.Page = resp.NextPage
}
return stable, latest, edge, fmt.Errorf("wasn't able to find commit for releases")
} }

View File

@ -63,11 +63,11 @@ func main() {
} }
// golintVersion returns stable version in semver format. // golintVersion returns stable version in semver format.
func golintVersion(ctx context.Context, owner, repo string) (stable string, err error) { func golintVersion(ctx context.Context, owner, repo string) (string, error) {
// get Golint version from GitHub Releases // get Golint version from GitHub Releases
stable, _, _, err = update.GHReleases(ctx, owner, repo) stable, _, _, err := update.GHReleases(ctx, owner, repo)
if err != nil || !semver.IsValid(stable) { if err != nil || !semver.IsValid(stable.Tag) {
return "", err return "", err
} }
return stable, nil return stable.Tag, nil
} }

View File

@ -83,11 +83,11 @@ func main() {
} }
// gopoghVersion returns gopogh stable version in semver format. // gopoghVersion returns gopogh stable version in semver format.
func gopoghVersion(ctx context.Context, owner, repo string) (stable string, err error) { func gopoghVersion(ctx context.Context, owner, repo string) (string, error) {
// get gopogh version from GitHub Releases // get gopogh version from GitHub Releases
stable, _, _, err = update.GHReleases(ctx, owner, repo) stable, _, _, err := update.GHReleases(ctx, owner, repo)
if err != nil || !semver.IsValid(stable) { if err != nil || !semver.IsValid(stable.Tag) {
return "", err return "", err
} }
return stable, nil return stable.Tag, nil
} }

View File

@ -69,11 +69,11 @@ func main() {
} }
// gotestsumVersion returns gotestsum stable version in semver format. // gotestsumVersion returns gotestsum stable version in semver format.
func gotestsumVersion(ctx context.Context, owner, repo string) (stable string, err error) { func gotestsumVersion(ctx context.Context, owner, repo string) (string, error) {
// get gotestsum version from GitHub Releases // get gotestsum version from GitHub Releases
stable, _, _, err = update.GHReleases(ctx, owner, repo) stable, _, _, err := update.GHReleases(ctx, owner, repo)
if err != nil || !semver.IsValid(stable) { if err != nil || !semver.IsValid(stable.Tag) {
return "", err return "", err
} }
return stable, nil return stable.Tag, nil
} }

View File

@ -63,11 +63,11 @@ func main() {
} }
// hugoVersion returns stable version in semver format. // hugoVersion returns stable version in semver format.
func hugoVersion(ctx context.Context, owner, repo string) (stable string, err error) { func hugoVersion(ctx context.Context, owner, repo string) (string, error) {
// get Hugo version from GitHub Releases // get Hugo version from GitHub Releases
stable, _, _, err = update.GHReleases(ctx, owner, repo) stable, _, _, err := update.GHReleases(ctx, owner, repo)
if err != nil || !semver.IsValid(stable) { if err != nil || !semver.IsValid(stable.Tag) {
return "", err return "", err
} }
return stable, nil return stable.Tag, nil
} }

View File

@ -133,7 +133,9 @@ func main() {
// k8sVersions returns Kubernetes versions. // k8sVersions returns Kubernetes versions.
func k8sVersions(ctx context.Context, owner, repo string) (stable, latest, latestMM, latestP0 string, err error) { func k8sVersions(ctx context.Context, owner, repo string) (stable, latest, latestMM, latestP0 string, err error) {
// get Kubernetes versions from GitHub Releases // get Kubernetes versions from GitHub Releases
stable, latest, _, err = update.GHReleases(ctx, owner, repo) stableRls, latestRls, _, err := update.GHReleases(ctx, owner, repo)
stable = stableRls.Tag
latest = latestRls.Tag
if err != nil || !semver.IsValid(stable) || !semver.IsValid(latest) { if err != nil || !semver.IsValid(stable) || !semver.IsValid(latest) {
return "", "", "", "", err return "", "", "", "", err
} }