docs-util: fix release scripts (#6353)

- Fix GitHub action to run on push and check if the commit message is "chore: Release". Only then are TSDocs generated and a PR is opened.
- Add an option to pass to the `run:release` method of the docblock generator a release tag. This is helpful in cases when the GitHub action fails for any reason.
- Add scripts that checks the message of a commit.
This commit is contained in:
Shahed Nasser
2024-02-08 22:36:27 +02:00
committed by GitHub
parent ef64f3740d
commit 66e8f4e0d2
7 changed files with 88 additions and 9 deletions

View File

@@ -0,0 +1,38 @@
import { Octokit } from "@octokit/core"
import * as core from "@actions/core"
const commitSha = process.argv.length >= 3 ? process.argv[2] : null
const octokit = new Octokit({
auth: process.env.GH_TOKEN,
})
async function checkReleaseCommit() {
if (!commitSha) {
throw new Error("Commit SHA is required.")
}
// retrieve commit by the SHA
const { data: commit } = await octokit.request(
"GET /repos/{owner}/{repo}/commits/{ref}",
{
owner: process.env.GIT_OWNER || "",
repo: process.env.GIT_REPO || "",
ref: commitSha,
headers: {
"X-GitHub-Api-Version": "2022-11-28",
},
}
)
if (!commit) {
throw new Error("Commit doesn't exist.")
}
core.setOutput(
"is_release_commit",
commit.commit.message === "chore: Release"
)
}
void checkReleaseCommit()

View File

@@ -6,11 +6,13 @@
"access": "public"
},
"scripts": {
"build": "tsc",
"generate:announcement": "ts-node ./doc-change-release.ts",
"generate:reference": "ts-node ./generate-reference.ts",
"merge:references": "yarn generate:reference merge",
"check:freshness": "ts-node ./freshness-check.ts",
"generate:message": "ts-node ./get-generate-diff-message.ts"
"generate:message": "ts-node ./get-generate-diff-message.ts",
"check:release-commit": "node ./dist/check-release-commit.js"
},
"version": "0.0.0",
"type": "module",

View File

@@ -4,6 +4,7 @@
"outDir": "./dist",
"module": "ESNext",
"moduleResolution": "node",
"rootDir": ".",
},
"include": ["*.ts"],
"ts-node": {