Skip to content
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

Add workflow to publish npm packages #3850

Merged
merged 1 commit into from
Jan 20, 2025

Conversation

AlanGreene
Copy link
Member

@AlanGreene AlanGreene commented Dec 18, 2024

Changes

Add workflow to handle automatically publishing packages to the npm registry when the commit message matches the expected format: Publish <version> of the @tektoncd/dashboard-* packages

For PRs it validates the PR is up-to-date with the base branch and that the PR title and commit message match.

For both PRs and pushes it validates that the version in the commit message matches the version in the package.json files.

Once all validation passes, it will publish the package (dry-run for PR).

This simplifies the process of releasing new package versions as now it only requires running the npm version --workspaces <version> command and committing the result. The rest of the process, i.e. ensuring inter-workspace dependencies are updated to use the correct versions before publishing, is handled by the workflow.

Also generate provenance statements for the packages.

Skip all steps if commit message or PR title don't match expected format so the job passes and doesn't block unrelated PRs for dependency updates etc.

/kind misc

Submitter Checklist

As the author of this PR, please check off the items in this checklist:

  • Docs included if any changes are user facing
  • Tests included if any functionality added or changed
  • Follows the commit message standard
  • Meets the Tekton contributor standards (including
    functionality, content, code)
  • Has a kind label. You can add one by adding a comment on this PR that contains /kind <type>. Valid types are bug, cleanup, design, documentation, feature, flake, misc, question, tep
  • Release notes block below has been updated with any user facing changes (new features, significant UI changes, API changes, bug fixes, changes requiring upgrade notices or deprecation warnings)
  • Release notes contains the string "action required" if the change requires additional action from users switching to the new release

Release Notes

NONE

@tekton-robot
Copy link
Contributor

Skipping CI for Draft Pull Request.
If you want CI signal for your change, please convert it to an actual PR.
You can still manually trigger a test run with /test all

@tekton-robot tekton-robot added do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. kind/misc Categorizes issue or PR as a miscellaneuous one. labels Dec 18, 2024
@tekton-robot tekton-robot added the size/L Denotes a PR that changes 100-499 lines, ignoring generated files. label Dec 18, 2024
@AlanGreene AlanGreene removed the request for review from skaegi December 18, 2024 15:43
@AlanGreene AlanGreene requested a review from LyndseyBu January 2, 2025 15:09
@AlanGreene AlanGreene marked this pull request as ready for review January 6, 2025 13:16
@tekton-robot tekton-robot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Jan 6, 2025
@AlanGreene AlanGreene marked this pull request as draft January 6, 2025 15:45
@tekton-robot tekton-robot added the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Jan 6, 2025
@AlanGreene

This comment was marked as resolved.

@AlanGreene AlanGreene force-pushed the gha_publish branch 3 times, most recently from 7a62def to ac0e9f6 Compare January 7, 2025 15:52
@AlanGreene AlanGreene marked this pull request as ready for review January 7, 2025 16:00
@tekton-robot tekton-robot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Jan 7, 2025
@tekton-robot tekton-robot requested a review from skaegi January 7, 2025 16:00
@AlanGreene AlanGreene removed the request for review from skaegi January 7, 2025 16:04
Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@tekton-robot tekton-robot added lgtm Indicates that a PR is ready to be merged. approved Indicates a PR has been approved by an approver from all required OWNERS files. labels Jan 7, 2025
@tekton-robot tekton-robot removed the lgtm Indicates that a PR is ready to be merged. label Jan 7, 2025
Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@tekton-robot tekton-robot added the lgtm Indicates that a PR is ready to be merged. label Jan 8, 2025
@AlanGreene
Copy link
Member Author

AlanGreene commented Jan 9, 2025

Tide is treating a skipped job as failed. This was fixed in a later prow release so we would need to update. As we're currently moving significant amounts of work off prow we'll hold off on the update for now.

See https://github.com/kubernetes-sigs/prow/issues/130 for details of the change.

I'll revisit this workflow in a week or two when I have time to change how we handle the conditional execution to avoid leaving skipped jobs, or decide that we'll live with it since it'll only run when package.json and package-lock.json files are updated in the PR.

/hold

@tekton-robot tekton-robot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Jan 9, 2025
@tekton-robot tekton-robot removed the lgtm Indicates that a PR is ready to be merged. label Jan 14, 2025
Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@tekton-robot tekton-robot added the lgtm Indicates that a PR is ready to be merged. label Jan 14, 2025
@AlanGreene
Copy link
Member Author

/hold cancel

@tekton-robot tekton-robot removed the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Jan 14, 2025
@AlanGreene
Copy link
Member Author

/retest

@AlanGreene
Copy link
Member Author

Let's merge this and if it becomes annoying having to override the publish step on dependabot or other PRs modifying the package.json / package-lock.json files we can disable the job temporarily until we have a cleaner approach.

/override publish

@AlanGreene
Copy link
Member Author

Doesn't look like /override is going to work for us… 🤔

@tekton-robot tekton-robot removed the lgtm Indicates that a PR is ready to be merged. label Jan 18, 2025
@AlanGreene
Copy link
Member Author

/hold

@tekton-robot tekton-robot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Jan 18, 2025
@AlanGreene AlanGreene force-pushed the gha_publish branch 2 times, most recently from 629d9fc to 85f3f0e Compare January 18, 2025 13:58
Add workflow to handle automatically publishing packages to the
npm registry when the commit message matches the expected format:
`Publish <version> of the @tektoncd/dashboard-* packages`

For PRs it validates the PR is up-to-date with the base branch
and that the PR title and commit message match.

For both PRs and pushes it validates that the version in the commit
message matches the version in the package.json files.

Once all validation passes, it will publish the package (dry-run
for PR).

This simplifies the process of releasing new package versions as
now it only requires running the `npm version --workspaces <version>`
command and committing the result. The rest of the process, i.e.
ensuring inter-workspace dependencies are updated to use the correct
versions before publishing, is handled by the workflow.

Also generate provenance statements for the packages.

Skip all steps if commit message or PR title don't match expected format
so the job passes and doesn't block unrelated PRs for dependency updates
etc.
@AlanGreene
Copy link
Member Author

/hold cancel

@tekton-robot tekton-robot removed the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Jan 18, 2025
@AlanGreene
Copy link
Member Author

AlanGreene commented Jan 18, 2025

Moved the PR title / commit message check to the first step so the job will run (previously skipped which was causing the issues above), but then skip the remaining steps if it's not a publish commit. Because the job runs in this case but all steps are skipped, it is marked as successful and doesn't block unrelated PRs changing the package.json / package-lock.json files (e.g. dependabot or other dependency / config updates).

Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@tekton-robot tekton-robot added the lgtm Indicates that a PR is ready to be merged. label Jan 20, 2025
@tekton-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: briangleeson

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@tekton-robot tekton-robot merged commit 3944f5d into tektoncd:main Jan 20, 2025
13 checks passed
@AlanGreene AlanGreene deleted the gha_publish branch January 20, 2025 11:39
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. kind/misc Categorizes issue or PR as a miscellaneuous one. lgtm Indicates that a PR is ready to be merged. size/L Denotes a PR that changes 100-499 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants