vaspera 2.9.0 → 2.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +122 -7
- package/README.md +58 -1
- package/dist/__tests__/autofix/branch-manager.test.d.ts +2 -0
- package/dist/__tests__/autofix/branch-manager.test.d.ts.map +1 -0
- package/dist/__tests__/autofix/branch-manager.test.js +60 -0
- package/dist/__tests__/autofix/branch-manager.test.js.map +1 -0
- package/dist/__tests__/autofix/commit-generator.test.d.ts +2 -0
- package/dist/__tests__/autofix/commit-generator.test.d.ts.map +1 -0
- package/dist/__tests__/autofix/commit-generator.test.js +147 -0
- package/dist/__tests__/autofix/commit-generator.test.js.map +1 -0
- package/dist/__tests__/autofix/constitution.test.d.ts +9 -0
- package/dist/__tests__/autofix/constitution.test.d.ts.map +1 -0
- package/dist/__tests__/autofix/constitution.test.js +421 -0
- package/dist/__tests__/autofix/constitution.test.js.map +1 -0
- package/dist/__tests__/autofix/pr-generator.test.d.ts +2 -0
- package/dist/__tests__/autofix/pr-generator.test.d.ts.map +1 -0
- package/dist/__tests__/autofix/pr-generator.test.js +152 -0
- package/dist/__tests__/autofix/pr-generator.test.js.map +1 -0
- package/dist/__tests__/property-test-helpers.d.ts +87 -0
- package/dist/__tests__/property-test-helpers.d.ts.map +1 -0
- package/dist/__tests__/property-test-helpers.js +136 -0
- package/dist/__tests__/property-test-helpers.js.map +1 -0
- package/dist/__tests__/scanners/dast/index.test.d.ts +2 -0
- package/dist/__tests__/scanners/dast/index.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/dast/index.test.js +183 -0
- package/dist/__tests__/scanners/dast/index.test.js.map +1 -0
- package/dist/__tests__/scanners/dast/nuclei.test.d.ts +2 -0
- package/dist/__tests__/scanners/dast/nuclei.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/dast/nuclei.test.js +166 -0
- package/dist/__tests__/scanners/dast/nuclei.test.js.map +1 -0
- package/dist/__tests__/scanners/dast/zap.test.d.ts +2 -0
- package/dist/__tests__/scanners/dast/zap.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/dast/zap.test.js +158 -0
- package/dist/__tests__/scanners/dast/zap.test.js.map +1 -0
- package/dist/__tests__/scanners/fp-feedback.test.d.ts +2 -0
- package/dist/__tests__/scanners/fp-feedback.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/fp-feedback.test.js +202 -0
- package/dist/__tests__/scanners/fp-feedback.test.js.map +1 -0
- package/dist/__tests__/scanners/fp-filter.property.test.d.ts +9 -0
- package/dist/__tests__/scanners/fp-filter.property.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/fp-filter.property.test.js +253 -0
- package/dist/__tests__/scanners/fp-filter.property.test.js.map +1 -0
- package/dist/__tests__/scanners/fp-filter.test.d.ts +2 -0
- package/dist/__tests__/scanners/fp-filter.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/fp-filter.test.js +234 -0
- package/dist/__tests__/scanners/fp-filter.test.js.map +1 -0
- package/dist/__tests__/scanners/fp-tracker.test.d.ts +2 -0
- package/dist/__tests__/scanners/fp-tracker.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/fp-tracker.test.js +262 -0
- package/dist/__tests__/scanners/fp-tracker.test.js.map +1 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.d.ts +10 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.js +238 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.js.map +1 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.test.d.ts +2 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.test.js +55 -0
- package/dist/__tests__/scanners/logic/endpoint-analyzer.test.js.map +1 -0
- package/dist/__tests__/scanners/logic/index.test.d.ts +2 -0
- package/dist/__tests__/scanners/logic/index.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/logic/index.test.js +165 -0
- package/dist/__tests__/scanners/logic/index.test.js.map +1 -0
- package/dist/__tests__/scanners/logic/types.test.d.ts +2 -0
- package/dist/__tests__/scanners/logic/types.test.d.ts.map +1 -0
- package/dist/__tests__/scanners/logic/types.test.js +85 -0
- package/dist/__tests__/scanners/logic/types.test.js.map +1 -0
- package/dist/action/pr-comment.test.js +4 -0
- package/dist/action/pr-comment.test.js.map +1 -1
- package/dist/action/sarif-upload.test.js +4 -0
- package/dist/action/sarif-upload.test.js.map +1 -1
- package/dist/autofix/branch-manager.d.ts +115 -0
- package/dist/autofix/branch-manager.d.ts.map +1 -0
- package/dist/autofix/branch-manager.js +308 -0
- package/dist/autofix/branch-manager.js.map +1 -0
- package/dist/autofix/commit-generator.d.ts +55 -0
- package/dist/autofix/commit-generator.d.ts.map +1 -0
- package/dist/autofix/commit-generator.js +277 -0
- package/dist/autofix/commit-generator.js.map +1 -0
- package/dist/autofix/constitution.d.ts +77 -0
- package/dist/autofix/constitution.d.ts.map +1 -0
- package/dist/autofix/constitution.js +261 -0
- package/dist/autofix/constitution.js.map +1 -0
- package/dist/autofix/constitution.schema.d.ts +441 -0
- package/dist/autofix/constitution.schema.d.ts.map +1 -0
- package/dist/autofix/constitution.schema.js +144 -0
- package/dist/autofix/constitution.schema.js.map +1 -0
- package/dist/autofix/index.d.ts +13 -0
- package/dist/autofix/index.d.ts.map +1 -0
- package/dist/autofix/index.js +15 -0
- package/dist/autofix/index.js.map +1 -0
- package/dist/autofix/pr-generator.d.ts +57 -0
- package/dist/autofix/pr-generator.d.ts.map +1 -0
- package/dist/autofix/pr-generator.js +597 -0
- package/dist/autofix/pr-generator.js.map +1 -0
- package/dist/autofix/types.d.ts +151 -0
- package/dist/autofix/types.d.ts.map +1 -0
- package/dist/autofix/types.js +22 -0
- package/dist/autofix/types.js.map +1 -0
- package/dist/eval/fixtures.d.ts +20 -0
- package/dist/eval/fixtures.d.ts.map +1 -1
- package/dist/eval/fixtures.js +430 -0
- package/dist/eval/fixtures.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +84 -1
- package/dist/index.js.map +1 -1
- package/dist/scanners/cache.d.ts.map +1 -1
- package/dist/scanners/cache.js +4 -0
- package/dist/scanners/cache.js.map +1 -1
- package/dist/scanners/dast/index.d.ts +39 -0
- package/dist/scanners/dast/index.d.ts.map +1 -0
- package/dist/scanners/dast/index.js +259 -0
- package/dist/scanners/dast/index.js.map +1 -0
- package/dist/scanners/dast/nuclei.d.ts +26 -0
- package/dist/scanners/dast/nuclei.d.ts.map +1 -0
- package/dist/scanners/dast/nuclei.js +354 -0
- package/dist/scanners/dast/nuclei.js.map +1 -0
- package/dist/scanners/dast/types.d.ts +306 -0
- package/dist/scanners/dast/types.d.ts.map +1 -0
- package/dist/scanners/dast/types.js +52 -0
- package/dist/scanners/dast/types.js.map +1 -0
- package/dist/scanners/dast/zap.d.ts +26 -0
- package/dist/scanners/dast/zap.d.ts.map +1 -0
- package/dist/scanners/dast/zap.js +453 -0
- package/dist/scanners/dast/zap.js.map +1 -0
- package/dist/scanners/fp-feedback.d.ts +140 -0
- package/dist/scanners/fp-feedback.d.ts.map +1 -0
- package/dist/scanners/fp-feedback.js +292 -0
- package/dist/scanners/fp-feedback.js.map +1 -0
- package/dist/scanners/fp-filter.d.ts +94 -0
- package/dist/scanners/fp-filter.d.ts.map +1 -0
- package/dist/scanners/fp-filter.js +397 -0
- package/dist/scanners/fp-filter.js.map +1 -0
- package/dist/scanners/fp-tracker.d.ts +125 -0
- package/dist/scanners/fp-tracker.d.ts.map +1 -0
- package/dist/scanners/fp-tracker.js +330 -0
- package/dist/scanners/fp-tracker.js.map +1 -0
- package/dist/scanners/index.d.ts.map +1 -1
- package/dist/scanners/index.js +56 -0
- package/dist/scanners/index.js.map +1 -1
- package/dist/scanners/index.test.js +6 -6
- package/dist/scanners/index.test.js.map +1 -1
- package/dist/scanners/logic/auth-flow-analyzer.d.ts +18 -0
- package/dist/scanners/logic/auth-flow-analyzer.d.ts.map +1 -0
- package/dist/scanners/logic/auth-flow-analyzer.js +384 -0
- package/dist/scanners/logic/auth-flow-analyzer.js.map +1 -0
- package/dist/scanners/logic/endpoint-analyzer.d.ts +29 -0
- package/dist/scanners/logic/endpoint-analyzer.d.ts.map +1 -0
- package/dist/scanners/logic/endpoint-analyzer.js +528 -0
- package/dist/scanners/logic/endpoint-analyzer.js.map +1 -0
- package/dist/scanners/logic/index.d.ts +41 -0
- package/dist/scanners/logic/index.d.ts.map +1 -0
- package/dist/scanners/logic/index.js +268 -0
- package/dist/scanners/logic/index.js.map +1 -0
- package/dist/scanners/logic/types.d.ts +254 -0
- package/dist/scanners/logic/types.d.ts.map +1 -0
- package/dist/scanners/logic/types.js +142 -0
- package/dist/scanners/logic/types.js.map +1 -0
- package/dist/scanners/types.d.ts +1 -1
- package/dist/scanners/types.d.ts.map +1 -1
- package/dist/scanners/types.js +4 -0
- package/dist/scanners/types.js.map +1 -1
- package/dist/telemetry/usage.d.ts +1 -1
- package/dist/telemetry/usage.d.ts.map +1 -1
- package/dist/telemetry/usage.js +14 -6
- package/dist/telemetry/usage.js.map +1 -1
- package/package.json +6 -8
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { parseZapAlerts } from "../../../scanners/dast/zap.js";
|
|
3
|
+
describe("zap scanner", () => {
|
|
4
|
+
describe("parseZapAlerts", () => {
|
|
5
|
+
it("parses ZAP alert to DASTFinding", () => {
|
|
6
|
+
const alert = {
|
|
7
|
+
sourceid: "1",
|
|
8
|
+
other: "",
|
|
9
|
+
method: "GET",
|
|
10
|
+
evidence: "<script>alert(1)</script>",
|
|
11
|
+
pluginId: "40012",
|
|
12
|
+
cweid: "79",
|
|
13
|
+
confidence: "High",
|
|
14
|
+
wascid: "8",
|
|
15
|
+
description: "Cross-site Scripting (XSS) is an attack technique...",
|
|
16
|
+
messageId: "1",
|
|
17
|
+
inputVector: "url",
|
|
18
|
+
url: "https://example.com/search?q=test",
|
|
19
|
+
tags: { "OWASP_2021_A03": "", "CWE-79": "" },
|
|
20
|
+
reference: "https://owasp.org/www-community/attacks/xss/",
|
|
21
|
+
solution: "Phase: Architecture and Design...",
|
|
22
|
+
alert: "Cross Site Scripting (Reflected)",
|
|
23
|
+
param: "q",
|
|
24
|
+
attack: "<script>alert(1)</script>",
|
|
25
|
+
name: "Cross Site Scripting (Reflected)",
|
|
26
|
+
risk: "High",
|
|
27
|
+
id: "1",
|
|
28
|
+
alertRef: "40012-1",
|
|
29
|
+
};
|
|
30
|
+
const findings = parseZapAlerts([alert]);
|
|
31
|
+
expect(findings).toHaveLength(1);
|
|
32
|
+
expect(findings[0].scanner).toBe("zap");
|
|
33
|
+
expect(findings[0].ruleId).toBe("zap-40012");
|
|
34
|
+
expect(findings[0].name).toBe("Cross Site Scripting (Reflected)");
|
|
35
|
+
expect(findings[0].severity).toBe("high");
|
|
36
|
+
expect(findings[0].confidence).toBe(90);
|
|
37
|
+
expect(findings[0].url).toBe("https://example.com/search?q=test");
|
|
38
|
+
expect(findings[0].method).toBe("GET");
|
|
39
|
+
expect(findings[0].parameter).toBe("q");
|
|
40
|
+
expect(findings[0].evidence).toBe("<script>alert(1)</script>");
|
|
41
|
+
expect(findings[0].attack).toBe("<script>alert(1)</script>");
|
|
42
|
+
expect(findings[0].cweIds).toContain("CWE-79");
|
|
43
|
+
expect(findings[0].solution).toContain("Phase:");
|
|
44
|
+
});
|
|
45
|
+
it("maps ZAP risk levels correctly", () => {
|
|
46
|
+
const alerts = [
|
|
47
|
+
{ ...createMockAlert(), risk: "High", pluginId: "1" },
|
|
48
|
+
{ ...createMockAlert(), risk: "Medium", pluginId: "2" },
|
|
49
|
+
{ ...createMockAlert(), risk: "Low", pluginId: "3" },
|
|
50
|
+
{ ...createMockAlert(), risk: "Informational", pluginId: "4" },
|
|
51
|
+
];
|
|
52
|
+
const findings = parseZapAlerts(alerts);
|
|
53
|
+
expect(findings[0].severity).toBe("high");
|
|
54
|
+
expect(findings[1].severity).toBe("medium");
|
|
55
|
+
expect(findings[2].severity).toBe("low");
|
|
56
|
+
expect(findings[3].severity).toBe("info");
|
|
57
|
+
});
|
|
58
|
+
it("maps ZAP confidence levels correctly", () => {
|
|
59
|
+
const alerts = [
|
|
60
|
+
{ ...createMockAlert(), confidence: "High", pluginId: "1" },
|
|
61
|
+
{ ...createMockAlert(), confidence: "Medium", pluginId: "2" },
|
|
62
|
+
{ ...createMockAlert(), confidence: "Low", pluginId: "3" },
|
|
63
|
+
{ ...createMockAlert(), confidence: "Confirmed", pluginId: "4" },
|
|
64
|
+
];
|
|
65
|
+
const findings = parseZapAlerts(alerts);
|
|
66
|
+
expect(findings[0].confidence).toBe(90);
|
|
67
|
+
expect(findings[1].confidence).toBe(70);
|
|
68
|
+
expect(findings[2].confidence).toBe(50);
|
|
69
|
+
expect(findings[3].confidence).toBe(100);
|
|
70
|
+
});
|
|
71
|
+
it("handles alerts without optional fields", () => {
|
|
72
|
+
const alert = {
|
|
73
|
+
sourceid: "1",
|
|
74
|
+
other: "",
|
|
75
|
+
method: "",
|
|
76
|
+
evidence: "",
|
|
77
|
+
pluginId: "10096",
|
|
78
|
+
cweid: "",
|
|
79
|
+
confidence: "Medium",
|
|
80
|
+
wascid: "",
|
|
81
|
+
description: "The response time was significantly different...",
|
|
82
|
+
messageId: "1",
|
|
83
|
+
inputVector: "",
|
|
84
|
+
url: "https://example.com/api",
|
|
85
|
+
tags: {},
|
|
86
|
+
reference: "",
|
|
87
|
+
solution: "",
|
|
88
|
+
alert: "Timestamp Disclosure",
|
|
89
|
+
param: "",
|
|
90
|
+
attack: "",
|
|
91
|
+
name: "Timestamp Disclosure",
|
|
92
|
+
risk: "Low",
|
|
93
|
+
id: "2",
|
|
94
|
+
alertRef: "10096-1",
|
|
95
|
+
};
|
|
96
|
+
const findings = parseZapAlerts([alert]);
|
|
97
|
+
expect(findings).toHaveLength(1);
|
|
98
|
+
expect(findings[0].cweIds).toBeUndefined();
|
|
99
|
+
expect(findings[0].references).toBeUndefined();
|
|
100
|
+
expect(findings[0].tags).toEqual([]);
|
|
101
|
+
});
|
|
102
|
+
it("parses multiple references", () => {
|
|
103
|
+
const alert = {
|
|
104
|
+
...createMockAlert(),
|
|
105
|
+
reference: "https://owasp.org/xss\nhttps://cwe.mitre.org/data/definitions/79.html",
|
|
106
|
+
};
|
|
107
|
+
const findings = parseZapAlerts([alert]);
|
|
108
|
+
expect(findings[0].references).toHaveLength(2);
|
|
109
|
+
expect(findings[0].references).toContain("https://owasp.org/xss");
|
|
110
|
+
expect(findings[0].references).toContain("https://cwe.mitre.org/data/definitions/79.html");
|
|
111
|
+
});
|
|
112
|
+
it("extracts tags from ZAP alert", () => {
|
|
113
|
+
const alert = {
|
|
114
|
+
...createMockAlert(),
|
|
115
|
+
tags: {
|
|
116
|
+
"OWASP_2021_A03": "Injection",
|
|
117
|
+
"CWE-79": "",
|
|
118
|
+
"WSTG-v42-INPV-01": "",
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
const findings = parseZapAlerts([alert]);
|
|
122
|
+
expect(findings[0].tags).toContain("OWASP_2021_A03");
|
|
123
|
+
expect(findings[0].tags).toContain("CWE-79");
|
|
124
|
+
expect(findings[0].tags).toContain("WSTG-v42-INPV-01");
|
|
125
|
+
});
|
|
126
|
+
it("handles empty alerts array", () => {
|
|
127
|
+
const findings = parseZapAlerts([]);
|
|
128
|
+
expect(findings).toHaveLength(0);
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
function createMockAlert() {
|
|
133
|
+
return {
|
|
134
|
+
sourceid: "1",
|
|
135
|
+
other: "",
|
|
136
|
+
method: "GET",
|
|
137
|
+
evidence: "",
|
|
138
|
+
pluginId: "99999",
|
|
139
|
+
cweid: "0",
|
|
140
|
+
confidence: "Medium",
|
|
141
|
+
wascid: "0",
|
|
142
|
+
description: "Test description",
|
|
143
|
+
messageId: "1",
|
|
144
|
+
inputVector: "",
|
|
145
|
+
url: "https://example.com",
|
|
146
|
+
tags: {},
|
|
147
|
+
reference: "",
|
|
148
|
+
solution: "",
|
|
149
|
+
alert: "Test Alert",
|
|
150
|
+
param: "",
|
|
151
|
+
attack: "",
|
|
152
|
+
name: "Test Alert",
|
|
153
|
+
risk: "Medium",
|
|
154
|
+
id: "1",
|
|
155
|
+
alertRef: "99999-1",
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
//# sourceMappingURL=zap.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zap.test.js","sourceRoot":"","sources":["../../../../src/__tests__/scanners/dast/zap.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fp-feedback.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/scanners/fp-feedback.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
|
|
2
|
+
import { mkdir, rm } from "fs/promises";
|
|
3
|
+
import { join } from "path";
|
|
4
|
+
import { tmpdir } from "os";
|
|
5
|
+
import { loadFeedbackDatabase, submitFeedback, getFeedbackForFinding, getFeedbackForRule, hasFeedback, getSuppressionSuggestions, generateFeedbackReport, FP_REASON_DESCRIPTIONS, } from "../../scanners/fp-feedback.js";
|
|
6
|
+
// Mock the fp-tracker module to avoid side effects
|
|
7
|
+
vi.mock("../../scanners/fp-tracker.js", () => ({
|
|
8
|
+
markFalsePositive: vi.fn().mockResolvedValue(undefined),
|
|
9
|
+
markTruePositive: vi.fn().mockResolvedValue(undefined),
|
|
10
|
+
}));
|
|
11
|
+
describe("fp-feedback", () => {
|
|
12
|
+
let testDir;
|
|
13
|
+
beforeEach(async () => {
|
|
14
|
+
testDir = join(tmpdir(), `fp-feedback-test-${Date.now()}`);
|
|
15
|
+
await mkdir(testDir, { recursive: true });
|
|
16
|
+
});
|
|
17
|
+
afterEach(async () => {
|
|
18
|
+
try {
|
|
19
|
+
await rm(testDir, { recursive: true, force: true });
|
|
20
|
+
}
|
|
21
|
+
catch {
|
|
22
|
+
// Ignore cleanup errors
|
|
23
|
+
}
|
|
24
|
+
vi.clearAllMocks();
|
|
25
|
+
});
|
|
26
|
+
const createFinding = (overrides = {}) => ({
|
|
27
|
+
scanner: "semgrep",
|
|
28
|
+
ruleId: "security.sql-injection",
|
|
29
|
+
file: "src/db.ts",
|
|
30
|
+
line: 10,
|
|
31
|
+
message: "SQL injection vulnerability",
|
|
32
|
+
severity: "high",
|
|
33
|
+
confidence: 100,
|
|
34
|
+
...overrides,
|
|
35
|
+
});
|
|
36
|
+
describe("FP_REASON_DESCRIPTIONS", () => {
|
|
37
|
+
it("has descriptions for all reasons", () => {
|
|
38
|
+
const reasons = [
|
|
39
|
+
"test-code",
|
|
40
|
+
"false-pattern-match",
|
|
41
|
+
"sanitized-elsewhere",
|
|
42
|
+
"intentional",
|
|
43
|
+
"vendor-code",
|
|
44
|
+
"generated-code",
|
|
45
|
+
"example-code",
|
|
46
|
+
"configuration",
|
|
47
|
+
"other",
|
|
48
|
+
];
|
|
49
|
+
for (const reason of reasons) {
|
|
50
|
+
expect(FP_REASON_DESCRIPTIONS[reason]).toBeDefined();
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe("loadFeedbackDatabase", () => {
|
|
55
|
+
it("returns empty database for new project", async () => {
|
|
56
|
+
const db = await loadFeedbackDatabase(testDir);
|
|
57
|
+
expect(db.version).toBe("1.0.0");
|
|
58
|
+
expect(db.entries).toHaveLength(0);
|
|
59
|
+
expect(db.stats.totalFeedback).toBe(0);
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
describe("submitFeedback", () => {
|
|
63
|
+
it("submits FP feedback correctly", async () => {
|
|
64
|
+
const finding = createFinding();
|
|
65
|
+
const entry = await submitFeedback(testDir, finding, "fp", {
|
|
66
|
+
reason: "test-code",
|
|
67
|
+
details: "This is test code",
|
|
68
|
+
});
|
|
69
|
+
expect(entry.id).toMatch(/^fb-/);
|
|
70
|
+
expect(entry.verdict).toBe("fp");
|
|
71
|
+
expect(entry.reason).toBe("test-code");
|
|
72
|
+
expect(entry.details).toBe("This is test code");
|
|
73
|
+
});
|
|
74
|
+
it("submits TP feedback correctly", async () => {
|
|
75
|
+
const finding = createFinding();
|
|
76
|
+
const entry = await submitFeedback(testDir, finding, "tp");
|
|
77
|
+
expect(entry.verdict).toBe("tp");
|
|
78
|
+
expect(entry.reason).toBeUndefined();
|
|
79
|
+
});
|
|
80
|
+
it("updates stats on submission", async () => {
|
|
81
|
+
const finding = createFinding();
|
|
82
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
83
|
+
await submitFeedback(testDir, finding, "tp");
|
|
84
|
+
const db = await loadFeedbackDatabase(testDir);
|
|
85
|
+
expect(db.stats.totalFeedback).toBe(2);
|
|
86
|
+
expect(db.stats.fpCount).toBe(1);
|
|
87
|
+
expect(db.stats.tpCount).toBe(1);
|
|
88
|
+
expect(db.stats.byReason["test-code"]).toBe(1);
|
|
89
|
+
});
|
|
90
|
+
it("tracks scanner stats", async () => {
|
|
91
|
+
const semgrepFinding = createFinding({ scanner: "semgrep" });
|
|
92
|
+
const eslintFinding = createFinding({ scanner: "eslint" });
|
|
93
|
+
await submitFeedback(testDir, semgrepFinding, "fp", { reason: "test-code" });
|
|
94
|
+
await submitFeedback(testDir, eslintFinding, "fp", { reason: "test-code" });
|
|
95
|
+
await submitFeedback(testDir, semgrepFinding, "tp");
|
|
96
|
+
const db = await loadFeedbackDatabase(testDir);
|
|
97
|
+
expect(db.stats.byScanner["semgrep"]).toEqual({ tp: 1, fp: 1 });
|
|
98
|
+
expect(db.stats.byScanner["eslint"]).toEqual({ tp: 0, fp: 1 });
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
describe("getFeedbackForFinding", () => {
|
|
102
|
+
it("returns matching feedback entries", async () => {
|
|
103
|
+
const finding1 = createFinding({ file: "src/a.ts", line: 10 });
|
|
104
|
+
const finding2 = createFinding({ file: "src/b.ts", line: 20 });
|
|
105
|
+
await submitFeedback(testDir, finding1, "fp", { reason: "test-code" });
|
|
106
|
+
await submitFeedback(testDir, finding2, "tp");
|
|
107
|
+
const feedback = await getFeedbackForFinding(testDir, "semgrep", "security.sql-injection", "src/a.ts", 10);
|
|
108
|
+
expect(feedback).toHaveLength(1);
|
|
109
|
+
expect(feedback[0].verdict).toBe("fp");
|
|
110
|
+
});
|
|
111
|
+
it("returns empty array for no matches", async () => {
|
|
112
|
+
const feedback = await getFeedbackForFinding(testDir, "semgrep", "nonexistent", "src/a.ts");
|
|
113
|
+
expect(feedback).toHaveLength(0);
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
describe("getFeedbackForRule", () => {
|
|
117
|
+
it("returns all feedback for a rule", async () => {
|
|
118
|
+
const finding1 = createFinding({ file: "src/a.ts" });
|
|
119
|
+
const finding2 = createFinding({ file: "src/b.ts" });
|
|
120
|
+
const finding3 = createFinding({ ruleId: "other-rule" });
|
|
121
|
+
await submitFeedback(testDir, finding1, "fp", { reason: "test-code" });
|
|
122
|
+
await submitFeedback(testDir, finding2, "tp");
|
|
123
|
+
await submitFeedback(testDir, finding3, "fp", { reason: "test-code" });
|
|
124
|
+
const feedback = await getFeedbackForRule(testDir, "semgrep", "security.sql-injection");
|
|
125
|
+
expect(feedback).toHaveLength(2);
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
describe("hasFeedback", () => {
|
|
129
|
+
it("returns true when feedback exists", async () => {
|
|
130
|
+
const finding = createFinding();
|
|
131
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
132
|
+
const result = await hasFeedback(testDir, "semgrep", "security.sql-injection", "src/db.ts", 10);
|
|
133
|
+
expect(result).toBe(true);
|
|
134
|
+
});
|
|
135
|
+
it("returns false when no feedback exists", async () => {
|
|
136
|
+
const result = await hasFeedback(testDir, "semgrep", "security.sql-injection", "src/db.ts");
|
|
137
|
+
expect(result).toBe(false);
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
describe("getSuppressionSuggestions", () => {
|
|
141
|
+
it("returns suggestions for high FP rate rules", async () => {
|
|
142
|
+
// Submit 10 FPs for one rule
|
|
143
|
+
for (let i = 0; i < 10; i++) {
|
|
144
|
+
const finding = createFinding({ file: `src/file${i}.ts`, line: i });
|
|
145
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
146
|
+
}
|
|
147
|
+
const suggestions = await getSuppressionSuggestions(testDir, {
|
|
148
|
+
minFPRate: 0.5,
|
|
149
|
+
minSampleSize: 5,
|
|
150
|
+
});
|
|
151
|
+
expect(suggestions.length).toBeGreaterThan(0);
|
|
152
|
+
expect(suggestions[0].fpRate).toBe(1.0);
|
|
153
|
+
expect(suggestions[0].suggestion).toBe("disable");
|
|
154
|
+
expect(suggestions[0].commonReasons).toContain("test-code");
|
|
155
|
+
});
|
|
156
|
+
it("returns empty for low FP rate rules", async () => {
|
|
157
|
+
// Submit mostly TPs
|
|
158
|
+
for (let i = 0; i < 8; i++) {
|
|
159
|
+
const finding = createFinding({ file: `src/file${i}.ts`, line: i });
|
|
160
|
+
await submitFeedback(testDir, finding, "tp");
|
|
161
|
+
}
|
|
162
|
+
// And 2 FPs
|
|
163
|
+
for (let i = 0; i < 2; i++) {
|
|
164
|
+
const finding = createFinding({ file: `src/fp${i}.ts`, line: i });
|
|
165
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
166
|
+
}
|
|
167
|
+
const suggestions = await getSuppressionSuggestions(testDir, {
|
|
168
|
+
minFPRate: 0.5,
|
|
169
|
+
minSampleSize: 5,
|
|
170
|
+
});
|
|
171
|
+
expect(suggestions).toHaveLength(0);
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
describe("generateFeedbackReport", () => {
|
|
175
|
+
it("generates comprehensive report", async () => {
|
|
176
|
+
// Submit varied feedback
|
|
177
|
+
const finding1 = createFinding({ scanner: "semgrep" });
|
|
178
|
+
const finding2 = createFinding({ scanner: "eslint" });
|
|
179
|
+
await submitFeedback(testDir, finding1, "fp", { reason: "test-code" });
|
|
180
|
+
await submitFeedback(testDir, finding2, "fp", { reason: "false-pattern-match" });
|
|
181
|
+
await submitFeedback(testDir, finding1, "tp");
|
|
182
|
+
const report = await generateFeedbackReport(testDir);
|
|
183
|
+
expect(report.overview.totalFeedback).toBe(3);
|
|
184
|
+
expect(report.overview.tpCount).toBe(1);
|
|
185
|
+
expect(report.overview.fpCount).toBe(2);
|
|
186
|
+
expect(report.byScanner.length).toBeGreaterThan(0);
|
|
187
|
+
expect(report.topFPReasons.length).toBeGreaterThan(0);
|
|
188
|
+
expect(report.recentFeedback.length).toBe(3);
|
|
189
|
+
});
|
|
190
|
+
it("calculates FP rate correctly", async () => {
|
|
191
|
+
const finding = createFinding();
|
|
192
|
+
// 1 TP, 3 FP = 75% FP rate
|
|
193
|
+
await submitFeedback(testDir, finding, "tp");
|
|
194
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
195
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
196
|
+
await submitFeedback(testDir, finding, "fp", { reason: "test-code" });
|
|
197
|
+
const report = await generateFeedbackReport(testDir);
|
|
198
|
+
expect(report.overview.overallFPRate).toBe(0.75);
|
|
199
|
+
});
|
|
200
|
+
});
|
|
201
|
+
});
|
|
202
|
+
//# sourceMappingURL=fp-feedback.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fp-feedback.test.js","sourceRoot":"","sources":["../../../src/__tests__/scanners/fp-feedback.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fp-filter.property.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/scanners/fp-filter.property.test.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG"}
|