mirror of
https://github.com/kairos-io/kairos-agent.git
synced 2025-04-27 19:28:59 +00:00
sparkles: Allow showing pre-releases on upgrade options (#1333)
By default get 30 releases and skip any pre-releases found. Allow toggling showing pre-releases both for upgrade and for listing them Signed-off-by: Itxaka <itxaka.garcia@spectrocloud.com>
This commit is contained in:
parent
d9c3ba5915
commit
7cadb1a20b
@ -23,7 +23,7 @@ func newHTTPClient(ctx context.Context, token string) *http.Client {
|
||||
|
||||
// FindReleases finds the releases from the given repo (slug) and returns a parsed semver.Collection
|
||||
// where the first item is the highest version as its sorted.
|
||||
func FindReleases(ctx context.Context, token, slug string) (semver.Collection, error) {
|
||||
func FindReleases(ctx context.Context, token, slug string, preReleases bool) (semver.Collection, error) {
|
||||
hc := newHTTPClient(ctx, token)
|
||||
cli := github.NewClient(hc)
|
||||
|
||||
@ -32,7 +32,9 @@ func FindReleases(ctx context.Context, token, slug string) (semver.Collection, e
|
||||
return nil, fmt.Errorf("Invalid slug format. It should be 'owner/name': %s", slug)
|
||||
}
|
||||
|
||||
rels, res, err := cli.Repositories.ListReleases(ctx, repo[0], repo[1], nil)
|
||||
// Get at least 30 releases
|
||||
opts := github.ListOptions{PerPage: 30}
|
||||
rels, res, err := cli.Repositories.ListReleases(ctx, repo[0], repo[1], &opts)
|
||||
if err != nil {
|
||||
log.Println("API returned an error response:", err)
|
||||
if res != nil && res.StatusCode == 404 {
|
||||
@ -46,7 +48,13 @@ func FindReleases(ctx context.Context, token, slug string) (semver.Collection, e
|
||||
var versions semver.Collection
|
||||
for _, rel := range rels {
|
||||
if strings.HasPrefix(*rel.Name, "v") {
|
||||
versions = append(versions, semver.MustParse(*rel.Name))
|
||||
v := semver.MustParse(*rel.Name)
|
||||
if v.Prerelease() == "" {
|
||||
versions = append(versions, v)
|
||||
}
|
||||
if v.Prerelease() != "" && preReleases {
|
||||
versions = append(versions, v)
|
||||
}
|
||||
}
|
||||
}
|
||||
// Return them reversed sorted so the higher is the first one in the collection!
|
||||
|
@ -16,7 +16,16 @@ func TestReleases(t *testing.T) {
|
||||
|
||||
var _ = Describe("Releases", func() {
|
||||
It("can find the proper releases in order", func() {
|
||||
releases, err := github.FindReleases(context.Background(), "", "kairos-io/kairos")
|
||||
releases, err := github.FindReleases(context.Background(), "", "kairos-io/kairos", false)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
Expect(len(releases)).To(BeNumerically(">", 0))
|
||||
// Expect the one at the bottom to be the first "real" release of kairos
|
||||
Expect(releases[len(releases)-1].Original()).To(Equal("v1.0.0"))
|
||||
// Expect the first one to be greater than the last one
|
||||
Expect(releases[0].GreaterThan(releases[len(releases)-1]))
|
||||
})
|
||||
It("can find the proper releases in order with prereleases", func() {
|
||||
releases, err := github.FindReleases(context.Background(), "", "kairos-io/kairos", true)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
Expect(len(releases)).To(BeNumerically(">", 0))
|
||||
// Expect the first one to be greater than the last one
|
||||
|
Loading…
Reference in New Issue
Block a user