pi-lens 2.2.9 → 3.0.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 +198 -0
- package/README.md +709 -519
- package/clients/__tests__/file-time.test.js +216 -0
- package/clients/__tests__/file-time.test.ts +276 -0
- package/clients/__tests__/format-service.test.js +245 -0
- package/clients/__tests__/format-service.test.ts +339 -0
- package/clients/__tests__/formatters.test.js +271 -0
- package/clients/__tests__/formatters.test.ts +401 -0
- package/clients/amain-types.js +164 -0
- package/clients/amain-types.ts +165 -0
- package/clients/architect-client.js +56 -12
- package/clients/architect-client.ts +81 -16
- package/clients/ast-grep-client.js +2 -2
- package/clients/ast-grep-client.ts +14 -39
- package/clients/ast-grep-parser.ts +1 -1
- package/clients/ast-grep-rule-manager.js +8 -0
- package/clients/ast-grep-rule-manager.ts +10 -1
- package/clients/ast-grep-types.js +9 -0
- package/clients/ast-grep-types.ts +106 -0
- package/clients/auto-loop.js +10 -0
- package/clients/auto-loop.ts +14 -1
- package/clients/biome-client.js +81 -19
- package/clients/biome-client.ts +103 -22
- package/clients/bus/bus.js +191 -0
- package/clients/bus/bus.ts +251 -0
- package/clients/bus/events.js +214 -0
- package/clients/bus/events.ts +279 -0
- package/clients/bus/index.js +8 -0
- package/clients/bus/index.ts +9 -0
- package/clients/bus/integration.js +158 -0
- package/clients/bus/integration.ts +214 -0
- package/clients/complexity-client.js +13 -7
- package/clients/complexity-client.ts +13 -7
- package/clients/config-validator.js +465 -0
- package/clients/config-validator.ts +558 -0
- package/clients/dependency-checker.js +4 -10
- package/clients/dependency-checker.ts +4 -10
- package/clients/dispatch/__tests__/autofix-integration.test.js +245 -0
- package/clients/dispatch/__tests__/autofix-integration.test.ts +300 -0
- package/clients/dispatch/__tests__/runner-registration.test.js +236 -0
- package/clients/dispatch/__tests__/runner-registration.test.ts +282 -0
- package/clients/dispatch/bus-dispatcher.js +177 -0
- package/clients/dispatch/bus-dispatcher.ts +251 -0
- package/clients/dispatch/dispatcher.edge.test.js +82 -0
- package/clients/dispatch/dispatcher.edge.test.ts +100 -0
- package/clients/dispatch/dispatcher.format.test.js +46 -0
- package/clients/dispatch/dispatcher.format.test.ts +58 -0
- package/clients/dispatch/dispatcher.inline.test.js +74 -0
- package/clients/dispatch/dispatcher.inline.test.ts +93 -0
- package/clients/dispatch/dispatcher.js +19 -53
- package/clients/dispatch/dispatcher.ts +20 -67
- package/clients/dispatch/plan.js +9 -4
- package/clients/dispatch/plan.ts +9 -4
- package/clients/dispatch/runners/architect.js +21 -7
- package/clients/dispatch/runners/architect.test.js +138 -0
- package/clients/dispatch/runners/architect.test.ts +162 -0
- package/clients/dispatch/runners/architect.ts +22 -7
- package/clients/dispatch/runners/ast-grep-napi.js +462 -0
- package/clients/dispatch/runners/ast-grep-napi.test.js +111 -0
- package/clients/dispatch/runners/ast-grep-napi.test.ts +133 -0
- package/clients/dispatch/runners/ast-grep-napi.ts +506 -0
- package/clients/dispatch/runners/ast-grep.js +62 -19
- package/clients/dispatch/runners/ast-grep.ts +70 -18
- package/clients/dispatch/runners/biome.js +29 -53
- package/clients/dispatch/runners/biome.ts +29 -63
- package/clients/dispatch/runners/config-validation.js +67 -0
- package/clients/dispatch/runners/config-validation.ts +82 -0
- package/clients/dispatch/runners/go-vet.js +4 -28
- package/clients/dispatch/runners/go-vet.ts +4 -32
- package/clients/dispatch/runners/index.js +30 -10
- package/clients/dispatch/runners/index.ts +30 -10
- package/clients/dispatch/runners/oxlint.js +141 -0
- package/clients/dispatch/runners/oxlint.test.js +230 -0
- package/clients/dispatch/runners/oxlint.test.ts +303 -0
- package/clients/dispatch/runners/oxlint.ts +175 -0
- package/clients/dispatch/runners/pyright.js +40 -70
- package/clients/dispatch/runners/pyright.test.js +16 -2
- package/clients/dispatch/runners/pyright.test.ts +14 -2
- package/clients/dispatch/runners/pyright.ts +48 -91
- package/clients/dispatch/runners/python-slop.js +97 -0
- package/clients/dispatch/runners/python-slop.test.js +203 -0
- package/clients/dispatch/runners/python-slop.test.ts +298 -0
- package/clients/dispatch/runners/python-slop.ts +124 -0
- package/clients/dispatch/runners/ruff.js +18 -71
- package/clients/dispatch/runners/ruff.ts +19 -79
- package/clients/dispatch/runners/rust-clippy.js +28 -32
- package/clients/dispatch/runners/rust-clippy.ts +29 -31
- package/clients/dispatch/runners/scan_codebase.test.js +89 -0
- package/clients/dispatch/runners/scan_codebase.test.ts +105 -0
- package/clients/dispatch/runners/shellcheck.js +147 -0
- package/clients/dispatch/runners/shellcheck.test.js +98 -0
- package/clients/dispatch/runners/shellcheck.test.ts +129 -0
- package/clients/dispatch/runners/shellcheck.ts +188 -0
- package/clients/dispatch/runners/similarity.js +230 -0
- package/clients/dispatch/runners/similarity.ts +339 -0
- package/clients/dispatch/runners/spellcheck.js +106 -0
- package/clients/dispatch/runners/spellcheck.test.js +158 -0
- package/clients/dispatch/runners/spellcheck.test.ts +214 -0
- package/clients/dispatch/runners/spellcheck.ts +136 -0
- package/clients/dispatch/runners/tree-sitter.js +107 -0
- package/clients/dispatch/runners/tree-sitter.ts +135 -0
- package/clients/dispatch/runners/ts-lsp.js +104 -33
- package/clients/dispatch/runners/ts-lsp.ts +120 -38
- package/clients/dispatch/runners/ts-slop.js +113 -0
- package/clients/dispatch/runners/ts-slop.test.js +180 -0
- package/clients/dispatch/runners/ts-slop.test.ts +230 -0
- package/clients/dispatch/runners/ts-slop.ts +142 -0
- package/clients/dispatch/runners/utils/diagnostic-parsers.js +134 -0
- package/clients/dispatch/runners/utils/diagnostic-parsers.ts +186 -0
- package/clients/dispatch/runners/utils/runner-helpers.js +115 -0
- package/clients/dispatch/runners/utils/runner-helpers.ts +167 -0
- package/clients/dispatch/runners/utils.js +2 -4
- package/clients/dispatch/runners/utils.ts +2 -4
- package/clients/dispatch/types.ts +1 -1
- package/clients/dispatch/utils/format-utils.js +49 -0
- package/clients/dispatch/utils/format-utils.ts +60 -0
- package/clients/dogfood.test.js +201 -0
- package/clients/dogfood.test.ts +269 -0
- package/clients/file-time.js +152 -0
- package/clients/file-time.ts +208 -0
- package/clients/file-utils.js +40 -0
- package/clients/file-utils.ts +44 -0
- package/clients/fix-scanners.js +10 -20
- package/clients/fix-scanners.ts +10 -22
- package/clients/format-service.js +172 -0
- package/clients/format-service.ts +254 -0
- package/clients/formatters.js +435 -0
- package/clients/formatters.ts +508 -0
- package/clients/go-client.js +5 -14
- package/clients/go-client.ts +5 -13
- package/clients/installer/index.js +356 -0
- package/clients/installer/index.ts +426 -0
- package/clients/jscpd-client.js +11 -9
- package/clients/jscpd-client.ts +12 -8
- package/clients/knip-client.js +3 -7
- package/clients/knip-client.ts +3 -6
- package/clients/lsp/__tests__/client.test.js +325 -0
- package/clients/lsp/__tests__/client.test.ts +434 -0
- package/clients/lsp/__tests__/config.test.js +166 -0
- package/clients/lsp/__tests__/config.test.ts +209 -0
- package/clients/lsp/__tests__/error-recovery.test.js +213 -0
- package/clients/lsp/__tests__/error-recovery.test.ts +279 -0
- package/clients/lsp/__tests__/integration.test.js +127 -0
- package/clients/lsp/__tests__/integration.test.ts +160 -0
- package/clients/lsp/__tests__/launch.test.js +260 -0
- package/clients/lsp/__tests__/launch.test.ts +329 -0
- package/clients/lsp/__tests__/server.test.js +259 -0
- package/clients/lsp/__tests__/server.test.ts +332 -0
- package/clients/lsp/__tests__/service.test.js +417 -0
- package/clients/lsp/__tests__/service.test.ts +499 -0
- package/clients/lsp/client.js +235 -0
- package/clients/lsp/client.ts +328 -0
- package/clients/lsp/config.js +115 -0
- package/clients/lsp/config.ts +149 -0
- package/clients/lsp/index.js +222 -0
- package/clients/lsp/index.ts +280 -0
- package/clients/lsp/installer/index.js +391 -0
- package/clients/lsp/interactive-install.js +210 -0
- package/clients/lsp/interactive-install.ts +251 -0
- package/clients/lsp/language.js +170 -0
- package/clients/lsp/language.ts +216 -0
- package/clients/lsp/launch.js +174 -0
- package/clients/lsp/launch.ts +240 -0
- package/clients/lsp/lsp/launch.js +116 -0
- package/clients/lsp/lsp/server.js +532 -0
- package/clients/lsp/lsp-index.js +10 -0
- package/clients/lsp/lsp-index.ts +11 -0
- package/clients/lsp/path-utils.js +48 -0
- package/clients/lsp/path-utils.ts +52 -0
- package/clients/lsp/server.js +615 -0
- package/clients/lsp/server.ts +800 -0
- package/clients/lsp/test-py-spawn/requirements.txt +1 -0
- package/clients/lsp/test-py-spawn/test.py +3 -0
- package/clients/lsp/test-py-svc/requirements.txt +1 -0
- package/clients/lsp/test-py-svc/test.py +3 -0
- package/clients/lsp/test-python-project/requirements.txt +1 -0
- package/clients/lsp/test-python-project/test.py +5 -0
- package/clients/metrics-history.js +2 -2
- package/clients/metrics-history.ts +2 -2
- package/clients/production-readiness.js +522 -0
- package/clients/production-readiness.ts +556 -0
- package/clients/project-index.js +255 -0
- package/clients/project-index.ts +383 -0
- package/clients/project-metadata.js +531 -0
- package/clients/project-metadata.ts +624 -0
- package/clients/ruff-client.js +56 -16
- package/clients/ruff-client.ts +72 -15
- package/clients/runner-tracker.js +152 -0
- package/clients/runner-tracker.ts +213 -0
- package/clients/rust-client.js +4 -11
- package/clients/rust-client.ts +5 -11
- package/clients/safe-spawn.js +96 -0
- package/clients/safe-spawn.ts +128 -0
- package/clients/scan-architectural-debt.js +3 -6
- package/clients/scan-architectural-debt.ts +3 -6
- package/clients/scan-utils.js +5 -20
- package/clients/scan-utils.ts +5 -29
- package/clients/secrets-scanner.js +3 -17
- package/clients/secrets-scanner.ts +4 -20
- package/clients/services/__tests__/effect-integration.test.js +86 -0
- package/clients/services/__tests__/effect-integration.test.ts +111 -0
- package/clients/services/effect-integration.js +194 -0
- package/clients/services/effect-integration.ts +268 -0
- package/clients/services/index.js +7 -0
- package/clients/services/index.ts +8 -0
- package/clients/services/runner-service.js +105 -0
- package/clients/services/runner-service.ts +179 -0
- package/clients/sg-runner.js +87 -13
- package/clients/sg-runner.ts +97 -13
- package/clients/state-matrix.js +160 -0
- package/clients/state-matrix.ts +202 -0
- package/clients/subprocess-client.js +10 -9
- package/clients/subprocess-client.ts +10 -8
- package/clients/test-runner-client.js +3 -7
- package/clients/test-runner-client.ts +3 -6
- package/clients/tool-availability.js +4 -10
- package/clients/tool-availability.ts +4 -9
- package/clients/tree-sitter-client.js +564 -0
- package/clients/tree-sitter-client.ts +797 -0
- package/clients/tree-sitter-query-loader.js +355 -0
- package/clients/tree-sitter-query-loader.ts +425 -0
- package/clients/type-coverage-client.js +3 -7
- package/clients/type-coverage-client.ts +3 -6
- package/clients/typescript-client.codefix.test.js +157 -0
- package/clients/typescript-client.codefix.test.ts +186 -0
- package/clients/typescript-client.js +43 -0
- package/clients/typescript-client.ts +98 -0
- package/commands/booboo.js +799 -219
- package/commands/booboo.ts +1004 -225
- package/commands/clients/ast-grep-client.js +250 -0
- package/commands/clients/ast-grep-parser.js +86 -0
- package/commands/clients/ast-grep-rule-manager.js +91 -0
- package/commands/clients/ast-grep-types.js +9 -0
- package/commands/clients/biome-client.js +380 -0
- package/commands/clients/complexity-client.js +667 -0
- package/commands/clients/file-kinds.js +177 -0
- package/commands/clients/file-utils.js +40 -0
- package/commands/clients/jscpd-client.js +169 -0
- package/commands/clients/knip-client.js +211 -0
- package/commands/clients/ruff-client.js +297 -0
- package/commands/clients/safe-spawn.js +88 -0
- package/commands/clients/scan-utils.js +83 -0
- package/commands/clients/sg-runner.js +190 -0
- package/commands/clients/types.js +11 -0
- package/commands/clients/typescript-client.js +505 -0
- package/commands/fix-from-booboo.js +398 -0
- package/commands/fix-from-booboo.ts +485 -0
- package/commands/fix-simplified.js +618 -0
- package/commands/fix-simplified.ts +768 -0
- package/commands/rate.js +10 -14
- package/commands/rate.ts +9 -16
- package/default-architect.yaml +59 -15
- package/index.ts +342 -429
- package/package.json +16 -3
- package/rules/ast-grep-rules/rules/empty-catch.yml +38 -13
- package/rules/ast-grep-rules/rules/no-array-constructor.yml +1 -0
- package/rules/ast-grep-rules/rules/no-debugger.yml +2 -0
- package/rules/python-slop-rules/.sgconfig.yml +4 -0
- package/rules/python-slop-rules/rules/slop-rules.yml +647 -0
- package/rules/tree-sitter-queries/python/bare-except.yml +54 -0
- package/rules/tree-sitter-queries/python/eval-exec.yml +50 -0
- package/rules/tree-sitter-queries/python/is-vs-equals.yml +60 -0
- package/rules/tree-sitter-queries/python/mutable-default-arg.yml +57 -0
- package/rules/tree-sitter-queries/python/unreachable-except.yml +60 -0
- package/rules/tree-sitter-queries/python/wildcard-import.yml +46 -0
- package/rules/tree-sitter-queries/tsx/dangerously-set-inner-html.yml +63 -0
- package/rules/tree-sitter-queries/typescript/await-in-loop.yml +56 -0
- package/rules/tree-sitter-queries/typescript/console-statement.yml +47 -0
- package/rules/tree-sitter-queries/typescript/debugger.yml +47 -0
- package/rules/tree-sitter-queries/typescript/deep-nesting.yml +117 -0
- package/rules/tree-sitter-queries/typescript/deep-promise-chain.yml +73 -0
- package/rules/tree-sitter-queries/typescript/empty-catch.yml +64 -0
- package/rules/tree-sitter-queries/typescript/eval.yml +48 -0
- package/rules/tree-sitter-queries/typescript/hardcoded-secrets.yml +78 -0
- package/rules/tree-sitter-queries/typescript/long-parameter-list.yml +62 -0
- package/rules/tree-sitter-queries/typescript/mixed-async-styles.yml +49 -0
- package/rules/tree-sitter-queries/typescript/nested-ternary.yml +45 -0
- package/rules/ts-slop-rules/.sgconfig.yml +4 -0
- package/rules/ts-slop-rules/rules/in-correct-optional-input-type.yml +10 -0
- package/rules/ts-slop-rules/rules/jwt-no-verify.yml +13 -0
- package/rules/ts-slop-rules/rules/no-architecture-violation.yml +10 -0
- package/rules/ts-slop-rules/rules/no-case-declarations.yml +10 -0
- package/rules/ts-slop-rules/rules/no-dangerously-set-inner-html.yml +10 -0
- package/rules/ts-slop-rules/rules/no-debugger.yml +10 -0
- package/rules/ts-slop-rules/rules/no-dupe-args.yml +10 -0
- package/rules/ts-slop-rules/rules/no-dupe-class-members.yml +10 -0
- package/rules/ts-slop-rules/rules/no-dupe-keys.yml +10 -0
- package/rules/ts-slop-rules/rules/no-eval.yml +13 -0
- package/rules/ts-slop-rules/rules/no-hardcoded-secrets.yml +12 -0
- package/rules/ts-slop-rules/rules/no-implied-eval.yml +12 -0
- package/rules/ts-slop-rules/rules/no-inner-html.yml +13 -0
- package/rules/ts-slop-rules/rules/no-javascript-url.yml +10 -0
- package/rules/ts-slop-rules/rules/no-mutable-default.yml +10 -0
- package/rules/ts-slop-rules/rules/no-nested-links.yml +12 -0
- package/rules/ts-slop-rules/rules/no-new-symbol.yml +10 -0
- package/rules/ts-slop-rules/rules/no-new-wrappers.yml +13 -0
- package/rules/ts-slop-rules/rules/no-open-redirect.yml +16 -0
- package/rules/ts-slop-rules/rules/slop-rules.yml +455 -0
- package/rules/ts-slop-rules/rules/weak-rsa-key.yml +12 -0
- package/skills/ast-grep/SKILL.md +182 -0
- package/clients/dispatch/runners/secrets.js +0 -109
- package/commands/fix.js +0 -244
- package/commands/fix.ts +0 -373
- package/rules/ast-grep-rules/rules/no-lonely-if.yml +0 -13
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import * as path from "node:path";
|
|
3
|
+
import { describe, expect, it } from "vitest";
|
|
4
|
+
function createMockContext(filePath, kind = "jsts") {
|
|
5
|
+
return {
|
|
6
|
+
filePath,
|
|
7
|
+
cwd: process.cwd(),
|
|
8
|
+
kind,
|
|
9
|
+
autofix: false,
|
|
10
|
+
deltaMode: false,
|
|
11
|
+
baselines: { get: () => [], add: () => { }, save: () => { } },
|
|
12
|
+
pi: {},
|
|
13
|
+
hasTool: async () => false,
|
|
14
|
+
log: () => { },
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
describe("ast-grep-napi vs CLI comparison", () => {
|
|
18
|
+
it("should load the napi module", async () => {
|
|
19
|
+
const napiModule = await import("./ast-grep-napi.js");
|
|
20
|
+
expect(napiModule.default.id).toBe("ast-grep-napi");
|
|
21
|
+
expect(napiModule.default.appliesTo).toEqual(["jsts"]);
|
|
22
|
+
});
|
|
23
|
+
it("should scan TypeScript file faster than CLI", async () => {
|
|
24
|
+
const tmpFile = path.join(process.env.TEMP || "/tmp", `napi_test_${Date.now()}.ts`);
|
|
25
|
+
fs.writeFileSync(tmpFile, `// Test file with various patterns
|
|
26
|
+
function test(items: string[]) {
|
|
27
|
+
for (let i = 0; i < items.length; i++) {
|
|
28
|
+
console.log(items[i]);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
try {
|
|
32
|
+
riskyOperation();
|
|
33
|
+
} catch (e) {
|
|
34
|
+
// empty catch
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return await fetchData();
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async function fetchData() {
|
|
41
|
+
return await Promise.resolve(42);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function riskyOperation() {
|
|
45
|
+
debugger;
|
|
46
|
+
}
|
|
47
|
+
`);
|
|
48
|
+
try {
|
|
49
|
+
// Test NAPI version
|
|
50
|
+
const napiModule = await import("./ast-grep-napi.js");
|
|
51
|
+
const napiRunner = napiModule.default;
|
|
52
|
+
console.time("napi");
|
|
53
|
+
const napiResult = await napiRunner.run(createMockContext(tmpFile));
|
|
54
|
+
console.timeEnd("napi");
|
|
55
|
+
// Test CLI version
|
|
56
|
+
const cliModule = await import("./ast-grep.js");
|
|
57
|
+
const cliRunner = cliModule.default;
|
|
58
|
+
console.time("cli");
|
|
59
|
+
const cliResult = await cliRunner.run(createMockContext(tmpFile));
|
|
60
|
+
console.timeEnd("cli");
|
|
61
|
+
// Both should complete successfully
|
|
62
|
+
expect(napiResult.status).not.toBe("skipped");
|
|
63
|
+
expect(cliResult.status).not.toBe("skipped");
|
|
64
|
+
// Log comparison
|
|
65
|
+
console.log("NAPI found:", napiResult.diagnostics.length, "issues");
|
|
66
|
+
console.log("CLI found:", cliResult.diagnostics.length, "issues");
|
|
67
|
+
// Show what NAPI found exactly
|
|
68
|
+
console.log("\n=== NAPI FINDINGS ===");
|
|
69
|
+
napiResult.diagnostics.forEach((d, i) => {
|
|
70
|
+
console.log(`${i + 1}. Line ${d.line}: ${d.rule}`);
|
|
71
|
+
});
|
|
72
|
+
// Show what CLI found (if any)
|
|
73
|
+
if (cliResult.diagnostics.length > 0) {
|
|
74
|
+
console.log("\n=== CLI FINDINGS ===");
|
|
75
|
+
cliResult.diagnostics.forEach((d, i) => {
|
|
76
|
+
console.log(`${i + 1}. Line ${d.line}: ${d.rule}`);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
finally {
|
|
81
|
+
try {
|
|
82
|
+
if (fs.existsSync(tmpFile)) {
|
|
83
|
+
fs.unlinkSync(tmpFile);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
catch {
|
|
87
|
+
// Ignore cleanup errors
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
it("should skip non-TS/JS files", async () => {
|
|
92
|
+
const tmpFile = path.join(process.env.TEMP || "/tmp", `napi_test_py_${Date.now()}.py`);
|
|
93
|
+
fs.writeFileSync(tmpFile, "# Python file\nprint('hello')");
|
|
94
|
+
try {
|
|
95
|
+
const napiModule = await import("./ast-grep-napi.js");
|
|
96
|
+
const napiRunner = napiModule.default;
|
|
97
|
+
const result = await napiRunner.run(createMockContext(tmpFile, "python"));
|
|
98
|
+
expect(result.status).toBe("skipped");
|
|
99
|
+
}
|
|
100
|
+
finally {
|
|
101
|
+
try {
|
|
102
|
+
if (fs.existsSync(tmpFile)) {
|
|
103
|
+
fs.unlinkSync(tmpFile);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
catch {
|
|
107
|
+
// Ignore cleanup errors
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
});
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import { createRequire } from "node:module";
|
|
3
|
+
import * as path from "node:path";
|
|
4
|
+
import { describe, expect, it } from "vitest";
|
|
5
|
+
import type { DispatchContext } from "../types.js";
|
|
6
|
+
|
|
7
|
+
function createMockContext(filePath: string, kind: any = "jsts"): DispatchContext {
|
|
8
|
+
return {
|
|
9
|
+
filePath,
|
|
10
|
+
cwd: process.cwd(),
|
|
11
|
+
kind,
|
|
12
|
+
autofix: false,
|
|
13
|
+
deltaMode: false,
|
|
14
|
+
baselines: { get: () => [], add: () => {}, save: () => {} } as any,
|
|
15
|
+
pi: {} as any,
|
|
16
|
+
hasTool: async () => false,
|
|
17
|
+
log: () => {},
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
describe("ast-grep-napi vs CLI comparison", () => {
|
|
22
|
+
it("should load the napi module", async () => {
|
|
23
|
+
const napiModule = await import("./ast-grep-napi.js");
|
|
24
|
+
expect(napiModule.default.id).toBe("ast-grep-napi");
|
|
25
|
+
expect(napiModule.default.appliesTo).toEqual(["jsts"]);
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
it("should scan TypeScript file faster than CLI", async () => {
|
|
29
|
+
const tmpFile = path.join(
|
|
30
|
+
process.env.TEMP || "/tmp",
|
|
31
|
+
`napi_test_${Date.now()}.ts`,
|
|
32
|
+
);
|
|
33
|
+
fs.writeFileSync(
|
|
34
|
+
tmpFile,
|
|
35
|
+
`// Test file with various patterns
|
|
36
|
+
function test(items: string[]) {
|
|
37
|
+
for (let i = 0; i < items.length; i++) {
|
|
38
|
+
console.log(items[i]);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
try {
|
|
42
|
+
riskyOperation();
|
|
43
|
+
} catch (e) {
|
|
44
|
+
// empty catch
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return await fetchData();
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async function fetchData() {
|
|
51
|
+
return await Promise.resolve(42);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function riskyOperation() {
|
|
55
|
+
debugger;
|
|
56
|
+
}
|
|
57
|
+
`,
|
|
58
|
+
);
|
|
59
|
+
|
|
60
|
+
try {
|
|
61
|
+
// Test NAPI version
|
|
62
|
+
const napiModule = await import("./ast-grep-napi.js");
|
|
63
|
+
const napiRunner = napiModule.default;
|
|
64
|
+
|
|
65
|
+
console.time("napi");
|
|
66
|
+
const napiResult = await napiRunner.run(createMockContext(tmpFile));
|
|
67
|
+
console.timeEnd("napi");
|
|
68
|
+
|
|
69
|
+
// Test CLI version
|
|
70
|
+
const cliModule = await import("./ast-grep.js");
|
|
71
|
+
const cliRunner = cliModule.default;
|
|
72
|
+
|
|
73
|
+
console.time("cli");
|
|
74
|
+
const cliResult = await cliRunner.run(createMockContext(tmpFile));
|
|
75
|
+
console.timeEnd("cli");
|
|
76
|
+
|
|
77
|
+
// Both should complete successfully
|
|
78
|
+
expect(napiResult.status).not.toBe("skipped");
|
|
79
|
+
expect(cliResult.status).not.toBe("skipped");
|
|
80
|
+
|
|
81
|
+
// Log comparison
|
|
82
|
+
console.log("NAPI found:", napiResult.diagnostics.length, "issues");
|
|
83
|
+
console.log("CLI found:", cliResult.diagnostics.length, "issues");
|
|
84
|
+
|
|
85
|
+
// Show what NAPI found exactly
|
|
86
|
+
console.log("\n=== NAPI FINDINGS ===");
|
|
87
|
+
napiResult.diagnostics.forEach((d, i) => {
|
|
88
|
+
console.log(`${i + 1}. Line ${d.line}: ${d.rule}`);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
// Show what CLI found (if any)
|
|
92
|
+
if (cliResult.diagnostics.length > 0) {
|
|
93
|
+
console.log("\n=== CLI FINDINGS ===");
|
|
94
|
+
cliResult.diagnostics.forEach((d, i) => {
|
|
95
|
+
console.log(`${i + 1}. Line ${d.line}: ${d.rule}`);
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
} finally {
|
|
100
|
+
try {
|
|
101
|
+
if (fs.existsSync(tmpFile)) {
|
|
102
|
+
fs.unlinkSync(tmpFile);
|
|
103
|
+
}
|
|
104
|
+
} catch {
|
|
105
|
+
// Ignore cleanup errors
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it("should skip non-TS/JS files", async () => {
|
|
111
|
+
const tmpFile = path.join(
|
|
112
|
+
process.env.TEMP || "/tmp",
|
|
113
|
+
`napi_test_py_${Date.now()}.py`,
|
|
114
|
+
);
|
|
115
|
+
fs.writeFileSync(tmpFile, "# Python file\nprint('hello')");
|
|
116
|
+
|
|
117
|
+
try {
|
|
118
|
+
const napiModule = await import("./ast-grep-napi.js");
|
|
119
|
+
const napiRunner = napiModule.default;
|
|
120
|
+
|
|
121
|
+
const result = await napiRunner.run(createMockContext(tmpFile, "python"));
|
|
122
|
+
expect(result.status).toBe("skipped");
|
|
123
|
+
} finally {
|
|
124
|
+
try {
|
|
125
|
+
if (fs.existsSync(tmpFile)) {
|
|
126
|
+
fs.unlinkSync(tmpFile);
|
|
127
|
+
}
|
|
128
|
+
} catch {
|
|
129
|
+
// Ignore cleanup errors
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
});
|