From c38307b572011aea640408bfd21e4e07567627bc Mon Sep 17 00:00:00 2001 From: Carlos Alexandro Becker Date: Fri, 13 Jan 2017 21:42:28 -0200 Subject: [PATCH 1/2] update or create release --- pipeline/release/release.go | 26 +++++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) diff --git a/pipeline/release/release.go b/pipeline/release/release.go index ecf0697af..399a3e075 100644 --- a/pipeline/release/release.go +++ b/pipeline/release/release.go @@ -23,19 +23,13 @@ func (Pipe) Name() string { // Run the pipe func (Pipe) Run(config config.ProjectConfig) error { - log.Println("Creating release", config.Git.CurrentTag, "on", config.Repo, "...") ts := oauth2.StaticTokenSource( &oauth2.Token{AccessToken: config.Token}, ) tc := oauth2.NewClient(context.Background(), ts) client := github.NewClient(tc) - owner, repo := split.OnSlash(config.Repo) - r, _, err := client.Repositories.CreateRelease(owner, repo, &github.RepositoryRelease{ - Name: github.String(config.Git.CurrentTag), - TagName: github.String(config.Git.CurrentTag), - Body: github.String(description(config.Git.Diff)), - }) + r, err := getOrCreateRelease(client, config) if err != nil { return err } @@ -52,6 +46,24 @@ func (Pipe) Run(config config.ProjectConfig) error { return g.Wait() } +func getOrCreateRelease(client *github.Client, config config.ProjectConfig) (*github.RepositoryRelease, error) { + owner, repo := split.OnSlash(config.Repo) + data := &github.RepositoryRelease{ + Name: github.String(config.Git.CurrentTag), + TagName: github.String(config.Git.CurrentTag), + Body: github.String(description(config.Git.Diff)), + } + r, res, err := client.Repositories.GetReleaseByTag(owner, repo, config.Git.CurrentTag) + if res.StatusCode == 404 { + log.Println("Creating release", config.Git.CurrentTag, "on", config.Repo, "...") + r, _, err := client.Repositories.CreateRelease(owner, repo, data) + return r, err + } + log.Println("Updating existing release", config.Git.CurrentTag, "on", config.Repo, "...") + r, _, err = client.Repositories.EditRelease(owner, repo, *r.ID, data) + return r, err +} + func description(diff string) string { result := "## Changelog\n" + diff + "\n\n--\nAutomated with @goreleaser" cmd := exec.Command("go", "version") From ba7a8ae7a29bb900bc76c488d8097f35a92b0aef Mon Sep 17 00:00:00 2001 From: Carlos Alexandro Becker Date: Fri, 13 Jan 2017 21:45:16 -0200 Subject: [PATCH 2/2] lint --- pipeline/release/release.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pipeline/release/release.go b/pipeline/release/release.go index 399a3e075..98cf6b4dc 100644 --- a/pipeline/release/release.go +++ b/pipeline/release/release.go @@ -54,9 +54,9 @@ func getOrCreateRelease(client *github.Client, config config.ProjectConfig) (*gi Body: github.String(description(config.Git.Diff)), } r, res, err := client.Repositories.GetReleaseByTag(owner, repo, config.Git.CurrentTag) - if res.StatusCode == 404 { + if err != nil && res.StatusCode == 404 { log.Println("Creating release", config.Git.CurrentTag, "on", config.Repo, "...") - r, _, err := client.Repositories.CreateRelease(owner, repo, data) + r, _, err = client.Repositories.CreateRelease(owner, repo, data) return r, err } log.Println("Updating existing release", config.Git.CurrentTag, "on", config.Repo, "...")