mirror of
https://github.com/openclaw/openclaw.git
synced 2026-06-30 17:03:40 +00:00
fix(ci): require OpenGrep SARIF artifacts
This commit is contained in:
@@ -6,6 +6,8 @@ import { parse } from "yaml";
|
||||
const CHECKOUT_V6 = "actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10";
|
||||
const CACHE_V5 = "actions/cache/restore@27d5ce7f107fe9357f9df03efb73ab90386fccae";
|
||||
const UPLOAD_ARTIFACT_V7 = "actions/upload-artifact@043fb46d1a93c77aae656e7c1c64a875d1fc6a0a";
|
||||
const OPENGREP_PR_DIFF_WORKFLOW = ".github/workflows/opengrep-precise.yml";
|
||||
const OPENGREP_FULL_WORKFLOW = ".github/workflows/opengrep-precise-full.yml";
|
||||
|
||||
function readCiWorkflow() {
|
||||
return parse(readFileSync(".github/workflows/ci.yml", "utf8"));
|
||||
@@ -104,6 +106,34 @@ describe("ci workflow guards", () => {
|
||||
expect(findUnpinnedExternalActions()).toEqual([]);
|
||||
});
|
||||
|
||||
it("fails OpenGrep SARIF artifact uploads when reports are missing", () => {
|
||||
const cases = [
|
||||
{
|
||||
workflowPath: OPENGREP_PR_DIFF_WORKFLOW,
|
||||
artifactName: "opengrep-pr-diff-sarif",
|
||||
},
|
||||
{
|
||||
workflowPath: OPENGREP_FULL_WORKFLOW,
|
||||
artifactName: "opengrep-full-sarif",
|
||||
},
|
||||
];
|
||||
|
||||
for (const item of cases) {
|
||||
const workflow = parse(readFileSync(item.workflowPath, "utf8"));
|
||||
const uploadStep = workflow.jobs.scan.steps.find(
|
||||
(step) => step.name === "Upload SARIF as workflow artifact",
|
||||
);
|
||||
|
||||
expect(uploadStep.if, item.workflowPath).toBe("always()");
|
||||
expect(uploadStep.uses, item.workflowPath).toBe(UPLOAD_ARTIFACT_V7);
|
||||
expect(uploadStep.with, item.workflowPath).toMatchObject({
|
||||
name: item.artifactName,
|
||||
path: ".opengrep-out/precise.sarif",
|
||||
"if-no-files-found": "error",
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
it("runs real behavior proof from the trusted workflow revision", () => {
|
||||
const workflow = readRealBehaviorProofWorkflow();
|
||||
const source = readFileSync(".github/workflows/real-behavior-proof.yml", "utf8");
|
||||
|
||||
@@ -68,6 +68,53 @@ describe("run-opengrep.sh", () => {
|
||||
expect(args).toContain("security/opengrep/precise.yml");
|
||||
});
|
||||
|
||||
it("writes empty SARIF when a changed scan has no first-party paths", () => {
|
||||
const repo = createTempDir("openclaw-run-opengrep-empty-sarif-");
|
||||
git(repo, "init", "-q");
|
||||
git(repo, "config", "user.email", "test@example.com");
|
||||
git(repo, "config", "user.name", "Test User");
|
||||
|
||||
copyRunOpengrepFiles(repo);
|
||||
writeFile(path.join(repo, "security/opengrep/precise.yml"), "rules: []\n");
|
||||
writeFile(path.join(repo, ".github/actions/ensure-base-commit/action.yml"), "name: ensure\n");
|
||||
git(repo, "add", ".");
|
||||
git(repo, "commit", "-qm", "initial");
|
||||
|
||||
fs.appendFileSync(path.join(repo, ".github/actions/ensure-base-commit/action.yml"), "# changed\n");
|
||||
const argsPath = path.join(repo, "opengrep-args.txt");
|
||||
const binDir = path.join(repo, "bin");
|
||||
fs.mkdirSync(binDir);
|
||||
writeFile(
|
||||
path.join(binDir, "opengrep"),
|
||||
[
|
||||
"#!/usr/bin/env bash",
|
||||
`printf '%s\\n' "$@" > ${JSON.stringify(argsPath)}`,
|
||||
"exit 0",
|
||||
"",
|
||||
].join("\n"),
|
||||
);
|
||||
fs.chmodSync(path.join(binDir, "opengrep"), 0o755);
|
||||
|
||||
execFileSync("bash", ["scripts/run-opengrep.sh", "--changed", "--sarif", "--error"], {
|
||||
cwd: repo,
|
||||
env: {
|
||||
...process.env,
|
||||
PATH: `${binDir}${path.delimiter}${process.env.PATH ?? ""}`,
|
||||
OPENCLAW_OPENGREP_BASE_REF: "HEAD",
|
||||
},
|
||||
encoding: "utf8",
|
||||
});
|
||||
|
||||
const sarif = JSON.parse(
|
||||
fs.readFileSync(path.join(repo, ".opengrep-out/precise.sarif"), "utf8"),
|
||||
);
|
||||
expect(sarif.version).toBe("2.1.0");
|
||||
expect(sarif.runs[0].tool.driver.name).toBe("Opengrep OSS");
|
||||
expect(sarif.runs[0].tool.driver.semanticVersion).toBe("1.22.0");
|
||||
expect(sarif.runs[0].results).toEqual([]);
|
||||
expect(fs.existsSync(argsPath)).toBe(false);
|
||||
});
|
||||
|
||||
it("scans PR files instead of main-only files when the payload base is stale", () => {
|
||||
const repo = createTempDir("openclaw-run-opengrep-merge-");
|
||||
git(repo, "init", "-q", "--initial-branch=main");
|
||||
|
||||
Reference in New Issue
Block a user