mirror of
https://github.com/diegosouzapw/OmniRoute.git
synced 2026-05-03 00:30:26 +00:00
- Removed the expensive (40s+) `npm run test:unit` step from the `pre-commit` hook - Created `.husky/pre-push` to run the unit test suite before pushing rather than per commit - This prevents spurious async teardown errors from local test runners from blocking fast commits - Replaced an explicit `any` cast with `Record<string, unknown> | undefined` in `chatCore.ts` to pass the `check:any-budget:t11` strict checker which enforces a budget of 0
107 lines
2.8 KiB
JavaScript
107 lines
2.8 KiB
JavaScript
import { execFileSync } from "node:child_process";
|
|
import { mkdirSync, writeFileSync } from "node:fs";
|
|
import path from "node:path";
|
|
|
|
const SOURCE_ROOTS = ["src/", "open-sse/", "electron/", "bin/"];
|
|
const TEST_PATTERNS = [/^tests\//, /(?:^|\/)__tests__\//, /\.(?:test|spec)\.[cm]?[jt]sx?$/];
|
|
|
|
function getArg(name, fallbackValue = "") {
|
|
const index = process.argv.indexOf(name);
|
|
if (index === -1 || index === process.argv.length - 1) {
|
|
return fallbackValue;
|
|
}
|
|
return process.argv[index + 1];
|
|
}
|
|
|
|
function runGit(args) {
|
|
return execFileSync("git", args, { encoding: "utf8" }).trim();
|
|
}
|
|
|
|
function isSourceFile(filePath) {
|
|
return SOURCE_ROOTS.some((root) => filePath.startsWith(root));
|
|
}
|
|
|
|
function isTestFile(filePath) {
|
|
return TEST_PATTERNS.some((pattern) => pattern.test(filePath));
|
|
}
|
|
|
|
function buildReport(lines) {
|
|
return `${lines.join("\n")}\n`;
|
|
}
|
|
|
|
const summaryFile = getArg("--summary-file", "");
|
|
const baseRef = process.env.GITHUB_BASE_REF;
|
|
|
|
if (!baseRef) {
|
|
const report = buildReport([
|
|
"## PR Test Policy",
|
|
"",
|
|
"Skipped: not running in a pull request context.",
|
|
]);
|
|
|
|
if (summaryFile) {
|
|
mkdirSync(path.dirname(summaryFile), { recursive: true });
|
|
writeFileSync(summaryFile, report);
|
|
}
|
|
|
|
process.stdout.write(report);
|
|
process.exit(0);
|
|
}
|
|
|
|
const baseTarget = process.env.GITHUB_BASE_SHA || `origin/${baseRef}`;
|
|
const changedFiles = runGit(["diff", "--name-only", "--diff-filter=ACMR", `${baseTarget}...HEAD`])
|
|
.split(/\r?\n/)
|
|
.map((line) => line.trim())
|
|
.filter(Boolean);
|
|
|
|
const changedSourceFiles = changedFiles.filter(isSourceFile);
|
|
const changedTestFiles = changedFiles.filter(isTestFile);
|
|
const hasRequiredTests = changedSourceFiles.length === 0 || changedTestFiles.length > 0;
|
|
|
|
const reportLines = [
|
|
"## PR Test Policy",
|
|
"",
|
|
`Base ref: \`${baseRef}\``,
|
|
`Changed production files: ${changedSourceFiles.length}`,
|
|
`Changed automated test files: ${changedTestFiles.length}`,
|
|
"",
|
|
];
|
|
|
|
if (changedSourceFiles.length > 0) {
|
|
reportLines.push("### Production files in scope", "");
|
|
for (const filePath of changedSourceFiles.slice(0, 20)) {
|
|
reportLines.push(`- \`${filePath}\``);
|
|
}
|
|
reportLines.push("");
|
|
}
|
|
|
|
if (changedTestFiles.length > 0) {
|
|
reportLines.push("### Tests in this PR", "");
|
|
for (const filePath of changedTestFiles.slice(0, 20)) {
|
|
reportLines.push(`- \`${filePath}\``);
|
|
}
|
|
reportLines.push("");
|
|
}
|
|
|
|
if (hasRequiredTests) {
|
|
reportLines.push("Result: PASS");
|
|
} else {
|
|
reportLines.push(
|
|
"Result: FAIL",
|
|
"",
|
|
"This PR changes production code under `src/`, `open-sse/`, `electron/`, or `bin/` but does not add or update automated tests."
|
|
);
|
|
}
|
|
|
|
const report = buildReport(reportLines);
|
|
|
|
if (summaryFile) {
|
|
mkdirSync(path.dirname(summaryFile), { recursive: true });
|
|
writeFileSync(summaryFile, report);
|
|
}
|
|
|
|
process.stdout.write(report);
|
|
|
|
if (!hasRequiredTests) {
|
|
process.exit(1);
|
|
}
|