feat(besadii): Link to started builds in CL comments
This makes it easier to click through to a build from Gerrit after submitting a CL. Change-Id: Ic5c6eeb81c87bc4ea23c5c5ca25704434b081fd0 Reviewed-on: https://cl.tvl.fyi/c/depot/+/3572 Tested-by: BuildkiteCI Reviewed-by: lukegb <lukegb@tvl.fyi>
This commit is contained in:
parent
ae93094ebf
commit
98e4d4b18f
1 changed files with 35 additions and 5 deletions
|
@ -60,6 +60,13 @@ type Build struct {
|
|||
Env map[string]string `json:"env"`
|
||||
}
|
||||
|
||||
// BuildResponse is the representation of Buildkite's success response
|
||||
// after triggering a build. This has many fields, but we only need
|
||||
// one of them.
|
||||
type buildResponse struct {
|
||||
WebUrl string `json:"web_url"`
|
||||
}
|
||||
|
||||
// reviewInput is a struct representing the data submitted to Gerrit
|
||||
// to post a review on a CL.
|
||||
//
|
||||
|
@ -138,13 +145,36 @@ func triggerBuild(log *syslog.Writer, token string, update *refUpdated) error {
|
|||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
if resp.StatusCode != 201 {
|
||||
respBody, _ := ioutil.ReadAll(resp.Body)
|
||||
log.Err(fmt.Sprintf("received non-success response from Buildkite: %s (%v)", respBody, resp.Status))
|
||||
} else {
|
||||
fmt.Fprintf(log, "triggered Buildkite build for ref %q at commit %q", update.ref, update.commit)
|
||||
respBody, err := ioutil.ReadAll(resp.Body)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to read Buildkite response body: %w", err)
|
||||
}
|
||||
|
||||
if resp.StatusCode != http.StatusCreated {
|
||||
return fmt.Errorf("received non-success response from Buildkite: %s (%v)", respBody, resp.Status)
|
||||
}
|
||||
|
||||
var buildResp buildResponse
|
||||
err = json.Unmarshal(respBody, &buildResp)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to unmarshal build response: %w", err)
|
||||
}
|
||||
|
||||
fmt.Fprintf(log, "triggered build for ref %q at commit %q: %s", update.ref, update.commit, buildResp.WebUrl)
|
||||
|
||||
// Report the status back to the Gerrit CL so that users can click
|
||||
// through to the running build.
|
||||
msg := fmt.Sprintf("Started build for patchset #%s of cl/%s: %s", *update.patchset, *update.changeId, buildResp.WebUrl)
|
||||
review := reviewInput{
|
||||
Message: msg,
|
||||
OmitDuplicateComments: true,
|
||||
Tag: "autogenerated:buildkite~trigger",
|
||||
|
||||
// Do not update the attention set for this comment.
|
||||
IgnoreDefaultAttentionSetRules: true,
|
||||
}
|
||||
updateGerrit(review, *update.changeId, *update.patchset)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue