Merge pull request #15794 from spowelljr/getCommit
CI: return commit when getting GitHub releasespull/15799/head
commit
fb74fcbb81
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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")
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue