-
Notifications
You must be signed in to change notification settings - Fork 17.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
x/tools, x/build: create a relui workflow for gopls release automation #57643
Comments
Change https://go.dev/cl/462517 mentions this issue: |
Change https://go.dev/cl/462815 mentions this issue: |
Narrow the scope of the release script to simply verifying that the release is ready. Remove: - checks for the release branch; the current branch doesn't matter for tagging - the -release and -remote flags, since we won't be using this script for performing the release Updates golang/go#57643 Change-Id: I80a5e367ad5b7df1d85f3af023dc10ccef242702 Reviewed-on: https://go-review.googlesource.com/c/tools/+/462815 Reviewed-by: Dylan Le <dungtuanle@google.com> TryBot-Result: Gopher Robot <gobot@golang.org> Run-TryBot: Robert Findley <rfindley@google.com> gopls-CI: kokoro <noreply+kokoro@google.com>
Change https://go.dev/cl/601236 mentions this issue: |
1. Param: coordinator need to provide the version string that will be released. 2. Task: validate the input version a valid version. 3. Output: returns whether the input version is valid. For golang/go#57643 Change-Id: Ib6d3f10c9a46ad2f24b0a1fc053265456d152f41 Reviewed-on: https://go-review.googlesource.com/c/build/+/601236 Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
Change https://go.dev/cl/601655 mentions this issue: |
In the next change, we will add a step to create a branch for a minor version (X.Y.0) release. In my local run, the release flow failed because of permission denied issue when trying to create the next minor release branch |
1. Add new method CreateBranch to interface GerritClient. a. Implement CreateBranch real gerrit client follow gerrit documentation. b. Implement CreateBranch using git branch for fake client. 2. Change fake gerrit client implementation of ReadBranchHead to return empty string if encounter error to align return value with the real client. 3. Change return type of isValidVersion to semantic version to avoid future code duplication. 4. Add a new action CreateBranchIfMinor to gopls release after converting the input version string to semantic version struct. A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2258617146. For golang/go#57643 Change-Id: I36eb88625ed6036eb322c39b345aee3f1ffa3f5c Reviewed-on: https://go-review.googlesource.com/c/build/+/601655 Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
In the next change, we will add a step to change the In my local run, I short circuit the previous steps (i.e. version validation, branch creation). Provide input parameter So the flow will create a CL to update |
Change https://go.dev/cl/601241 mentions this issue: |
In the next change, we will add a step to update the The way of updating the dependency:
In my local run, I short circuit the previous steps (i.e. branch creation). Provide input parameter version = The CL created update the
And the
The CL change the version of |
Change https://go.dev/cl/602516 mentions this issue: |
1. Add optional parameter reviewers to gopls release flow. 2. Add a Task to update code review configuration in release branch. 3. Add a Action to wait for CL to be submitted. A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2259049777 For golang/go#57643 Change-Id: Iae3ebd5dd7bc9040979185aa353e2a4afed8cb54 Reviewed-on: https://go-review.googlesource.com/c/build/+/601241 Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org>
updateXToolsDependency will drop the replace directive in gopls sub module and pin the x/tools version to the head of the current gopls release branch. A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2263725465 For golang/go#57643 Change-Id: I0d9f4462b71b394ff432bc65142cf35e70977e6a Reviewed-on: https://go-review.googlesource.com/c/build/+/602516 Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
In the next change, we will add a step to verify we can successfully install gopls from the head of the branch using the Update: The gopls verification will download the gopls using the commit from the previous merged CL. (If the previous step does not merge any CL, using the commit from head of release branch). Run a simple smoke test by |
Change https://go.dev/cl/603036 mentions this issue: |
In the next change, we will add a step to tag the pre-release for a given release. In my local run, I tried to release a new gopls version 0.16.2. (This is the next patch version so there is no tag related to this release). The flow realize he should tag this release branch's ( My personal credential do not have permission to tag this repo. So I get 403 permission denied error. (Just like steps above, I did short-circuit a few steps to make this happen) |
Change https://go.dev/cl/602520 mentions this issue: |
1. Install gopls using the commit from the previous CL or using the head of the release branch. 2. Print gopls version as informational log. 3. Run smoke test using gopls references. A local relui screenshot is at golang/go#57643 (comment) For golang/go#57643 Change-Id: I2a79a0ac35c78c8277a7b5e8a32af82edb9d0573 Reviewed-on: https://go-review.googlesource.com/c/build/+/603036 Reviewed-by: Robert Findley <rfindley@google.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org>
Change https://go.dev/cl/603875 mentions this issue: |
A local relui screenshot is at golang/go#57643 (comment) For golang/go#57643 Change-Id: I5b302086afd632839ac034a7e04a7bf7da49d0db Reviewed-on: https://go-review.googlesource.com/c/build/+/602520 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org>
Next change, the release automation will find the release milestone and create a release tracking issue. All the CL created for this release should reference this issue (part of the commit message). Happy case 1: release milestone exist, release issue does not exist. A new issue should be created, CL should have this issue number in commit message. Happy case 2: release milestone exist, release issue exist. All the CL should refer to this pre-existing issue. Failure case: the milestone is closed. The flow should error out. |
Change https://go.dev/cl/603876 mentions this issue: |
Next change, the release automation will re-run a verification after tag the pre-release version. So the workflow will verify the gopls installation twice. From the high level, the flow looks like this:
In my local relui, a lot of steps are being short circuited. |
Change https://go.dev/cl/606336 mentions this issue: |
Change https://go.dev/cl/606876 mentions this issue: |
Have you also considered doing both updates in one CL, and does splitting it out into two parallel CLs end up working out better? |
Hi Dmitri, we have some more update on the CL comment. It turns out, we only need to update the gopls sub module in the But you have a good point, if we ever need to perform two operations, why not just do things together. |
1. Extract the awaitSubmission method so that it can be shared by multiple workflows. 2. Add an executeAndMonitorChange helper, to run a script and return any change to the file list provided. 3. Add a task to the gopls release flow to upgrade dependency for x/tools' gopls submodule in master branch. (only for minor version release) 4. Update the gopls release flow to accept CL reviewers as a parameter. A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2294232653 For golang/go#57643 Change-Id: I9cb6495956409ce9a3712584278ba0e031e48cfc Reviewed-on: https://go-review.googlesource.com/c/build/+/606336 Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> Reviewed-by: Robert Findley <rfindley@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
As discussed offline within tooling gophers, we think at the end of the flow, we should send an email announcement. The end state will be:
But right now, we want to do some internal testing first. So both release and pre-release flow will send email to tooling gophers only. At some point in the future, we may also send the final release email to a publicly visible distribution. |
Change https://go.dev/cl/607497 mentions this issue: |
In the next CL, we will introduce the wait for approval step in pre-release flow. In local relui, I tried to run step after figure out the pre-release version. The release coordinator is suppose to take a look at the version printed in the relui and either approve or deny (which is stop button on the top right). The Once I approve it, the flow will move forward |
Update cmd/relui to accept gopls announcement receiver and sender. For golang/go#57643 Change-Id: I8271a778a77ea01a51314128b21b7d6b26a273b9 Reviewed-on: https://go-review.googlesource.com/c/build/+/606876 Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Robert Findley <rfindley@google.com>
Change https://go.dev/cl/607896 mentions this issue: |
Keeping one struct gopls release task which can create both gopls release workflow and pre-release workflow using different method. For golang/go#57643 Change-Id: I8880684ab1cc0068b1a02f8bc3d791f3ad98bcfe Reviewed-on: https://go-review.googlesource.com/c/build/+/607497 Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> Reviewed-by: Robert Findley <rfindley@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2305572494 For golang/go#57643 Change-Id: Iab10d6b4adbb04cfa8381d4e4776c3166ae40f41 Reviewed-on: https://go-review.googlesource.com/c/build/+/607896 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> Reviewed-by: Robert Findley <rfindley@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> Commit-Queue: Hongxiang Jiang <hxjiang@golang.org>
The next CL, we will add a selection input parameter The UI looks like: Coordinator will use this field to select which kind of version he/she want to release. But the old input parameter Most of the case should be handled by the selection instead of the manual input. Use the Use the |
Change https://go.dev/cl/608415 mentions this issue: |
Coordinator have three options to run the pre-release flow: * next minor or next patch, the flow will interpret the user intention. * use explicit version, the user must input the version explicitly. A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2310730081 For golang/go#57643 Change-Id: I9621da87f248c79597641162682fb2d108bc19f9 Reviewed-on: https://go-review.googlesource.com/c/build/+/608415 Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> Reviewed-by: Robert Findley <rfindley@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
The next CL, we will apply the same change from pre-release to the release flow. (Meaning the release flow will also accept input selection) SCREENSHOT1: run the release flow with SCREENSHOT2: run with |
Change https://go.dev/cl/609078 mentions this issue: |
Change https://go.dev/cl/610236 mentions this issue: |
The release issue will be referenced by all CLs generated by the gopls release process. For golang/go#57643 Change-Id: Icc44aeab84a7a1fc3c624267cb398729371db068 Reviewed-on: https://go-review.googlesource.com/c/build/+/610236 Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Robert Findley <rfindley@google.com>
A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2326945383 For golang/go#57643 Change-Id: I8168c59552ebcdbc4626b28e8fd456816dd8bf7c Reviewed-on: https://go-review.googlesource.com/c/build/+/609078 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> Reviewed-by: Robert Findley <rfindley@google.com>
Next change, we will add the same approval step in gopls release process. This process will print out the pre-release version will be released in this flow execution, the coordinator will check the log and click approve so the flow can move forward. SCREENSHOT: run the flow with next patch, the flow find the release candidate I want to release is SCREENSHOT: run the flow with next minor, the flow figured out the release but can not find any rc for that release. |
Change https://go.dev/cl/610536 mentions this issue: |
Fix a bug where inputVersion and versionBumpStrategy arguments were switched in the determineReleaseVersion step. Also, add a step to wait for explicit user approval for the gopls release. A local relui screenshot is at https://go.dev/issue/57643#issuecomment-2329523260 For golang/go#57643 Change-Id: I2201e046970cea4e14fa12e040020dcd54e20940 Reviewed-on: https://go-review.googlesource.com/c/build/+/610536 Reviewed-by: Robert Findley <rfindley@google.com> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Change https://go.dev/cl/610895 mentions this issue: |
Change https://go.dev/cl/611475 mentions this issue: |
For golang/go#57643 Change-Id: I6ba563b941df4ce703281163f2aaa714f57f3646 Reviewed-on: https://go-review.googlesource.com/c/build/+/610895 Reviewed-by: Robert Findley <rfindley@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> Auto-Submit: Hongxiang Jiang <hxjiang@golang.org>
For golang/go#57643 Change-Id: I2f95f961648c9aa9a8c126982cace1a7814ae9a1 Reviewed-on: https://go-review.googlesource.com/c/build/+/611475 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Robert Findley <rfindley@google.com>
We have successfully executee the gopls release and prerelease flow for gopls v0.16.2. So all the implementation necessary is done for this effort. Hopefully all the future release will be simple and only need button clicking! |
This issue tracks the relui workflow to automate gopls release namely:
CC @findleyr
The text was updated successfully, but these errors were encountered: