mirror of
https://github.com/n8n-io/n8n.git
synced 2026-05-12 16:10:30 +02:00
ci: Detect new unpublished packages after merge and add manual publish workflow (#27611)
Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
parent
44af2a1bbd
commit
d1fd399ca2
9
.github/scripts/detect-new-packages.mjs
vendored
9
.github/scripts/detect-new-packages.mjs
vendored
|
|
@ -16,6 +16,7 @@
|
|||
|
||||
import child_process from 'child_process';
|
||||
import { promisify } from 'util';
|
||||
import { writeGithubOutput } from './github-helpers.mjs';
|
||||
|
||||
const exec = promisify(child_process.exec);
|
||||
|
||||
|
|
@ -31,6 +32,7 @@ for (const { name, private: isPrivate } of packages) {
|
|||
const url = `https://registry.npmjs.org/${encodedName}`;
|
||||
|
||||
try {
|
||||
console.log(`Checking if ${name} exists...`);
|
||||
const response = await fetch(url, { method: 'HEAD' });
|
||||
if (response.status === 404) {
|
||||
newPackages.push(name);
|
||||
|
|
@ -63,7 +65,6 @@ OIDC Trusted Publishing until they have been published at least once manually:
|
|||
`);
|
||||
|
||||
for (const pkg of newPackages) {
|
||||
console.log(` - ${pkg}`);
|
||||
console.log(
|
||||
`::error::Package "${pkg}" has never been published to npm. A manual first-publish with an NPM token is required before it can use OIDC Trusted Publishing.`,
|
||||
);
|
||||
|
|
@ -88,4 +89,10 @@ Steps to unblock the release, for each new package listed above:
|
|||
3. Re-run the Release: Publish workflow.
|
||||
|
||||
`);
|
||||
|
||||
const output = {
|
||||
packages: newPackages.join(','),
|
||||
};
|
||||
console.log(` -- Writing to github output: ${JSON.stringify(output)}`);
|
||||
writeGithubOutput(output);
|
||||
process.exit(1);
|
||||
|
|
|
|||
47
.github/workflows/ci-detect-new-packages.yml
vendored
Normal file
47
.github/workflows/ci-detect-new-packages.yml
vendored
Normal file
|
|
@ -0,0 +1,47 @@
|
|||
name: 'CI: Detect New Packages on Master'
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
types:
|
||||
- closed
|
||||
branches:
|
||||
- master
|
||||
|
||||
jobs:
|
||||
detect-new-packages:
|
||||
name: Check for new unpublished packages
|
||||
runs-on: ubuntu-latest
|
||||
if: github.event.pull_request.merged == true
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-nodejs
|
||||
with:
|
||||
build-command: ''
|
||||
install-command: pnpm install --frozen-lockfile --dir ./.github/scripts --ignore-workspace
|
||||
|
||||
- name: Check for new unpublished packages
|
||||
id: detect
|
||||
continue-on-error: true
|
||||
run: node .github/scripts/detect-new-packages.mjs
|
||||
|
||||
- name: Notify Slack about new packages
|
||||
if: steps.detect.outcome == 'failure' && steps.detect.outputs.packages != ''
|
||||
uses: slackapi/slack-github-action@91efab103c0de0a537f72a35f6b8cda0ee76bf0a # v2.1.1
|
||||
with:
|
||||
method: chat.postMessage
|
||||
token: ${{ secrets.RELEASE_HELPER_SLACK_TOKEN }}
|
||||
payload: |
|
||||
channel: C036AELNMV0
|
||||
text: |-
|
||||
:warning: *New unpublished packages detected* after merging <${{ github.event.pull_request.html_url }}|PR #${{ github.event.pull_request.number }}: ${{ github.event.pull_request.title }}>
|
||||
|
||||
The following packages do not exist on npm yet: `${{ steps.detect.outputs.packages }}`
|
||||
|
||||
*If a package is not intended for npm*, set `"private": true` in its `package.json` to exclude it from future checks.
|
||||
|
||||
*Otherwise, to unblock the next release:*
|
||||
1. Run the <${{ github.server_url }}/${{ github.repository }}/actions/workflows/release-publish-new-package.yml|Release: Publish New Package> workflow for each package
|
||||
2. Configure Trusted Publishing on npmjs.com (owner: `n8n-io`, repo: `n8n`, workflow: `release-publish.yml`)
|
||||
40
.github/workflows/release-publish-new-package.yml
vendored
Normal file
40
.github/workflows/release-publish-new-package.yml
vendored
Normal file
|
|
@ -0,0 +1,40 @@
|
|||
name: 'Release: Publish New Package'
|
||||
|
||||
on:
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
package-path:
|
||||
description: 'Path to the package to publish (e.g. packages/@n8n/my-new-package)'
|
||||
required: true
|
||||
type: string
|
||||
|
||||
concurrency:
|
||||
group: release-new-package-${{ github.event.inputs.package-path }}
|
||||
cancel-in-progress: false
|
||||
|
||||
jobs:
|
||||
publish-to-npm:
|
||||
name: Publish to NPM
|
||||
runs-on: ubuntu-latest
|
||||
timeout-minutes: 30
|
||||
environment: release
|
||||
|
||||
steps:
|
||||
- name: Check branch
|
||||
if: github.ref != 'refs/heads/master'
|
||||
run: |
|
||||
echo "::error::This workflow can only be run from the master branch"
|
||||
exit 1
|
||||
|
||||
- name: Checkout
|
||||
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
||||
|
||||
- name: Setup and Build
|
||||
uses: ./.github/actions/setup-nodejs
|
||||
|
||||
- name: Configure NPM token
|
||||
run: echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" > ~/.npmrc
|
||||
|
||||
- name: Publish package
|
||||
working-directory: ${{ github.event.inputs.package-path }}
|
||||
run: pnpm publish --access public --no-git-checks
|
||||
Loading…
Reference in New Issue
Block a user