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.
Files changed (166) hide show
  1. package/CHANGELOG.md +122 -7
  2. package/README.md +58 -1
  3. package/dist/__tests__/autofix/branch-manager.test.d.ts +2 -0
  4. package/dist/__tests__/autofix/branch-manager.test.d.ts.map +1 -0
  5. package/dist/__tests__/autofix/branch-manager.test.js +60 -0
  6. package/dist/__tests__/autofix/branch-manager.test.js.map +1 -0
  7. package/dist/__tests__/autofix/commit-generator.test.d.ts +2 -0
  8. package/dist/__tests__/autofix/commit-generator.test.d.ts.map +1 -0
  9. package/dist/__tests__/autofix/commit-generator.test.js +147 -0
  10. package/dist/__tests__/autofix/commit-generator.test.js.map +1 -0
  11. package/dist/__tests__/autofix/constitution.test.d.ts +9 -0
  12. package/dist/__tests__/autofix/constitution.test.d.ts.map +1 -0
  13. package/dist/__tests__/autofix/constitution.test.js +421 -0
  14. package/dist/__tests__/autofix/constitution.test.js.map +1 -0
  15. package/dist/__tests__/autofix/pr-generator.test.d.ts +2 -0
  16. package/dist/__tests__/autofix/pr-generator.test.d.ts.map +1 -0
  17. package/dist/__tests__/autofix/pr-generator.test.js +152 -0
  18. package/dist/__tests__/autofix/pr-generator.test.js.map +1 -0
  19. package/dist/__tests__/property-test-helpers.d.ts +87 -0
  20. package/dist/__tests__/property-test-helpers.d.ts.map +1 -0
  21. package/dist/__tests__/property-test-helpers.js +136 -0
  22. package/dist/__tests__/property-test-helpers.js.map +1 -0
  23. package/dist/__tests__/scanners/dast/index.test.d.ts +2 -0
  24. package/dist/__tests__/scanners/dast/index.test.d.ts.map +1 -0
  25. package/dist/__tests__/scanners/dast/index.test.js +183 -0
  26. package/dist/__tests__/scanners/dast/index.test.js.map +1 -0
  27. package/dist/__tests__/scanners/dast/nuclei.test.d.ts +2 -0
  28. package/dist/__tests__/scanners/dast/nuclei.test.d.ts.map +1 -0
  29. package/dist/__tests__/scanners/dast/nuclei.test.js +166 -0
  30. package/dist/__tests__/scanners/dast/nuclei.test.js.map +1 -0
  31. package/dist/__tests__/scanners/dast/zap.test.d.ts +2 -0
  32. package/dist/__tests__/scanners/dast/zap.test.d.ts.map +1 -0
  33. package/dist/__tests__/scanners/dast/zap.test.js +158 -0
  34. package/dist/__tests__/scanners/dast/zap.test.js.map +1 -0
  35. package/dist/__tests__/scanners/fp-feedback.test.d.ts +2 -0
  36. package/dist/__tests__/scanners/fp-feedback.test.d.ts.map +1 -0
  37. package/dist/__tests__/scanners/fp-feedback.test.js +202 -0
  38. package/dist/__tests__/scanners/fp-feedback.test.js.map +1 -0
  39. package/dist/__tests__/scanners/fp-filter.property.test.d.ts +9 -0
  40. package/dist/__tests__/scanners/fp-filter.property.test.d.ts.map +1 -0
  41. package/dist/__tests__/scanners/fp-filter.property.test.js +253 -0
  42. package/dist/__tests__/scanners/fp-filter.property.test.js.map +1 -0
  43. package/dist/__tests__/scanners/fp-filter.test.d.ts +2 -0
  44. package/dist/__tests__/scanners/fp-filter.test.d.ts.map +1 -0
  45. package/dist/__tests__/scanners/fp-filter.test.js +234 -0
  46. package/dist/__tests__/scanners/fp-filter.test.js.map +1 -0
  47. package/dist/__tests__/scanners/fp-tracker.test.d.ts +2 -0
  48. package/dist/__tests__/scanners/fp-tracker.test.d.ts.map +1 -0
  49. package/dist/__tests__/scanners/fp-tracker.test.js +262 -0
  50. package/dist/__tests__/scanners/fp-tracker.test.js.map +1 -0
  51. package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.d.ts +10 -0
  52. package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.d.ts.map +1 -0
  53. package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.js +238 -0
  54. package/dist/__tests__/scanners/logic/endpoint-analyzer.property.test.js.map +1 -0
  55. package/dist/__tests__/scanners/logic/endpoint-analyzer.test.d.ts +2 -0
  56. package/dist/__tests__/scanners/logic/endpoint-analyzer.test.d.ts.map +1 -0
  57. package/dist/__tests__/scanners/logic/endpoint-analyzer.test.js +55 -0
  58. package/dist/__tests__/scanners/logic/endpoint-analyzer.test.js.map +1 -0
  59. package/dist/__tests__/scanners/logic/index.test.d.ts +2 -0
  60. package/dist/__tests__/scanners/logic/index.test.d.ts.map +1 -0
  61. package/dist/__tests__/scanners/logic/index.test.js +165 -0
  62. package/dist/__tests__/scanners/logic/index.test.js.map +1 -0
  63. package/dist/__tests__/scanners/logic/types.test.d.ts +2 -0
  64. package/dist/__tests__/scanners/logic/types.test.d.ts.map +1 -0
  65. package/dist/__tests__/scanners/logic/types.test.js +85 -0
  66. package/dist/__tests__/scanners/logic/types.test.js.map +1 -0
  67. package/dist/action/pr-comment.test.js +4 -0
  68. package/dist/action/pr-comment.test.js.map +1 -1
  69. package/dist/action/sarif-upload.test.js +4 -0
  70. package/dist/action/sarif-upload.test.js.map +1 -1
  71. package/dist/autofix/branch-manager.d.ts +115 -0
  72. package/dist/autofix/branch-manager.d.ts.map +1 -0
  73. package/dist/autofix/branch-manager.js +308 -0
  74. package/dist/autofix/branch-manager.js.map +1 -0
  75. package/dist/autofix/commit-generator.d.ts +55 -0
  76. package/dist/autofix/commit-generator.d.ts.map +1 -0
  77. package/dist/autofix/commit-generator.js +277 -0
  78. package/dist/autofix/commit-generator.js.map +1 -0
  79. package/dist/autofix/constitution.d.ts +77 -0
  80. package/dist/autofix/constitution.d.ts.map +1 -0
  81. package/dist/autofix/constitution.js +261 -0
  82. package/dist/autofix/constitution.js.map +1 -0
  83. package/dist/autofix/constitution.schema.d.ts +441 -0
  84. package/dist/autofix/constitution.schema.d.ts.map +1 -0
  85. package/dist/autofix/constitution.schema.js +144 -0
  86. package/dist/autofix/constitution.schema.js.map +1 -0
  87. package/dist/autofix/index.d.ts +13 -0
  88. package/dist/autofix/index.d.ts.map +1 -0
  89. package/dist/autofix/index.js +15 -0
  90. package/dist/autofix/index.js.map +1 -0
  91. package/dist/autofix/pr-generator.d.ts +57 -0
  92. package/dist/autofix/pr-generator.d.ts.map +1 -0
  93. package/dist/autofix/pr-generator.js +597 -0
  94. package/dist/autofix/pr-generator.js.map +1 -0
  95. package/dist/autofix/types.d.ts +151 -0
  96. package/dist/autofix/types.d.ts.map +1 -0
  97. package/dist/autofix/types.js +22 -0
  98. package/dist/autofix/types.js.map +1 -0
  99. package/dist/eval/fixtures.d.ts +20 -0
  100. package/dist/eval/fixtures.d.ts.map +1 -1
  101. package/dist/eval/fixtures.js +430 -0
  102. package/dist/eval/fixtures.js.map +1 -1
  103. package/dist/index.d.ts.map +1 -1
  104. package/dist/index.js +84 -1
  105. package/dist/index.js.map +1 -1
  106. package/dist/scanners/cache.d.ts.map +1 -1
  107. package/dist/scanners/cache.js +4 -0
  108. package/dist/scanners/cache.js.map +1 -1
  109. package/dist/scanners/dast/index.d.ts +39 -0
  110. package/dist/scanners/dast/index.d.ts.map +1 -0
  111. package/dist/scanners/dast/index.js +259 -0
  112. package/dist/scanners/dast/index.js.map +1 -0
  113. package/dist/scanners/dast/nuclei.d.ts +26 -0
  114. package/dist/scanners/dast/nuclei.d.ts.map +1 -0
  115. package/dist/scanners/dast/nuclei.js +354 -0
  116. package/dist/scanners/dast/nuclei.js.map +1 -0
  117. package/dist/scanners/dast/types.d.ts +306 -0
  118. package/dist/scanners/dast/types.d.ts.map +1 -0
  119. package/dist/scanners/dast/types.js +52 -0
  120. package/dist/scanners/dast/types.js.map +1 -0
  121. package/dist/scanners/dast/zap.d.ts +26 -0
  122. package/dist/scanners/dast/zap.d.ts.map +1 -0
  123. package/dist/scanners/dast/zap.js +453 -0
  124. package/dist/scanners/dast/zap.js.map +1 -0
  125. package/dist/scanners/fp-feedback.d.ts +140 -0
  126. package/dist/scanners/fp-feedback.d.ts.map +1 -0
  127. package/dist/scanners/fp-feedback.js +292 -0
  128. package/dist/scanners/fp-feedback.js.map +1 -0
  129. package/dist/scanners/fp-filter.d.ts +94 -0
  130. package/dist/scanners/fp-filter.d.ts.map +1 -0
  131. package/dist/scanners/fp-filter.js +397 -0
  132. package/dist/scanners/fp-filter.js.map +1 -0
  133. package/dist/scanners/fp-tracker.d.ts +125 -0
  134. package/dist/scanners/fp-tracker.d.ts.map +1 -0
  135. package/dist/scanners/fp-tracker.js +330 -0
  136. package/dist/scanners/fp-tracker.js.map +1 -0
  137. package/dist/scanners/index.d.ts.map +1 -1
  138. package/dist/scanners/index.js +56 -0
  139. package/dist/scanners/index.js.map +1 -1
  140. package/dist/scanners/index.test.js +6 -6
  141. package/dist/scanners/index.test.js.map +1 -1
  142. package/dist/scanners/logic/auth-flow-analyzer.d.ts +18 -0
  143. package/dist/scanners/logic/auth-flow-analyzer.d.ts.map +1 -0
  144. package/dist/scanners/logic/auth-flow-analyzer.js +384 -0
  145. package/dist/scanners/logic/auth-flow-analyzer.js.map +1 -0
  146. package/dist/scanners/logic/endpoint-analyzer.d.ts +29 -0
  147. package/dist/scanners/logic/endpoint-analyzer.d.ts.map +1 -0
  148. package/dist/scanners/logic/endpoint-analyzer.js +528 -0
  149. package/dist/scanners/logic/endpoint-analyzer.js.map +1 -0
  150. package/dist/scanners/logic/index.d.ts +41 -0
  151. package/dist/scanners/logic/index.d.ts.map +1 -0
  152. package/dist/scanners/logic/index.js +268 -0
  153. package/dist/scanners/logic/index.js.map +1 -0
  154. package/dist/scanners/logic/types.d.ts +254 -0
  155. package/dist/scanners/logic/types.d.ts.map +1 -0
  156. package/dist/scanners/logic/types.js +142 -0
  157. package/dist/scanners/logic/types.js.map +1 -0
  158. package/dist/scanners/types.d.ts +1 -1
  159. package/dist/scanners/types.d.ts.map +1 -1
  160. package/dist/scanners/types.js +4 -0
  161. package/dist/scanners/types.js.map +1 -1
  162. package/dist/telemetry/usage.d.ts +1 -1
  163. package/dist/telemetry/usage.d.ts.map +1 -1
  164. package/dist/telemetry/usage.js +14 -6
  165. package/dist/telemetry/usage.js.map +1 -1
  166. 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":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAG/D,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,MAAM,KAAK,GAAa;gBACtB,QAAQ,EAAE,GAAG;gBACb,KAAK,EAAE,EAAE;gBACT,MAAM,EAAE,KAAK;gBACb,QAAQ,EAAE,2BAA2B;gBACrC,QAAQ,EAAE,OAAO;gBACjB,KAAK,EAAE,IAAI;gBACX,UAAU,EAAE,MAAM;gBAClB,MAAM,EAAE,GAAG;gBACX,WAAW,EAAE,sDAAsD;gBACnE,SAAS,EAAE,GAAG;gBACd,WAAW,EAAE,KAAK;gBAClB,GAAG,EAAE,mCAAmC;gBACxC,IAAI,EAAE,EAAE,gBAAgB,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;gBAC5C,SAAS,EAAE,8CAA8C;gBACzD,QAAQ,EAAE,mCAAmC;gBAC7C,KAAK,EAAE,kCAAkC;gBACzC,KAAK,EAAE,GAAG;gBACV,MAAM,EAAE,2BAA2B;gBACnC,IAAI,EAAE,kCAAkC;gBACxC,IAAI,EAAE,MAAM;gBACZ,EAAE,EAAE,GAAG;gBACP,QAAQ,EAAE,SAAS;aACpB,CAAC;YAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YAEzC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC7C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;YAClE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC1C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;YAClE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACvC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;YAC/D,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;YAC7D,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAC/C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,MAAM,GAAe;gBACzB,EAAE,GAAG,eAAe,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE;gBACrD,EAAE,GAAG,eAAe,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE;gBACvD,EAAE,GAAG,eAAe,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,EAAE;gBACpD,EAAE,GAAG,eAAe,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,QAAQ,EAAE,GAAG,EAAE;aAC/D,CAAC;YAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;YAExC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC1C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC5C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC9C,MAAM,MAAM,GAAe;gBACzB,EAAE,GAAG,eAAe,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE;gBAC3D,EAAE,GAAG,eAAe,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE;gBAC7D,EAAE,GAAG,eAAe,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,EAAE;gBAC1D,EAAE,GAAG,eAAe,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,EAAE;aACjE,CAAC;YAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;YAExC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;YAChD,MAAM,KAAK,GAAa;gBACtB,QAAQ,EAAE,GAAG;gBACb,KAAK,EAAE,EAAE;gBACT,MAAM,EAAE,EAAE;gBACV,QAAQ,EAAE,EAAE;gBACZ,QAAQ,EAAE,OAAO;gBACjB,KAAK,EAAE,EAAE;gBACT,UAAU,EAAE,QAAQ;gBACpB,MAAM,EAAE,EAAE;gBACV,WAAW,EAAE,kDAAkD;gBAC/D,SAAS,EAAE,GAAG;gBACd,WAAW,EAAE,EAAE;gBACf,GAAG,EAAE,yBAAyB;gBAC9B,IAAI,EAAE,EAAE;gBACR,SAAS,EAAE,EAAE;gBACb,QAAQ,EAAE,EAAE;gBACZ,KAAK,EAAE,sBAAsB;gBAC7B,KAAK,EAAE,EAAE;gBACT,MAAM,EAAE,EAAE;gBACV,IAAI,EAAE,sBAAsB;gBAC5B,IAAI,EAAE,KAAK;gBACX,EAAE,EAAE,GAAG;gBACP,QAAQ,EAAE,SAAS;aACpB,CAAC;YAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YAEzC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,CAAC;YAC3C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,CAAC;YAC/C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,MAAM,KAAK,GAAa;gBACtB,GAAG,eAAe,EAAE;gBACpB,SAAS,EAAE,uEAAuE;aACnF,CAAC;YAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YAEzC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC/C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;YAClE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,gDAAgD,CAAC,CAAC;QAC7F,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;YACtC,MAAM,KAAK,GAAa;gBACtB,GAAG,eAAe,EAAE;gBACpB,IAAI,EAAE;oBACJ,gBAAgB,EAAE,WAAW;oBAC7B,QAAQ,EAAE,EAAE;oBACZ,kBAAkB,EAAE,EAAE;iBACvB;aACF,CAAC;YAEF,MAAM,QAAQ,GAAG,cAAc,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YAEzC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;YACrD,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAC7C,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,MAAM,QAAQ,GAAG,cAAc,CAAC,EAAE,CAAC,CAAC;YACpC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,SAAS,eAAe;IACtB,OAAO;QACL,QAAQ,EAAE,GAAG;QACb,KAAK,EAAE,EAAE;QACT,MAAM,EAAE,KAAK;QACb,QAAQ,EAAE,EAAE;QACZ,QAAQ,EAAE,OAAO;QACjB,KAAK,EAAE,GAAG;QACV,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,kBAAkB;QAC/B,SAAS,EAAE,GAAG;QACd,WAAW,EAAE,EAAE;QACf,GAAG,EAAE,qBAAqB;QAC1B,IAAI,EAAE,EAAE;QACR,SAAS,EAAE,EAAE;QACb,QAAQ,EAAE,EAAE;QACZ,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,EAAE;QACT,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE,QAAQ;QACd,EAAE,EAAE,GAAG;QACP,QAAQ,EAAE,SAAS;KACpB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=fp-feedback.test.d.ts.map
@@ -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,9 @@
1
+ /**
2
+ * Property-Based Tests for FP Filter
3
+ *
4
+ * Tests invariants of analyzeFilePath using fast-check property-based testing.
5
+ *
6
+ * @module __tests__/scanners/fp-filter.property
7
+ */
8
+ export {};
9
+ //# sourceMappingURL=fp-filter.property.test.d.ts.map
@@ -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"}