2019-12-16 18:34:12 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/SAP/jenkins-library/pkg/log"
|
2020-02-04 11:46:43 +02:00
|
|
|
"github.com/SAP/jenkins-library/pkg/telemetry"
|
2020-09-14 12:05:12 +02:00
|
|
|
"github.com/google/go-github/v32/github"
|
2019-12-16 18:34:12 +02:00
|
|
|
"github.com/pkg/errors"
|
|
|
|
|
|
|
|
piperGithub "github.com/SAP/jenkins-library/pkg/github"
|
|
|
|
)
|
|
|
|
|
|
|
|
type githubPRService interface {
|
|
|
|
Create(ctx context.Context, owner string, repo string, pull *github.NewPullRequest) (*github.PullRequest, *github.Response, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
type githubIssueService interface {
|
|
|
|
Edit(ctx context.Context, owner string, repo string, number int, issue *github.IssueRequest) (*github.Issue, *github.Response, error)
|
|
|
|
}
|
|
|
|
|
2020-02-04 11:46:43 +02:00
|
|
|
func githubCreatePullRequest(config githubCreatePullRequestOptions, telemetryData *telemetry.CustomData) {
|
|
|
|
ctx, client, err := piperGithub.NewClient(config.Token, config.APIURL, "")
|
2019-12-16 18:34:12 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Entry().WithError(err).Fatal("Failed to get GitHub client")
|
|
|
|
}
|
|
|
|
|
2020-02-04 11:46:43 +02:00
|
|
|
err = runGithubCreatePullRequest(ctx, &config, client.PullRequests, client.Issues)
|
2019-12-16 18:34:12 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Entry().WithError(err).Fatal("Failed to create GitHub pull request")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-04 11:46:43 +02:00
|
|
|
func runGithubCreatePullRequest(ctx context.Context, config *githubCreatePullRequestOptions, ghPRService githubPRService, ghIssueService githubIssueService) error {
|
2019-12-16 18:34:12 +02:00
|
|
|
|
|
|
|
prRequest := github.NewPullRequest{
|
2020-02-04 11:46:43 +02:00
|
|
|
Title: &config.Title,
|
|
|
|
Head: &config.Head,
|
|
|
|
Base: &config.Base,
|
|
|
|
Body: &config.Body,
|
2019-12-16 18:34:12 +02:00
|
|
|
}
|
|
|
|
|
2020-02-04 11:46:43 +02:00
|
|
|
newPR, resp, err := ghPRService.Create(ctx, config.Owner, config.Repository, &prRequest)
|
2019-12-16 18:34:12 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Entry().Errorf("GitHub response code %v", resp.Status)
|
|
|
|
return errors.Wrap(err, "Error occured when creating pull request")
|
|
|
|
}
|
|
|
|
log.Entry().Debugf("New pull request created: %v", newPR)
|
|
|
|
|
|
|
|
issueRequest := github.IssueRequest{
|
2020-02-04 11:46:43 +02:00
|
|
|
Labels: &config.Labels,
|
|
|
|
Assignees: &config.Assignees,
|
2019-12-16 18:34:12 +02:00
|
|
|
}
|
|
|
|
|
2020-02-04 11:46:43 +02:00
|
|
|
updatedPr, resp, err := ghIssueService.Edit(ctx, config.Owner, config.Repository, newPR.GetNumber(), &issueRequest)
|
2019-12-16 18:34:12 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Entry().Errorf("GitHub response code %v", resp.Status)
|
|
|
|
return errors.Wrap(err, "Error occured when editing pull request")
|
|
|
|
}
|
|
|
|
log.Entry().Debugf("Updated pull request: %v", updatedPr)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|