- version-stamp.mjs: regenerate package-lock.json after dev version stamp (mirrors the same fix applied to bump-version.mjs in #4116) - bump-version.mjs: regenerate root and web/package-lock.json after version bump so both lockfiles are always in sync at release time - pipeline.yml: add post-bump validation step that verifies all package.json files parse as valid JSON before the release commit is made - pipeline.yml: split "Commit, tag, and push" — commit+tag+rebase happen before build, but git push is deferred until after build and npm publish both succeed, preventing a broken tag from landing on main - pipeline.yml: emit a :⚠️: annotation when live LLM tests fail so failures are visible in the Actions UI instead of silently swallowed Closes #4118 Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com>
22 lines
1,017 B
JavaScript
22 lines
1,017 B
JavaScript
import { readFileSync, writeFileSync } from "fs";
|
|
import { execFileSync, execSync } from "child_process";
|
|
import { fileURLToPath } from "url";
|
|
import { dirname, resolve } from "path";
|
|
|
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
const root = resolve(__dirname, "..");
|
|
|
|
const pkgPath = new URL("../package.json", import.meta.url);
|
|
const pkg = JSON.parse(readFileSync(pkgPath, "utf8"));
|
|
|
|
const shortSha = execFileSync("git", ["rev-parse", "--short", "HEAD"], { encoding: "utf8" }).trim();
|
|
const devVersion = `${pkg.version}-dev.${shortSha}`;
|
|
|
|
pkg.version = devVersion;
|
|
writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
|
|
console.log(`Stamped version: ${devVersion}`);
|
|
|
|
// Regenerate package-lock.json to reflect the stamped dev version.
|
|
// --package-lock-only updates the lockfile in-place without touching node_modules.
|
|
execSync("npm install --package-lock-only --ignore-scripts", { cwd: root, stdio: "inherit" });
|
|
console.log(`[version-stamp] package-lock.json regenerated at ${devVersion}`);
|