@diff-review-system/drs 4.0.0-rc.4 → 4.0.1
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/.pi/agents/describe/pr-describer.md +14 -0
- package/.pi/agents/review/unified-reviewer.md +31 -1
- package/.pi/agents/task/agents-md-updater.md +3 -1
- package/.pi/agents/task/review-issue-fixer.md +18 -1
- package/.pi/agents/visual/pr-explainer.md +205 -0
- package/.pi/workflows/github-pr-describe.yaml +10 -7
- package/.pi/workflows/github-pr-fix-review-issues-stacked.yaml +148 -0
- package/.pi/workflows/github-pr-post-comment.yaml +10 -10
- package/.pi/workflows/github-pr-review-post.yaml +19 -8
- package/.pi/workflows/github-pr-review.yaml +348 -7
- package/.pi/workflows/github-pr-show-changes.yaml +8 -8
- package/.pi/workflows/github-pr-update-agents-md-stacked.yaml +103 -0
- package/.pi/workflows/github-pr-visual-explain.yaml +35 -0
- package/.pi/workflows/gitlab-mr-describe.yaml +8 -5
- package/.pi/workflows/gitlab-mr-fix-review-issues-stacked.yaml +144 -0
- package/.pi/workflows/gitlab-mr-post-comment.yaml +8 -8
- package/.pi/workflows/gitlab-mr-review.yaml +348 -5
- package/.pi/workflows/gitlab-mr-show-changes.yaml +6 -6
- package/.pi/workflows/gitlab-mr-update-agents-md-stacked.yaml +100 -0
- package/.pi/workflows/gitlab-mr-visual-explain.yaml +33 -0
- package/.pi/workflows/local-fix-review-issues.yaml +82 -13
- package/.pi/workflows/local-review.yaml +9 -2
- package/.pi/workflows/local-update-agents-md.yaml +1 -1
- package/.pi/workflows/local-visual-explain.yaml +31 -0
- package/.pi/workflows/release-changelog-finalize.yaml +47 -0
- package/.pi/workflows/tag-changelog-update.yaml +4 -4
- package/README.md +91 -27
- package/dist/ci/runner.d.ts.map +1 -1
- package/dist/ci/runner.js +3 -1
- package/dist/ci/runner.js.map +1 -1
- package/dist/cli/index.js +48 -6
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/run-agent.d.ts +2 -0
- package/dist/cli/run-agent.d.ts.map +1 -1
- package/dist/cli/run-agent.js +4 -0
- package/dist/cli/run-agent.js.map +1 -1
- package/dist/cli/workflow.d.ts +56 -2
- package/dist/cli/workflow.d.ts.map +1 -1
- package/dist/cli/workflow.js +2165 -85
- package/dist/cli/workflow.js.map +1 -1
- package/dist/github/client.d.ts +12 -0
- package/dist/github/client.d.ts.map +1 -1
- package/dist/github/client.js +27 -0
- package/dist/github/client.js.map +1 -1
- package/dist/github/platform-adapter.d.ts +6 -1
- package/dist/github/platform-adapter.d.ts.map +1 -1
- package/dist/github/platform-adapter.js +84 -8
- package/dist/github/platform-adapter.js.map +1 -1
- package/dist/gitlab/client.d.ts +11 -0
- package/dist/gitlab/client.d.ts.map +1 -1
- package/dist/gitlab/client.js +11 -0
- package/dist/gitlab/client.js.map +1 -1
- package/dist/gitlab/platform-adapter.d.ts +3 -1
- package/dist/gitlab/platform-adapter.d.ts.map +1 -1
- package/dist/gitlab/platform-adapter.js +32 -1
- package/dist/gitlab/platform-adapter.js.map +1 -1
- package/dist/lib/comment-formatter.d.ts +8 -0
- package/dist/lib/comment-formatter.d.ts.map +1 -1
- package/dist/lib/comment-formatter.js +12 -4
- package/dist/lib/comment-formatter.js.map +1 -1
- package/dist/lib/comment-poster.d.ts.map +1 -1
- package/dist/lib/comment-poster.js +28 -1
- package/dist/lib/comment-poster.js.map +1 -1
- package/dist/lib/config.d.ts +50 -11
- package/dist/lib/config.d.ts.map +1 -1
- package/dist/lib/config.js +163 -28
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/context-compression.d.ts +10 -0
- package/dist/lib/context-compression.d.ts.map +1 -1
- package/dist/lib/context-compression.js +101 -13
- package/dist/lib/context-compression.js.map +1 -1
- package/dist/lib/context-loader.d.ts +2 -1
- package/dist/lib/context-loader.d.ts.map +1 -1
- package/dist/lib/context-loader.js +70 -1
- package/dist/lib/context-loader.js.map +1 -1
- package/dist/lib/describe-core.d.ts.map +1 -1
- package/dist/lib/describe-core.js +3 -2
- package/dist/lib/describe-core.js.map +1 -1
- package/dist/lib/diff-lines.d.ts +9 -0
- package/dist/lib/diff-lines.d.ts.map +1 -1
- package/dist/lib/diff-lines.js +17 -9
- package/dist/lib/diff-lines.js.map +1 -1
- package/dist/lib/exit.js +4 -4
- package/dist/lib/exit.js.map +1 -1
- package/dist/lib/html-artifact.d.ts +14 -0
- package/dist/lib/html-artifact.d.ts.map +1 -0
- package/dist/lib/html-artifact.js +59 -0
- package/dist/lib/html-artifact.js.map +1 -0
- package/dist/lib/issue-parser.js +3 -3
- package/dist/lib/issue-parser.js.map +1 -1
- package/dist/lib/json-output-schema.d.ts +70 -0
- package/dist/lib/json-output-schema.d.ts.map +1 -1
- package/dist/lib/json-output-schema.js +40 -0
- package/dist/lib/json-output-schema.js.map +1 -1
- package/dist/lib/platform-client.d.ts +26 -0
- package/dist/lib/platform-client.d.ts.map +1 -1
- package/dist/lib/review-artifact.d.ts +69 -0
- package/dist/lib/review-artifact.d.ts.map +1 -0
- package/dist/lib/review-artifact.js +171 -0
- package/dist/lib/review-artifact.js.map +1 -0
- package/dist/lib/review-core.d.ts +6 -4
- package/dist/lib/review-core.d.ts.map +1 -1
- package/dist/lib/review-core.js +71 -151
- package/dist/lib/review-core.js.map +1 -1
- package/dist/lib/review-orchestrator.d.ts +23 -0
- package/dist/lib/review-orchestrator.d.ts.map +1 -1
- package/dist/lib/review-orchestrator.js +20 -13
- package/dist/lib/review-orchestrator.js.map +1 -1
- package/dist/lib/review-usage.d.ts +4 -0
- package/dist/lib/review-usage.d.ts.map +1 -1
- package/dist/lib/review-usage.js +25 -0
- package/dist/lib/review-usage.js.map +1 -1
- package/dist/lib/trace-collector.d.ts +105 -0
- package/dist/lib/trace-collector.d.ts.map +1 -0
- package/dist/lib/trace-collector.js +255 -0
- package/dist/lib/trace-collector.js.map +1 -0
- package/dist/lib/trace-html.d.ts +3 -0
- package/dist/lib/trace-html.d.ts.map +1 -0
- package/dist/lib/trace-html.js +349 -0
- package/dist/lib/trace-html.js.map +1 -0
- package/dist/lib/workflow-artifacts.d.ts +54 -0
- package/dist/lib/workflow-artifacts.d.ts.map +1 -0
- package/dist/lib/workflow-artifacts.js +150 -0
- package/dist/lib/workflow-artifacts.js.map +1 -0
- package/dist/pi/sdk.d.ts.map +1 -1
- package/dist/pi/sdk.js +570 -6
- package/dist/pi/sdk.js.map +1 -1
- package/dist/runtime/agent-loader.js +2 -2
- package/dist/runtime/client.d.ts +2 -0
- package/dist/runtime/client.d.ts.map +1 -1
- package/dist/runtime/client.js +11 -5
- package/dist/runtime/client.js.map +1 -1
- package/package.json +21 -15
- package/.pi/workflows/github-pr-describe-post.yaml +0 -24
- package/.pi/workflows/gitlab-mr-describe-post.yaml +0 -22
- package/.pi/workflows/gitlab-mr-review-code-quality.yaml +0 -31
- package/.pi/workflows/gitlab-mr-review-post-code-quality.yaml +0 -40
- package/.pi/workflows/gitlab-mr-review-post.yaml +0 -30
- package/.pi/workflows/local-staged-review.yaml +0 -17
- package/dist/cli/run-agent.test.d.ts +0 -2
- package/dist/cli/run-agent.test.d.ts.map +0 -1
- package/dist/cli/run-agent.test.js +0 -204
- package/dist/cli/run-agent.test.js.map +0 -1
- package/dist/cli/workflow.test.d.ts +0 -2
- package/dist/cli/workflow.test.d.ts.map +0 -1
- package/dist/cli/workflow.test.js +0 -1410
- package/dist/cli/workflow.test.js.map +0 -1
- package/dist/github/client.test.d.ts +0 -2
- package/dist/github/client.test.d.ts.map +0 -1
- package/dist/github/client.test.js +0 -206
- package/dist/github/client.test.js.map +0 -1
- package/dist/github/platform-adapter.test.d.ts +0 -2
- package/dist/github/platform-adapter.test.d.ts.map +0 -1
- package/dist/github/platform-adapter.test.js +0 -40
- package/dist/github/platform-adapter.test.js.map +0 -1
- package/dist/gitlab/diff-parser.test.d.ts +0 -2
- package/dist/gitlab/diff-parser.test.d.ts.map +0 -1
- package/dist/gitlab/diff-parser.test.js +0 -315
- package/dist/gitlab/diff-parser.test.js.map +0 -1
- package/dist/gitlab/platform-adapter.test.d.ts +0 -2
- package/dist/gitlab/platform-adapter.test.d.ts.map +0 -1
- package/dist/gitlab/platform-adapter.test.js +0 -21
- package/dist/gitlab/platform-adapter.test.js.map +0 -1
- package/dist/index.test.d.ts +0 -2
- package/dist/index.test.d.ts.map +0 -1
- package/dist/index.test.js +0 -7
- package/dist/index.test.js.map +0 -1
- package/dist/lib/code-quality-report.test.d.ts +0 -2
- package/dist/lib/code-quality-report.test.d.ts.map +0 -1
- package/dist/lib/code-quality-report.test.js +0 -327
- package/dist/lib/code-quality-report.test.js.map +0 -1
- package/dist/lib/comment-formatter.test.d.ts +0 -2
- package/dist/lib/comment-formatter.test.d.ts.map +0 -1
- package/dist/lib/comment-formatter.test.js +0 -727
- package/dist/lib/comment-formatter.test.js.map +0 -1
- package/dist/lib/comment-manager.test.d.ts +0 -2
- package/dist/lib/comment-manager.test.d.ts.map +0 -1
- package/dist/lib/comment-manager.test.js +0 -680
- package/dist/lib/comment-manager.test.js.map +0 -1
- package/dist/lib/comment-poster.test.d.ts +0 -5
- package/dist/lib/comment-poster.test.d.ts.map +0 -1
- package/dist/lib/comment-poster.test.js +0 -255
- package/dist/lib/comment-poster.test.js.map +0 -1
- package/dist/lib/config-model-overrides.test.d.ts +0 -2
- package/dist/lib/config-model-overrides.test.d.ts.map +0 -1
- package/dist/lib/config-model-overrides.test.js +0 -218
- package/dist/lib/config-model-overrides.test.js.map +0 -1
- package/dist/lib/config.test.d.ts +0 -2
- package/dist/lib/config.test.d.ts.map +0 -1
- package/dist/lib/config.test.js +0 -353
- package/dist/lib/config.test.js.map +0 -1
- package/dist/lib/context-compression.test.d.ts +0 -2
- package/dist/lib/context-compression.test.d.ts.map +0 -1
- package/dist/lib/context-compression.test.js +0 -337
- package/dist/lib/context-compression.test.js.map +0 -1
- package/dist/lib/context-loader.test.d.ts +0 -2
- package/dist/lib/context-loader.test.d.ts.map +0 -1
- package/dist/lib/context-loader.test.js +0 -212
- package/dist/lib/context-loader.test.js.map +0 -1
- package/dist/lib/cursor-fix-link.test.d.ts +0 -2
- package/dist/lib/cursor-fix-link.test.d.ts.map +0 -1
- package/dist/lib/cursor-fix-link.test.js +0 -70
- package/dist/lib/cursor-fix-link.test.js.map +0 -1
- package/dist/lib/describe-core.test.d.ts +0 -2
- package/dist/lib/describe-core.test.d.ts.map +0 -1
- package/dist/lib/describe-core.test.js +0 -208
- package/dist/lib/describe-core.test.js.map +0 -1
- package/dist/lib/describe-output-path.test.d.ts +0 -2
- package/dist/lib/describe-output-path.test.d.ts.map +0 -1
- package/dist/lib/describe-output-path.test.js +0 -51
- package/dist/lib/describe-output-path.test.js.map +0 -1
- package/dist/lib/describe-parser.test.d.ts +0 -2
- package/dist/lib/describe-parser.test.d.ts.map +0 -1
- package/dist/lib/describe-parser.test.js +0 -282
- package/dist/lib/describe-parser.test.js.map +0 -1
- package/dist/lib/description-executor.test.d.ts +0 -2
- package/dist/lib/description-executor.test.d.ts.map +0 -1
- package/dist/lib/description-executor.test.js +0 -135
- package/dist/lib/description-executor.test.js.map +0 -1
- package/dist/lib/description-formatter.test.d.ts +0 -2
- package/dist/lib/description-formatter.test.d.ts.map +0 -1
- package/dist/lib/description-formatter.test.js +0 -57
- package/dist/lib/description-formatter.test.js.map +0 -1
- package/dist/lib/diff-lines.test.d.ts +0 -2
- package/dist/lib/diff-lines.test.d.ts.map +0 -1
- package/dist/lib/diff-lines.test.js +0 -13
- package/dist/lib/diff-lines.test.js.map +0 -1
- package/dist/lib/diff-parser.test.d.ts +0 -2
- package/dist/lib/diff-parser.test.d.ts.map +0 -1
- package/dist/lib/diff-parser.test.js +0 -335
- package/dist/lib/diff-parser.test.js.map +0 -1
- package/dist/lib/error-comment-poster.test.d.ts +0 -2
- package/dist/lib/error-comment-poster.test.d.ts.map +0 -1
- package/dist/lib/error-comment-poster.test.js +0 -128
- package/dist/lib/error-comment-poster.test.js.map +0 -1
- package/dist/lib/exit.test.d.ts +0 -2
- package/dist/lib/exit.test.d.ts.map +0 -1
- package/dist/lib/exit.test.js +0 -120
- package/dist/lib/exit.test.js.map +0 -1
- package/dist/lib/issue-parser.test.d.ts +0 -2
- package/dist/lib/issue-parser.test.d.ts.map +0 -1
- package/dist/lib/issue-parser.test.js +0 -281
- package/dist/lib/issue-parser.test.js.map +0 -1
- package/dist/lib/json-output-schema.test.d.ts +0 -2
- package/dist/lib/json-output-schema.test.d.ts.map +0 -1
- package/dist/lib/json-output-schema.test.js +0 -92
- package/dist/lib/json-output-schema.test.js.map +0 -1
- package/dist/lib/json-output.test.d.ts +0 -2
- package/dist/lib/json-output.test.d.ts.map +0 -1
- package/dist/lib/json-output.test.js +0 -141
- package/dist/lib/json-output.test.js.map +0 -1
- package/dist/lib/logger.test.d.ts +0 -2
- package/dist/lib/logger.test.d.ts.map +0 -1
- package/dist/lib/logger.test.js +0 -324
- package/dist/lib/logger.test.js.map +0 -1
- package/dist/lib/position-validator.test.d.ts +0 -2
- package/dist/lib/position-validator.test.d.ts.map +0 -1
- package/dist/lib/position-validator.test.js +0 -128
- package/dist/lib/position-validator.test.js.map +0 -1
- package/dist/lib/prompt-budget.test.d.ts +0 -2
- package/dist/lib/prompt-budget.test.d.ts.map +0 -1
- package/dist/lib/prompt-budget.test.js +0 -55
- package/dist/lib/prompt-budget.test.js.map +0 -1
- package/dist/lib/repository-validator.test.d.ts +0 -5
- package/dist/lib/repository-validator.test.d.ts.map +0 -1
- package/dist/lib/repository-validator.test.js +0 -341
- package/dist/lib/repository-validator.test.js.map +0 -1
- package/dist/lib/review-core.test.d.ts +0 -2
- package/dist/lib/review-core.test.d.ts.map +0 -1
- package/dist/lib/review-core.test.js +0 -614
- package/dist/lib/review-core.test.js.map +0 -1
- package/dist/lib/review-orchestrator.test.d.ts +0 -2
- package/dist/lib/review-orchestrator.test.d.ts.map +0 -1
- package/dist/lib/review-orchestrator.test.js +0 -552
- package/dist/lib/review-orchestrator.test.js.map +0 -1
- package/dist/lib/review-output-path.test.d.ts +0 -2
- package/dist/lib/review-output-path.test.d.ts.map +0 -1
- package/dist/lib/review-output-path.test.js +0 -83
- package/dist/lib/review-output-path.test.js.map +0 -1
- package/dist/lib/review-parser.test.d.ts +0 -2
- package/dist/lib/review-parser.test.d.ts.map +0 -1
- package/dist/lib/review-parser.test.js +0 -130
- package/dist/lib/review-parser.test.js.map +0 -1
- package/dist/lib/review-usage.test.d.ts +0 -2
- package/dist/lib/review-usage.test.d.ts.map +0 -1
- package/dist/lib/review-usage.test.js +0 -83
- package/dist/lib/review-usage.test.js.map +0 -1
- package/dist/lib/unified-review-executor.d.ts +0 -58
- package/dist/lib/unified-review-executor.d.ts.map +0 -1
- package/dist/lib/unified-review-executor.js +0 -201
- package/dist/lib/unified-review-executor.js.map +0 -1
- package/dist/lib/unified-review-executor.test.d.ts +0 -5
- package/dist/lib/unified-review-executor.test.d.ts.map +0 -1
- package/dist/lib/unified-review-executor.test.js +0 -472
- package/dist/lib/unified-review-executor.test.js.map +0 -1
- package/dist/lib/write-json-output.test.d.ts +0 -2
- package/dist/lib/write-json-output.test.d.ts.map +0 -1
- package/dist/lib/write-json-output.test.js +0 -259
- package/dist/lib/write-json-output.test.js.map +0 -1
- package/dist/pi/sdk.test.d.ts +0 -2
- package/dist/pi/sdk.test.d.ts.map +0 -1
- package/dist/pi/sdk.test.js +0 -488
- package/dist/pi/sdk.test.js.map +0 -1
- package/dist/runtime/agent-loader.test.d.ts +0 -2
- package/dist/runtime/agent-loader.test.d.ts.map +0 -1
- package/dist/runtime/agent-loader.test.js +0 -277
- package/dist/runtime/agent-loader.test.js.map +0 -1
- package/dist/runtime/client.test.d.ts +0 -2
- package/dist/runtime/client.test.d.ts.map +0 -1
- package/dist/runtime/client.test.js +0 -772
- package/dist/runtime/client.test.js.map +0 -1
- package/dist/runtime/path-config.test.d.ts +0 -2
- package/dist/runtime/path-config.test.d.ts.map +0 -1
- package/dist/runtime/path-config.test.js +0 -112
- package/dist/runtime/path-config.test.js.map +0 -1
|
@@ -1,281 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { parseReviewIssues } from './issue-parser.js';
|
|
3
|
-
describe('parseReviewIssues', () => {
|
|
4
|
-
it('should parse valid JSON code block with issues', () => {
|
|
5
|
-
const content = `Here are my findings:
|
|
6
|
-
|
|
7
|
-
\`\`\`json
|
|
8
|
-
{
|
|
9
|
-
"issues": [
|
|
10
|
-
{
|
|
11
|
-
"category": "SECURITY",
|
|
12
|
-
"severity": "CRITICAL",
|
|
13
|
-
"title": "SQL Injection vulnerability",
|
|
14
|
-
"file": "src/api/users.ts",
|
|
15
|
-
"line": 42,
|
|
16
|
-
"problem": "Query uses string concatenation",
|
|
17
|
-
"solution": "Use parameterized queries",
|
|
18
|
-
"references": ["https://owasp.org/sql-injection"],
|
|
19
|
-
"agent": "security"
|
|
20
|
-
}
|
|
21
|
-
]
|
|
22
|
-
}
|
|
23
|
-
\`\`\``;
|
|
24
|
-
const issues = parseReviewIssues(content, 'security');
|
|
25
|
-
expect(issues).toHaveLength(1);
|
|
26
|
-
expect(issues[0]).toEqual({
|
|
27
|
-
category: 'SECURITY',
|
|
28
|
-
severity: 'CRITICAL',
|
|
29
|
-
title: 'SQL Injection vulnerability',
|
|
30
|
-
file: 'src/api/users.ts',
|
|
31
|
-
line: 42,
|
|
32
|
-
problem: 'Query uses string concatenation',
|
|
33
|
-
solution: 'Use parameterized queries',
|
|
34
|
-
references: ['https://owasp.org/sql-injection'],
|
|
35
|
-
agent: 'security',
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
it('should parse multiple issues in a single JSON block', () => {
|
|
39
|
-
const content = `\`\`\`json
|
|
40
|
-
{
|
|
41
|
-
"issues": [
|
|
42
|
-
{
|
|
43
|
-
"category": "QUALITY",
|
|
44
|
-
"severity": "HIGH",
|
|
45
|
-
"title": "High complexity function",
|
|
46
|
-
"file": "src/utils/helper.ts",
|
|
47
|
-
"line": 10,
|
|
48
|
-
"problem": "Function has cyclomatic complexity of 15",
|
|
49
|
-
"solution": "Break into smaller functions",
|
|
50
|
-
"agent": "quality"
|
|
51
|
-
},
|
|
52
|
-
{
|
|
53
|
-
"category": "QUALITY",
|
|
54
|
-
"severity": "MEDIUM",
|
|
55
|
-
"title": "Code duplication",
|
|
56
|
-
"file": "src/utils/helper.ts",
|
|
57
|
-
"line": 50,
|
|
58
|
-
"problem": "Duplicated validation logic",
|
|
59
|
-
"solution": "Extract to shared validator function"
|
|
60
|
-
}
|
|
61
|
-
]
|
|
62
|
-
}
|
|
63
|
-
\`\`\``;
|
|
64
|
-
const issues = parseReviewIssues(content, 'quality');
|
|
65
|
-
expect(issues).toHaveLength(2);
|
|
66
|
-
expect(issues[0].severity).toBe('HIGH');
|
|
67
|
-
expect(issues[1].severity).toBe('MEDIUM');
|
|
68
|
-
expect(issues[1].agent).toBe('quality'); // Should use default agent name
|
|
69
|
-
});
|
|
70
|
-
it('should parse raw JSON without code block markers', () => {
|
|
71
|
-
const content = `{"issues":[{"category":"PERFORMANCE","severity":"LOW","title":"Inefficient loop","file":"src/app.ts","line":5,"problem":"Using nested loops","solution":"Use hash map"}]}`;
|
|
72
|
-
const issues = parseReviewIssues(content, 'performance');
|
|
73
|
-
expect(issues).toHaveLength(1);
|
|
74
|
-
expect(issues[0].category).toBe('PERFORMANCE');
|
|
75
|
-
expect(issues[0].file).toBe('src/app.ts');
|
|
76
|
-
});
|
|
77
|
-
it('should handle issues without line numbers', () => {
|
|
78
|
-
const content = `\`\`\`json
|
|
79
|
-
{
|
|
80
|
-
"issues": [
|
|
81
|
-
{
|
|
82
|
-
"category": "STYLE",
|
|
83
|
-
"severity": "LOW",
|
|
84
|
-
"title": "Missing file header",
|
|
85
|
-
"file": "src/main.ts",
|
|
86
|
-
"problem": "No copyright header",
|
|
87
|
-
"solution": "Add standard file header",
|
|
88
|
-
"agent": "style"
|
|
89
|
-
}
|
|
90
|
-
]
|
|
91
|
-
}
|
|
92
|
-
\`\`\``;
|
|
93
|
-
const issues = parseReviewIssues(content, 'style');
|
|
94
|
-
expect(issues).toHaveLength(1);
|
|
95
|
-
expect(issues[0].line).toBeUndefined();
|
|
96
|
-
});
|
|
97
|
-
it('should handle issues without references', () => {
|
|
98
|
-
const content = `\`\`\`json
|
|
99
|
-
{
|
|
100
|
-
"issues": [
|
|
101
|
-
{
|
|
102
|
-
"category": "QUALITY",
|
|
103
|
-
"severity": "MEDIUM",
|
|
104
|
-
"title": "Long function",
|
|
105
|
-
"file": "src/utils.ts",
|
|
106
|
-
"line": 100,
|
|
107
|
-
"problem": "Function exceeds 50 lines",
|
|
108
|
-
"solution": "Refactor into smaller functions",
|
|
109
|
-
"agent": "quality"
|
|
110
|
-
}
|
|
111
|
-
]
|
|
112
|
-
}
|
|
113
|
-
\`\`\``;
|
|
114
|
-
const issues = parseReviewIssues(content, 'quality');
|
|
115
|
-
expect(issues).toHaveLength(1);
|
|
116
|
-
expect(issues[0].references).toBeUndefined();
|
|
117
|
-
});
|
|
118
|
-
it('should return empty array for invalid JSON', () => {
|
|
119
|
-
const content = 'This is not valid JSON';
|
|
120
|
-
const issues = parseReviewIssues(content);
|
|
121
|
-
expect(issues).toEqual([]);
|
|
122
|
-
});
|
|
123
|
-
it('should return empty array for JSON without issues array', () => {
|
|
124
|
-
const content = `\`\`\`json
|
|
125
|
-
{
|
|
126
|
-
"message": "No issues found"
|
|
127
|
-
}
|
|
128
|
-
\`\`\``;
|
|
129
|
-
const issues = parseReviewIssues(content);
|
|
130
|
-
expect(issues).toEqual([]);
|
|
131
|
-
});
|
|
132
|
-
it('should skip invalid issues that are missing required fields', () => {
|
|
133
|
-
const content = `\`\`\`json
|
|
134
|
-
{
|
|
135
|
-
"issues": [
|
|
136
|
-
{
|
|
137
|
-
"category": "SECURITY",
|
|
138
|
-
"severity": "HIGH",
|
|
139
|
-
"title": "Missing problem field",
|
|
140
|
-
"file": "src/test.ts",
|
|
141
|
-
"solution": "Fix it"
|
|
142
|
-
},
|
|
143
|
-
{
|
|
144
|
-
"category": "QUALITY",
|
|
145
|
-
"severity": "MEDIUM",
|
|
146
|
-
"title": "Valid issue",
|
|
147
|
-
"file": "src/valid.ts",
|
|
148
|
-
"line": 10,
|
|
149
|
-
"problem": "This is valid",
|
|
150
|
-
"solution": "This has all required fields"
|
|
151
|
-
}
|
|
152
|
-
]
|
|
153
|
-
}
|
|
154
|
-
\`\`\``;
|
|
155
|
-
const issues = parseReviewIssues(content);
|
|
156
|
-
// Should only parse the valid issue
|
|
157
|
-
expect(issues).toHaveLength(1);
|
|
158
|
-
expect(issues[0].title).toBe('Valid issue');
|
|
159
|
-
});
|
|
160
|
-
it('should reject issues with invalid category', () => {
|
|
161
|
-
const content = `\`\`\`json
|
|
162
|
-
{
|
|
163
|
-
"issues": [
|
|
164
|
-
{
|
|
165
|
-
"category": "INVALID_CATEGORY",
|
|
166
|
-
"severity": "HIGH",
|
|
167
|
-
"title": "Test",
|
|
168
|
-
"file": "test.ts",
|
|
169
|
-
"problem": "Problem",
|
|
170
|
-
"solution": "Solution"
|
|
171
|
-
}
|
|
172
|
-
]
|
|
173
|
-
}
|
|
174
|
-
\`\`\``;
|
|
175
|
-
const issues = parseReviewIssues(content);
|
|
176
|
-
expect(issues).toEqual([]);
|
|
177
|
-
});
|
|
178
|
-
it('should reject issues with invalid severity', () => {
|
|
179
|
-
const content = `\`\`\`json
|
|
180
|
-
{
|
|
181
|
-
"issues": [
|
|
182
|
-
{
|
|
183
|
-
"category": "SECURITY",
|
|
184
|
-
"severity": "SUPER_CRITICAL",
|
|
185
|
-
"title": "Test",
|
|
186
|
-
"file": "test.ts",
|
|
187
|
-
"problem": "Problem",
|
|
188
|
-
"solution": "Solution"
|
|
189
|
-
}
|
|
190
|
-
]
|
|
191
|
-
}
|
|
192
|
-
\`\`\``;
|
|
193
|
-
const issues = parseReviewIssues(content);
|
|
194
|
-
expect(issues).toEqual([]);
|
|
195
|
-
});
|
|
196
|
-
it('should handle multiple JSON blocks in same content', () => {
|
|
197
|
-
const content = `First agent findings:
|
|
198
|
-
|
|
199
|
-
\`\`\`json
|
|
200
|
-
{
|
|
201
|
-
"issues": [
|
|
202
|
-
{
|
|
203
|
-
"category": "SECURITY",
|
|
204
|
-
"severity": "HIGH",
|
|
205
|
-
"title": "Issue 1",
|
|
206
|
-
"file": "src/a.ts",
|
|
207
|
-
"line": 1,
|
|
208
|
-
"problem": "Problem 1",
|
|
209
|
-
"solution": "Solution 1",
|
|
210
|
-
"agent": "security"
|
|
211
|
-
}
|
|
212
|
-
]
|
|
213
|
-
}
|
|
214
|
-
\`\`\`
|
|
215
|
-
|
|
216
|
-
Second agent findings:
|
|
217
|
-
|
|
218
|
-
\`\`\`json
|
|
219
|
-
{
|
|
220
|
-
"issues": [
|
|
221
|
-
{
|
|
222
|
-
"category": "QUALITY",
|
|
223
|
-
"severity": "MEDIUM",
|
|
224
|
-
"title": "Issue 2",
|
|
225
|
-
"file": "src/b.ts",
|
|
226
|
-
"line": 2,
|
|
227
|
-
"problem": "Problem 2",
|
|
228
|
-
"solution": "Solution 2",
|
|
229
|
-
"agent": "quality"
|
|
230
|
-
}
|
|
231
|
-
]
|
|
232
|
-
}
|
|
233
|
-
\`\`\``;
|
|
234
|
-
const issues = parseReviewIssues(content);
|
|
235
|
-
expect(issues).toHaveLength(2);
|
|
236
|
-
expect(issues[0].agent).toBe('security');
|
|
237
|
-
expect(issues[1].agent).toBe('quality');
|
|
238
|
-
});
|
|
239
|
-
it('should use provided agent name when issue does not have agent field', () => {
|
|
240
|
-
const content = `\`\`\`json
|
|
241
|
-
{
|
|
242
|
-
"issues": [
|
|
243
|
-
{
|
|
244
|
-
"category": "PERFORMANCE",
|
|
245
|
-
"severity": "LOW",
|
|
246
|
-
"title": "Slow operation",
|
|
247
|
-
"file": "src/perf.ts",
|
|
248
|
-
"line": 20,
|
|
249
|
-
"problem": "Inefficient algorithm",
|
|
250
|
-
"solution": "Use better algorithm"
|
|
251
|
-
}
|
|
252
|
-
]
|
|
253
|
-
}
|
|
254
|
-
\`\`\``;
|
|
255
|
-
const issues = parseReviewIssues(content, 'performance-agent');
|
|
256
|
-
expect(issues).toHaveLength(1);
|
|
257
|
-
expect(issues[0].agent).toBe('performance-agent');
|
|
258
|
-
});
|
|
259
|
-
it('should handle whitespace in JSON code blocks', () => {
|
|
260
|
-
const content = `\`\`\`json
|
|
261
|
-
|
|
262
|
-
{
|
|
263
|
-
"issues": [
|
|
264
|
-
{
|
|
265
|
-
"category": "STYLE",
|
|
266
|
-
"severity": "LOW",
|
|
267
|
-
"title": "Formatting",
|
|
268
|
-
"file": "src/style.ts",
|
|
269
|
-
"line": 1,
|
|
270
|
-
"problem": "Inconsistent formatting",
|
|
271
|
-
"solution": "Run prettier"
|
|
272
|
-
}
|
|
273
|
-
]
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
\`\`\``;
|
|
277
|
-
const issues = parseReviewIssues(content);
|
|
278
|
-
expect(issues).toHaveLength(1);
|
|
279
|
-
});
|
|
280
|
-
});
|
|
281
|
-
//# sourceMappingURL=issue-parser.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"issue-parser.test.js","sourceRoot":"","sources":["../../src/lib/issue-parser.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json-output-schema.test.d.ts","sourceRoot":"","sources":["../../src/lib/json-output-schema.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import Ajv from 'ajv';
|
|
3
|
-
import { describeOutputSchema, reviewOutputSchema } from './json-output-schema.js';
|
|
4
|
-
const ajv = new Ajv({ allErrors: true });
|
|
5
|
-
const validateDescribe = ajv.compile(describeOutputSchema);
|
|
6
|
-
const validateReview = ajv.compile(reviewOutputSchema);
|
|
7
|
-
describe('json-output schemas', () => {
|
|
8
|
-
it('validates describe output schema', () => {
|
|
9
|
-
const payload = {
|
|
10
|
-
type: 'feature',
|
|
11
|
-
title: 'Add describe output validation tooling',
|
|
12
|
-
summary: ['Adds schema validation for describe output'],
|
|
13
|
-
walkthrough: [
|
|
14
|
-
{
|
|
15
|
-
file: 'src/lib/describe-core.ts',
|
|
16
|
-
changeType: 'modified',
|
|
17
|
-
semanticLabel: 'feature',
|
|
18
|
-
title: 'Require tool-based output',
|
|
19
|
-
changes: ['Adds write_json_output requirement'],
|
|
20
|
-
significance: 'major',
|
|
21
|
-
},
|
|
22
|
-
],
|
|
23
|
-
labels: ['feature', 'describe'],
|
|
24
|
-
recommendations: ['Add unit tests for schema validation'],
|
|
25
|
-
};
|
|
26
|
-
const isValid = validateDescribe(payload);
|
|
27
|
-
expect(isValid).toBe(true);
|
|
28
|
-
expect(validateDescribe.errors).toBeNull();
|
|
29
|
-
});
|
|
30
|
-
it('rejects describe output with invalid type', () => {
|
|
31
|
-
const payload = {
|
|
32
|
-
type: 'invalid',
|
|
33
|
-
title: 'Bad type',
|
|
34
|
-
summary: ['Invalid type'],
|
|
35
|
-
};
|
|
36
|
-
const isValid = validateDescribe(payload);
|
|
37
|
-
expect(isValid).toBe(false);
|
|
38
|
-
});
|
|
39
|
-
it('validates review output schema', () => {
|
|
40
|
-
const payload = {
|
|
41
|
-
timestamp: new Date().toISOString(),
|
|
42
|
-
summary: {
|
|
43
|
-
filesReviewed: 3,
|
|
44
|
-
issuesFound: 2,
|
|
45
|
-
bySeverity: {
|
|
46
|
-
CRITICAL: 0,
|
|
47
|
-
HIGH: 1,
|
|
48
|
-
MEDIUM: 1,
|
|
49
|
-
LOW: 0,
|
|
50
|
-
},
|
|
51
|
-
byCategory: {
|
|
52
|
-
SECURITY: 1,
|
|
53
|
-
QUALITY: 1,
|
|
54
|
-
STYLE: 0,
|
|
55
|
-
PERFORMANCE: 0,
|
|
56
|
-
DOCUMENTATION: 0,
|
|
57
|
-
},
|
|
58
|
-
},
|
|
59
|
-
issues: [
|
|
60
|
-
{
|
|
61
|
-
category: 'SECURITY',
|
|
62
|
-
severity: 'HIGH',
|
|
63
|
-
title: 'Avoid plaintext secrets',
|
|
64
|
-
file: 'src/config.ts',
|
|
65
|
-
problem: 'Secret is stored in code.',
|
|
66
|
-
solution: 'Use environment variables.',
|
|
67
|
-
agent: 'review/security',
|
|
68
|
-
},
|
|
69
|
-
],
|
|
70
|
-
metadata: {
|
|
71
|
-
source: 'PR #123',
|
|
72
|
-
project: 'org/repo',
|
|
73
|
-
branch: {
|
|
74
|
-
source: 'feature',
|
|
75
|
-
target: 'main',
|
|
76
|
-
},
|
|
77
|
-
},
|
|
78
|
-
};
|
|
79
|
-
const isValid = validateReview(payload);
|
|
80
|
-
expect(isValid).toBe(true);
|
|
81
|
-
expect(validateReview.errors).toBeNull();
|
|
82
|
-
});
|
|
83
|
-
it('rejects review output with missing summary', () => {
|
|
84
|
-
const payload = {
|
|
85
|
-
timestamp: new Date().toISOString(),
|
|
86
|
-
issues: [],
|
|
87
|
-
};
|
|
88
|
-
const isValid = validateReview(payload);
|
|
89
|
-
expect(isValid).toBe(false);
|
|
90
|
-
});
|
|
91
|
-
});
|
|
92
|
-
//# sourceMappingURL=json-output-schema.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json-output-schema.test.js","sourceRoot":"","sources":["../../src/lib/json-output-schema.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json-output.test.d.ts","sourceRoot":"","sources":["../../src/lib/json-output.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi, afterEach } from 'vitest';
|
|
2
|
-
import { writeFile, readFile, rm, mkdir } from 'fs/promises';
|
|
3
|
-
import { join } from 'path';
|
|
4
|
-
import { tmpdir } from 'os';
|
|
5
|
-
import { formatReviewJson, writeReviewJson, printReviewJson } from './json-output.js';
|
|
6
|
-
// ── Fixtures ─────────────────────────────────────────────────────
|
|
7
|
-
const SUMMARY = {
|
|
8
|
-
filesReviewed: 5,
|
|
9
|
-
issuesFound: 2,
|
|
10
|
-
bySeverity: { CRITICAL: 0, HIGH: 1, MEDIUM: 1, LOW: 0 },
|
|
11
|
-
byCategory: { SECURITY: 1, QUALITY: 1, STYLE: 0, PERFORMANCE: 0, DOCUMENTATION: 0 },
|
|
12
|
-
};
|
|
13
|
-
const ISSUES = [
|
|
14
|
-
{
|
|
15
|
-
category: 'SECURITY',
|
|
16
|
-
severity: 'HIGH',
|
|
17
|
-
title: 'SQL Injection',
|
|
18
|
-
file: 'src/db.ts',
|
|
19
|
-
line: 42,
|
|
20
|
-
problem: 'Unsanitized query',
|
|
21
|
-
solution: 'Use parameterized queries',
|
|
22
|
-
agent: 'security',
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
category: 'QUALITY',
|
|
26
|
-
severity: 'MEDIUM',
|
|
27
|
-
title: 'Missing null check',
|
|
28
|
-
file: 'src/utils.ts',
|
|
29
|
-
problem: 'Possible null dereference',
|
|
30
|
-
solution: 'Add null guard',
|
|
31
|
-
agent: 'quality',
|
|
32
|
-
},
|
|
33
|
-
];
|
|
34
|
-
// ── formatReviewJson ─────────────────────────────────────────────
|
|
35
|
-
describe('formatReviewJson', () => {
|
|
36
|
-
it('creates output with timestamp, summary, and issues', () => {
|
|
37
|
-
const result = formatReviewJson(SUMMARY, ISSUES);
|
|
38
|
-
expect(result.timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T/);
|
|
39
|
-
expect(result.summary).toEqual(SUMMARY);
|
|
40
|
-
expect(result.issues).toEqual(ISSUES);
|
|
41
|
-
expect(result.usage).toBeUndefined();
|
|
42
|
-
expect(result.metadata).toBeUndefined();
|
|
43
|
-
});
|
|
44
|
-
it('includes metadata when provided', () => {
|
|
45
|
-
const metadata = {
|
|
46
|
-
source: 'MR !42',
|
|
47
|
-
project: 'org/repo',
|
|
48
|
-
branch: { source: 'feature', target: 'main' },
|
|
49
|
-
};
|
|
50
|
-
const result = formatReviewJson(SUMMARY, ISSUES, metadata);
|
|
51
|
-
expect(result.metadata).toEqual(metadata);
|
|
52
|
-
});
|
|
53
|
-
it('includes usage when provided', () => {
|
|
54
|
-
const usage = {
|
|
55
|
-
total: {
|
|
56
|
-
input: 1000,
|
|
57
|
-
output: 200,
|
|
58
|
-
cacheRead: 50,
|
|
59
|
-
cacheWrite: 10,
|
|
60
|
-
totalTokens: 1260,
|
|
61
|
-
cost: 0.005,
|
|
62
|
-
},
|
|
63
|
-
agents: [],
|
|
64
|
-
};
|
|
65
|
-
const result = formatReviewJson(SUMMARY, ISSUES, undefined, usage);
|
|
66
|
-
expect(result.usage).toEqual(usage);
|
|
67
|
-
});
|
|
68
|
-
it('handles empty issues array', () => {
|
|
69
|
-
const emptySummary = {
|
|
70
|
-
filesReviewed: 3,
|
|
71
|
-
issuesFound: 0,
|
|
72
|
-
bySeverity: { CRITICAL: 0, HIGH: 0, MEDIUM: 0, LOW: 0 },
|
|
73
|
-
byCategory: { SECURITY: 0, QUALITY: 0, STYLE: 0, PERFORMANCE: 0, DOCUMENTATION: 0 },
|
|
74
|
-
};
|
|
75
|
-
const result = formatReviewJson(emptySummary, []);
|
|
76
|
-
expect(result.issues).toEqual([]);
|
|
77
|
-
expect(result.summary.issuesFound).toBe(0);
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
// ── writeReviewJson ──────────────────────────────────────────────
|
|
81
|
-
describe('writeReviewJson', () => {
|
|
82
|
-
let testDir;
|
|
83
|
-
afterEach(async () => {
|
|
84
|
-
if (testDir) {
|
|
85
|
-
await rm(testDir, { recursive: true, force: true });
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
it('writes formatted JSON to the specified path', async () => {
|
|
89
|
-
testDir = join(tmpdir(), `drs-json-output-test-${Date.now()}-${Math.random().toString(36).slice(2)}`);
|
|
90
|
-
await mkdir(testDir, { recursive: true });
|
|
91
|
-
const output = formatReviewJson(SUMMARY, ISSUES);
|
|
92
|
-
const outputPath = 'review.json';
|
|
93
|
-
await writeReviewJson(output, outputPath, testDir);
|
|
94
|
-
const content = await readFile(join(testDir, outputPath), 'utf-8');
|
|
95
|
-
const parsed = JSON.parse(content);
|
|
96
|
-
expect(parsed.summary.filesReviewed).toBe(5);
|
|
97
|
-
expect(parsed.issues).toHaveLength(2);
|
|
98
|
-
// Verify 2-space indent
|
|
99
|
-
expect(content).toContain(' "timestamp"');
|
|
100
|
-
});
|
|
101
|
-
it('overwrites existing file', async () => {
|
|
102
|
-
testDir = join(tmpdir(), `drs-json-output-test-${Date.now()}-${Math.random().toString(36).slice(2)}`);
|
|
103
|
-
await mkdir(testDir, { recursive: true });
|
|
104
|
-
const outputPath = 'review.json';
|
|
105
|
-
await writeFile(join(testDir, outputPath), '{"old": true}');
|
|
106
|
-
const output = formatReviewJson(SUMMARY, ISSUES);
|
|
107
|
-
await writeReviewJson(output, outputPath, testDir);
|
|
108
|
-
const content = await readFile(join(testDir, outputPath), 'utf-8');
|
|
109
|
-
const parsed = JSON.parse(content);
|
|
110
|
-
expect(parsed.old).toBeUndefined();
|
|
111
|
-
expect(parsed.issues).toHaveLength(2);
|
|
112
|
-
});
|
|
113
|
-
it('refuses to write outside the working directory', async () => {
|
|
114
|
-
testDir = join(tmpdir(), `drs-json-output-test-${Date.now()}-${Math.random().toString(36).slice(2)}`);
|
|
115
|
-
await mkdir(testDir, { recursive: true });
|
|
116
|
-
const output = formatReviewJson(SUMMARY, ISSUES);
|
|
117
|
-
await expect(writeReviewJson(output, '../outside.json', testDir)).rejects.toThrow('Refusing to write outside working directory');
|
|
118
|
-
});
|
|
119
|
-
});
|
|
120
|
-
// ── printReviewJson ──────────────────────────────────────────────
|
|
121
|
-
describe('printReviewJson', () => {
|
|
122
|
-
it('prints formatted JSON to console.log', () => {
|
|
123
|
-
const spy = vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
124
|
-
const output = formatReviewJson(SUMMARY, ISSUES);
|
|
125
|
-
printReviewJson(output);
|
|
126
|
-
expect(spy).toHaveBeenCalledTimes(1);
|
|
127
|
-
const printed = String(spy.mock.calls[0][0]);
|
|
128
|
-
const parsed = JSON.parse(printed);
|
|
129
|
-
expect(parsed.issues).toHaveLength(2);
|
|
130
|
-
spy.mockRestore();
|
|
131
|
-
});
|
|
132
|
-
it('output is valid JSON with 2-space indent', () => {
|
|
133
|
-
const spy = vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
134
|
-
printReviewJson(formatReviewJson(SUMMARY, []));
|
|
135
|
-
const printed = String(spy.mock.calls[0][0]);
|
|
136
|
-
expect(printed).toContain(' "timestamp"');
|
|
137
|
-
expect(() => JSON.parse(printed)).not.toThrow();
|
|
138
|
-
spy.mockRestore();
|
|
139
|
-
});
|
|
140
|
-
});
|
|
141
|
-
//# sourceMappingURL=json-output.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json-output.test.js","sourceRoot":"","sources":["../../src/lib/json-output.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"logger.test.d.ts","sourceRoot":"","sources":["../../src/lib/logger.test.ts"],"names":[],"mappings":""}
|