superskill 0.2.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 +42 -0
- package/LICENSE +21 -0
- package/README.md +235 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +1158 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/brainstorm.d.ts +9 -0
- package/dist/commands/brainstorm.js +37 -0
- package/dist/commands/brainstorm.js.map +1 -0
- package/dist/commands/brainstorm.test.d.ts +1 -0
- package/dist/commands/brainstorm.test.js +110 -0
- package/dist/commands/brainstorm.test.js.map +1 -0
- package/dist/commands/context.d.ts +18 -0
- package/dist/commands/context.js +88 -0
- package/dist/commands/context.js.map +1 -0
- package/dist/commands/context.test.d.ts +1 -0
- package/dist/commands/context.test.js +230 -0
- package/dist/commands/context.test.js.map +1 -0
- package/dist/commands/decide.d.ts +12 -0
- package/dist/commands/decide.js +40 -0
- package/dist/commands/decide.js.map +1 -0
- package/dist/commands/decide.test.d.ts +1 -0
- package/dist/commands/decide.test.js +109 -0
- package/dist/commands/decide.test.js.map +1 -0
- package/dist/commands/graph.d.ts +15 -0
- package/dist/commands/graph.js +89 -0
- package/dist/commands/graph.js.map +1 -0
- package/dist/commands/graph.test.d.ts +1 -0
- package/dist/commands/graph.test.js +215 -0
- package/dist/commands/graph.test.js.map +1 -0
- package/dist/commands/init.d.ts +11 -0
- package/dist/commands/init.js +257 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/learn.d.ts +25 -0
- package/dist/commands/learn.js +92 -0
- package/dist/commands/learn.js.map +1 -0
- package/dist/commands/learn.test.d.ts +1 -0
- package/dist/commands/learn.test.js +241 -0
- package/dist/commands/learn.test.js.map +1 -0
- package/dist/commands/prune.d.ts +58 -0
- package/dist/commands/prune.js +246 -0
- package/dist/commands/prune.js.map +1 -0
- package/dist/commands/read.d.ts +8 -0
- package/dist/commands/read.js +7 -0
- package/dist/commands/read.js.map +1 -0
- package/dist/commands/read.test.d.ts +1 -0
- package/dist/commands/read.test.js +48 -0
- package/dist/commands/read.test.js.map +1 -0
- package/dist/commands/resume.d.ts +20 -0
- package/dist/commands/resume.js +141 -0
- package/dist/commands/resume.js.map +1 -0
- package/dist/commands/resume.test.d.ts +1 -0
- package/dist/commands/resume.test.js +243 -0
- package/dist/commands/resume.test.js.map +1 -0
- package/dist/commands/search.d.ts +8 -0
- package/dist/commands/search.js +25 -0
- package/dist/commands/search.js.map +1 -0
- package/dist/commands/search.test.d.ts +1 -0
- package/dist/commands/search.test.js +61 -0
- package/dist/commands/search.test.js.map +1 -0
- package/dist/commands/session.d.ts +22 -0
- package/dist/commands/session.js +79 -0
- package/dist/commands/session.js.map +1 -0
- package/dist/commands/session.test.d.ts +1 -0
- package/dist/commands/session.test.js +231 -0
- package/dist/commands/session.test.js.map +1 -0
- package/dist/commands/skill/catalog.d.ts +39 -0
- package/dist/commands/skill/catalog.js +260 -0
- package/dist/commands/skill/catalog.js.map +1 -0
- package/dist/commands/skill/index.d.ts +55 -0
- package/dist/commands/skill/index.js +82 -0
- package/dist/commands/skill/index.js.map +1 -0
- package/dist/commands/skill/index.test.d.ts +1 -0
- package/dist/commands/skill/index.test.js +137 -0
- package/dist/commands/skill/index.test.js.map +1 -0
- package/dist/commands/skill/install.d.ts +14 -0
- package/dist/commands/skill/install.js +108 -0
- package/dist/commands/skill/install.js.map +1 -0
- package/dist/commands/skill/install.test.d.ts +1 -0
- package/dist/commands/skill/install.test.js +225 -0
- package/dist/commands/skill/install.test.js.map +1 -0
- package/dist/commands/skill/list.d.ts +6 -0
- package/dist/commands/skill/list.js +5 -0
- package/dist/commands/skill/list.js.map +1 -0
- package/dist/commands/skill/list.test.d.ts +1 -0
- package/dist/commands/skill/list.test.js +101 -0
- package/dist/commands/skill/list.test.js.map +1 -0
- package/dist/commands/skill/marketplace.d.ts +121 -0
- package/dist/commands/skill/marketplace.js +548 -0
- package/dist/commands/skill/marketplace.js.map +1 -0
- package/dist/commands/skill/schema.d.ts +27 -0
- package/dist/commands/skill/schema.js +55 -0
- package/dist/commands/skill/schema.js.map +1 -0
- package/dist/commands/skill/schema.test.d.ts +1 -0
- package/dist/commands/skill/schema.test.js +142 -0
- package/dist/commands/skill/schema.test.js.map +1 -0
- package/dist/commands/skill/validate.d.ts +10 -0
- package/dist/commands/skill/validate.js +40 -0
- package/dist/commands/skill/validate.js.map +1 -0
- package/dist/commands/skill/validate.test.d.ts +1 -0
- package/dist/commands/skill/validate.test.js +171 -0
- package/dist/commands/skill/validate.test.js.map +1 -0
- package/dist/commands/task.d.ts +34 -0
- package/dist/commands/task.js +160 -0
- package/dist/commands/task.js.map +1 -0
- package/dist/commands/task.test.d.ts +1 -0
- package/dist/commands/task.test.js +395 -0
- package/dist/commands/task.test.js.map +1 -0
- package/dist/commands/todo.d.ts +15 -0
- package/dist/commands/todo.js +99 -0
- package/dist/commands/todo.js.map +1 -0
- package/dist/commands/todo.test.d.ts +1 -0
- package/dist/commands/todo.test.js +324 -0
- package/dist/commands/todo.test.js.map +1 -0
- package/dist/commands/write.d.ts +12 -0
- package/dist/commands/write.js +40 -0
- package/dist/commands/write.js.map +1 -0
- package/dist/commands/write.test.d.ts +1 -0
- package/dist/commands/write.test.js +79 -0
- package/dist/commands/write.test.js.map +1 -0
- package/dist/config.d.ts +15 -0
- package/dist/config.js +49 -0
- package/dist/config.js.map +1 -0
- package/dist/config.test.d.ts +1 -0
- package/dist/config.test.js +147 -0
- package/dist/config.test.js.map +1 -0
- package/dist/core/executor.d.ts +11 -0
- package/dist/core/executor.js +42 -0
- package/dist/core/executor.js.map +1 -0
- package/dist/core/executor.test.d.ts +1 -0
- package/dist/core/executor.test.js +206 -0
- package/dist/core/executor.test.js.map +1 -0
- package/dist/core/middleware/error-handler.d.ts +2 -0
- package/dist/core/middleware/error-handler.js +29 -0
- package/dist/core/middleware/error-handler.js.map +1 -0
- package/dist/core/middleware/index.d.ts +2 -0
- package/dist/core/middleware/index.js +3 -0
- package/dist/core/middleware/index.js.map +1 -0
- package/dist/core/middleware/logging.d.ts +2 -0
- package/dist/core/middleware/logging.js +18 -0
- package/dist/core/middleware/logging.js.map +1 -0
- package/dist/core/registry.d.ts +12 -0
- package/dist/core/registry.js +552 -0
- package/dist/core/registry.js.map +1 -0
- package/dist/core/registry.test.d.ts +1 -0
- package/dist/core/registry.test.js +213 -0
- package/dist/core/registry.test.js.map +1 -0
- package/dist/core/types.d.ts +38 -0
- package/dist/core/types.js +2 -0
- package/dist/core/types.js.map +1 -0
- package/dist/integration/coordination.test.d.ts +1 -0
- package/dist/integration/coordination.test.js +286 -0
- package/dist/integration/coordination.test.js.map +1 -0
- package/dist/integration/project-artifacts.test.d.ts +1 -0
- package/dist/integration/project-artifacts.test.js +275 -0
- package/dist/integration/project-artifacts.test.js.map +1 -0
- package/dist/integration/registry-graph.test.d.ts +1 -0
- package/dist/integration/registry-graph.test.js +157 -0
- package/dist/integration/registry-graph.test.js.map +1 -0
- package/dist/integration/vault-lifecycle.test.d.ts +1 -0
- package/dist/integration/vault-lifecycle.test.js +183 -0
- package/dist/integration/vault-lifecycle.test.js.map +1 -0
- package/dist/lib/auto-number.d.ts +10 -0
- package/dist/lib/auto-number.js +33 -0
- package/dist/lib/auto-number.js.map +1 -0
- package/dist/lib/auto-number.test.d.ts +1 -0
- package/dist/lib/auto-number.test.js +88 -0
- package/dist/lib/auto-number.test.js.map +1 -0
- package/dist/lib/auto-profile.d.ts +11 -0
- package/dist/lib/auto-profile.js +123 -0
- package/dist/lib/auto-profile.js.map +1 -0
- package/dist/lib/auto-profile.test.d.ts +1 -0
- package/dist/lib/auto-profile.test.js +227 -0
- package/dist/lib/auto-profile.test.js.map +1 -0
- package/dist/lib/escape-regex.d.ts +4 -0
- package/dist/lib/escape-regex.js +8 -0
- package/dist/lib/escape-regex.js.map +1 -0
- package/dist/lib/escape-regex.test.d.ts +1 -0
- package/dist/lib/escape-regex.test.js +27 -0
- package/dist/lib/escape-regex.test.js.map +1 -0
- package/dist/lib/frontmatter.d.ts +34 -0
- package/dist/lib/frontmatter.js +75 -0
- package/dist/lib/frontmatter.js.map +1 -0
- package/dist/lib/frontmatter.test.d.ts +1 -0
- package/dist/lib/frontmatter.test.js +192 -0
- package/dist/lib/frontmatter.test.js.map +1 -0
- package/dist/lib/project-detector.d.ts +12 -0
- package/dist/lib/project-detector.js +124 -0
- package/dist/lib/project-detector.js.map +1 -0
- package/dist/lib/project-detector.test.d.ts +1 -0
- package/dist/lib/project-detector.test.js +117 -0
- package/dist/lib/project-detector.test.js.map +1 -0
- package/dist/lib/safe-external-path.d.ts +10 -0
- package/dist/lib/safe-external-path.js +47 -0
- package/dist/lib/safe-external-path.js.map +1 -0
- package/dist/lib/safe-external-path.test.d.ts +1 -0
- package/dist/lib/safe-external-path.test.js +99 -0
- package/dist/lib/safe-external-path.test.js.map +1 -0
- package/dist/lib/search-engine.d.ts +19 -0
- package/dist/lib/search-engine.js +164 -0
- package/dist/lib/search-engine.js.map +1 -0
- package/dist/lib/search-engine.test.d.ts +1 -0
- package/dist/lib/search-engine.test.js +120 -0
- package/dist/lib/search-engine.test.js.map +1 -0
- package/dist/lib/session-registry.d.ts +59 -0
- package/dist/lib/session-registry.js +231 -0
- package/dist/lib/session-registry.js.map +1 -0
- package/dist/lib/session-registry.test.d.ts +1 -0
- package/dist/lib/session-registry.test.js +199 -0
- package/dist/lib/session-registry.test.js.map +1 -0
- package/dist/lib/skill-registry.d.ts +13 -0
- package/dist/lib/skill-registry.js +77 -0
- package/dist/lib/skill-registry.js.map +1 -0
- package/dist/lib/stack-detector.d.ts +7 -0
- package/dist/lib/stack-detector.js +184 -0
- package/dist/lib/stack-detector.js.map +1 -0
- package/dist/lib/stack-detector.test.d.ts +1 -0
- package/dist/lib/stack-detector.test.js +110 -0
- package/dist/lib/stack-detector.test.js.map +1 -0
- package/dist/lib/token-estimator.d.ts +19 -0
- package/dist/lib/token-estimator.js +59 -0
- package/dist/lib/token-estimator.js.map +1 -0
- package/dist/lib/token-estimator.test.d.ts +1 -0
- package/dist/lib/token-estimator.test.js +65 -0
- package/dist/lib/token-estimator.test.js.map +1 -0
- package/dist/lib/tool-detector.d.ts +8 -0
- package/dist/lib/tool-detector.js +76 -0
- package/dist/lib/tool-detector.js.map +1 -0
- package/dist/lib/tool-detector.test.d.ts +1 -0
- package/dist/lib/tool-detector.test.js +170 -0
- package/dist/lib/tool-detector.test.js.map +1 -0
- package/dist/lib/vault-fs.d.ts +39 -0
- package/dist/lib/vault-fs.js +184 -0
- package/dist/lib/vault-fs.js.map +1 -0
- package/dist/lib/vault-fs.test.d.ts +1 -0
- package/dist/lib/vault-fs.test.js +210 -0
- package/dist/lib/vault-fs.test.js.map +1 -0
- package/dist/mcp-server.d.ts +2 -0
- package/dist/mcp-server.js +387 -0
- package/dist/mcp-server.js.map +1 -0
- package/dist/setup/clients.d.ts +2 -0
- package/dist/setup/clients.js +109 -0
- package/dist/setup/clients.js.map +1 -0
- package/dist/setup/configure.d.ts +6 -0
- package/dist/setup/configure.js +126 -0
- package/dist/setup/configure.js.map +1 -0
- package/dist/setup/configure.test.d.ts +1 -0
- package/dist/setup/configure.test.js +112 -0
- package/dist/setup/configure.test.js.map +1 -0
- package/dist/setup/detect.d.ts +3 -0
- package/dist/setup/detect.js +24 -0
- package/dist/setup/detect.js.map +1 -0
- package/dist/setup/detect.test.d.ts +1 -0
- package/dist/setup/detect.test.js +44 -0
- package/dist/setup/detect.test.js.map +1 -0
- package/dist/setup/index.d.ts +2 -0
- package/dist/setup/index.js +147 -0
- package/dist/setup/index.js.map +1 -0
- package/dist/setup/instructions.d.ts +4 -0
- package/dist/setup/instructions.js +62 -0
- package/dist/setup/instructions.js.map +1 -0
- package/dist/setup/instructions.test.d.ts +1 -0
- package/dist/setup/instructions.test.js +84 -0
- package/dist/setup/instructions.test.js.map +1 -0
- package/dist/setup/json-config.d.ts +10 -0
- package/dist/setup/json-config.js +43 -0
- package/dist/setup/json-config.js.map +1 -0
- package/dist/setup/json-config.test.d.ts +1 -0
- package/dist/setup/json-config.test.js +92 -0
- package/dist/setup/json-config.test.js.map +1 -0
- package/dist/setup/postinstall.d.ts +2 -0
- package/dist/setup/postinstall.js +22 -0
- package/dist/setup/postinstall.js.map +1 -0
- package/dist/setup/preuninstall.d.ts +2 -0
- package/dist/setup/preuninstall.js +12 -0
- package/dist/setup/preuninstall.js.map +1 -0
- package/dist/setup/setup-integration.test.d.ts +1 -0
- package/dist/setup/setup-integration.test.js +72 -0
- package/dist/setup/setup-integration.test.js.map +1 -0
- package/dist/setup/teardown.d.ts +5 -0
- package/dist/setup/teardown.js +94 -0
- package/dist/setup/teardown.js.map +1 -0
- package/dist/setup/teardown.test.d.ts +1 -0
- package/dist/setup/teardown.test.js +105 -0
- package/dist/setup/teardown.test.js.map +1 -0
- package/dist/setup/toml-config.d.ts +5 -0
- package/dist/setup/toml-config.js +26 -0
- package/dist/setup/toml-config.js.map +1 -0
- package/dist/setup/toml-config.test.d.ts +1 -0
- package/dist/setup/toml-config.test.js +49 -0
- package/dist/setup/toml-config.test.js.map +1 -0
- package/dist/setup/types.d.ts +52 -0
- package/dist/setup/types.js +23 -0
- package/dist/setup/types.js.map +1 -0
- package/dist/test-helpers.d.ts +20 -0
- package/dist/test-helpers.js +47 -0
- package/dist/test-helpers.js.map +1 -0
- package/dist/test-helpers.test.d.ts +1 -0
- package/dist/test-helpers.test.js +90 -0
- package/dist/test-helpers.test.js.map +1 -0
- package/package.json +74 -0
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from "vitest";
|
|
2
|
+
import { existsSync, readFileSync, writeFileSync, unlinkSync } from "fs";
|
|
3
|
+
import { teardownClient, teardownAll } from "./teardown.js";
|
|
4
|
+
import { readJsonConfig, removeMcpEntry } from "./json-config.js";
|
|
5
|
+
import { removeTomlBlock } from "./toml-config.js";
|
|
6
|
+
import { removeMarkdownInstruction, removeMdcInstruction } from "./instructions.js";
|
|
7
|
+
import { CLIENT_REGISTRY } from "./clients.js";
|
|
8
|
+
vi.mock("./json-config.js");
|
|
9
|
+
vi.mock("./toml-config.js");
|
|
10
|
+
vi.mock("./instructions.js");
|
|
11
|
+
vi.mock("./detect.js", () => ({
|
|
12
|
+
detectClient: vi.fn().mockReturnValue(null),
|
|
13
|
+
}));
|
|
14
|
+
vi.mock("fs", () => ({
|
|
15
|
+
existsSync: vi.fn(),
|
|
16
|
+
readFileSync: vi.fn(),
|
|
17
|
+
writeFileSync: vi.fn(),
|
|
18
|
+
unlinkSync: vi.fn(),
|
|
19
|
+
}));
|
|
20
|
+
const mockExists = vi.mocked(existsSync);
|
|
21
|
+
beforeEach(() => vi.resetAllMocks());
|
|
22
|
+
function makeDetected(slug) {
|
|
23
|
+
const config = CLIENT_REGISTRY.find((c) => c.slug === slug);
|
|
24
|
+
return {
|
|
25
|
+
config,
|
|
26
|
+
mcpConfigPath: `/home/${slug}/config`,
|
|
27
|
+
instructionPath: `/home/${slug}/instruction`,
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
describe("teardownClient", () => {
|
|
31
|
+
it("removes JSON MCP entry and markdown instruction", () => {
|
|
32
|
+
mockExists.mockReturnValue(true);
|
|
33
|
+
vi.mocked(readJsonConfig).mockReturnValue({
|
|
34
|
+
mcpServers: { "superskill": { command: "npx" } },
|
|
35
|
+
});
|
|
36
|
+
vi.mocked(removeMcpEntry).mockReturnValue({
|
|
37
|
+
config: { mcpServers: {} },
|
|
38
|
+
removed: true,
|
|
39
|
+
});
|
|
40
|
+
vi.mocked(removeMarkdownInstruction).mockReturnValue(true);
|
|
41
|
+
const result = teardownClient(makeDetected("claude-code"));
|
|
42
|
+
expect(result.client).toBe("Claude Code");
|
|
43
|
+
expect(result.mcpRemoved).toBe(true);
|
|
44
|
+
expect(result.instructionRemoved).toBe(true);
|
|
45
|
+
});
|
|
46
|
+
it("handles missing config file gracefully", () => {
|
|
47
|
+
mockExists.mockReturnValue(false);
|
|
48
|
+
vi.mocked(removeMarkdownInstruction).mockReturnValue(false);
|
|
49
|
+
const result = teardownClient(makeDetected("claude-code"));
|
|
50
|
+
expect(result.mcpRemoved).toBe(false);
|
|
51
|
+
});
|
|
52
|
+
it("reports nothing removed when entry not found", () => {
|
|
53
|
+
mockExists.mockReturnValue(true);
|
|
54
|
+
vi.mocked(readJsonConfig).mockReturnValue({ mcpServers: {} });
|
|
55
|
+
vi.mocked(removeMcpEntry).mockReturnValue({ config: { mcpServers: {} }, removed: false });
|
|
56
|
+
vi.mocked(removeMarkdownInstruction).mockReturnValue(false);
|
|
57
|
+
const result = teardownClient(makeDetected("claude-code"));
|
|
58
|
+
expect(result.mcpRemoved).toBe(false);
|
|
59
|
+
expect(result.instructionRemoved).toBe(false);
|
|
60
|
+
});
|
|
61
|
+
it("handles dry run", () => {
|
|
62
|
+
const result = teardownClient(makeDetected("claude-code"), { dryRun: true });
|
|
63
|
+
expect(result.mcpRemoved).toBe(true);
|
|
64
|
+
expect(result.instructionRemoved).toBe(true);
|
|
65
|
+
});
|
|
66
|
+
it("removes TOML MCP entry (Codex)", () => {
|
|
67
|
+
mockExists.mockReturnValue(true);
|
|
68
|
+
vi.mocked(readFileSync).mockReturnValue("toml content");
|
|
69
|
+
vi.mocked(removeTomlBlock).mockReturnValue({ content: "clean", removed: true });
|
|
70
|
+
vi.mocked(removeMarkdownInstruction).mockReturnValue(true);
|
|
71
|
+
const result = teardownClient(makeDetected("codex"));
|
|
72
|
+
expect(result.mcpRemoved).toBe(true);
|
|
73
|
+
expect(writeFileSync).toHaveBeenCalled();
|
|
74
|
+
});
|
|
75
|
+
it("removes mdc instruction (Cursor)", () => {
|
|
76
|
+
mockExists.mockReturnValue(true);
|
|
77
|
+
vi.mocked(readJsonConfig).mockReturnValue({ mcpServers: {} });
|
|
78
|
+
vi.mocked(removeMcpEntry).mockReturnValue({ config: {}, removed: false });
|
|
79
|
+
vi.mocked(removeMdcInstruction).mockReturnValue(true);
|
|
80
|
+
const result = teardownClient(makeDetected("cursor"));
|
|
81
|
+
expect(result.instructionRemoved).toBe(true);
|
|
82
|
+
});
|
|
83
|
+
it("removes config-array instruction (OpenCode)", () => {
|
|
84
|
+
mockExists.mockReturnValue(true);
|
|
85
|
+
vi.mocked(readJsonConfig).mockReturnValue({ instructions: ["/home/opencode/instruction"] });
|
|
86
|
+
vi.mocked(removeMcpEntry).mockReturnValue({ config: {}, removed: false });
|
|
87
|
+
const result = teardownClient(makeDetected("opencode"));
|
|
88
|
+
expect(result.instructionRemoved).toBe(true);
|
|
89
|
+
expect(unlinkSync).toHaveBeenCalled();
|
|
90
|
+
});
|
|
91
|
+
it("handles none instruction strategy", () => {
|
|
92
|
+
mockExists.mockReturnValue(true);
|
|
93
|
+
vi.mocked(readJsonConfig).mockReturnValue({});
|
|
94
|
+
vi.mocked(removeMcpEntry).mockReturnValue({ config: {}, removed: false });
|
|
95
|
+
const result = teardownClient(makeDetected("claude-desktop"));
|
|
96
|
+
expect(result.instructionRemoved).toBe(false);
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
describe("teardownAll", () => {
|
|
100
|
+
it("returns empty array when no clients detected", async () => {
|
|
101
|
+
const results = await teardownAll();
|
|
102
|
+
expect(results).toEqual([]);
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
//# sourceMappingURL=teardown.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"teardown.test.js","sourceRoot":"","sources":["../../src/setup/teardown.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-or-later OR Commercial
|
|
2
|
+
import { MARKER_START_TOML, MARKER_END_TOML } from "./types.js";
|
|
3
|
+
export function insertTomlBlock(content, block, force = false) {
|
|
4
|
+
const hasBlock = content.includes(MARKER_START_TOML) && content.includes(MARKER_END_TOML);
|
|
5
|
+
if (hasBlock && !force)
|
|
6
|
+
return null;
|
|
7
|
+
let base = content;
|
|
8
|
+
if (hasBlock && force) {
|
|
9
|
+
base = removeTomlBlock(content).content;
|
|
10
|
+
}
|
|
11
|
+
const trimmed = base.trimEnd();
|
|
12
|
+
const separator = trimmed.length > 0 ? "\n\n" : "";
|
|
13
|
+
return `${trimmed}${separator}${MARKER_START_TOML}\n${block}\n${MARKER_END_TOML}\n`;
|
|
14
|
+
}
|
|
15
|
+
export function removeTomlBlock(content) {
|
|
16
|
+
const regex = new RegExp(`\\n?${escapeRegex(MARKER_START_TOML)}[\\s\\S]*?${escapeRegex(MARKER_END_TOML)}\\n?`, "g");
|
|
17
|
+
const result = content.replace(regex, "\n");
|
|
18
|
+
return {
|
|
19
|
+
content: result.replace(/\n{3,}/g, "\n\n").trimEnd() + "\n",
|
|
20
|
+
removed: result !== content,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
function escapeRegex(s) {
|
|
24
|
+
return s.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=toml-config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toml-config.js","sourceRoot":"","sources":["../../src/setup/toml-config.ts"],"names":[],"mappings":"AAAA,2DAA2D;AAC3D,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAEhE,MAAM,UAAU,eAAe,CAC7B,OAAe,EACf,KAAa,EACb,KAAK,GAAG,KAAK;IAEb,MAAM,QAAQ,GACZ,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;IAE3E,IAAI,QAAQ,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IAEpC,IAAI,IAAI,GAAG,OAAO,CAAC;IACnB,IAAI,QAAQ,IAAI,KAAK,EAAE,CAAC;QACtB,IAAI,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC;IAC1C,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC/B,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;IACnD,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,iBAAiB,KAAK,KAAK,KAAK,eAAe,IAAI,CAAC;AACtF,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,OAAe;IAI7C,MAAM,KAAK,GAAG,IAAI,MAAM,CACtB,OAAO,WAAW,CAAC,iBAAiB,CAAC,aAAa,WAAW,CAAC,eAAe,CAAC,MAAM,EACpF,GAAG,CACJ,CAAC;IACF,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC5C,OAAO;QACL,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI;QAC3D,OAAO,EAAE,MAAM,KAAK,OAAO;KAC5B,CAAC;AACJ,CAAC;AAED,SAAS,WAAW,CAAC,CAAS;IAC5B,OAAO,CAAC,CAAC,OAAO,CAAC,qBAAqB,EAAE,MAAM,CAAC,CAAC;AAClD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { insertTomlBlock, removeTomlBlock } from "./toml-config.js";
|
|
3
|
+
const BLOCK = `[mcp_servers.superskill]
|
|
4
|
+
command = "npx"
|
|
5
|
+
args = ["-y", "superskill"]
|
|
6
|
+
|
|
7
|
+
[mcp_servers.superskill.env]
|
|
8
|
+
VAULT_PATH = "~/Vaults/ai"`;
|
|
9
|
+
describe("insertTomlBlock", () => {
|
|
10
|
+
it("appends block with markers to empty content", () => {
|
|
11
|
+
const result = insertTomlBlock("", BLOCK);
|
|
12
|
+
expect(result).toContain("# superskill:start");
|
|
13
|
+
expect(result).toContain("# superskill:end");
|
|
14
|
+
expect(result).toContain('[mcp_servers.superskill]');
|
|
15
|
+
});
|
|
16
|
+
it("appends block to existing content", () => {
|
|
17
|
+
const existing = '[other]\nkey = "value"\n';
|
|
18
|
+
const result = insertTomlBlock(existing, BLOCK);
|
|
19
|
+
expect(result).toContain('[other]');
|
|
20
|
+
expect(result).toContain("# superskill:start");
|
|
21
|
+
});
|
|
22
|
+
it("returns null if block already exists (no force)", () => {
|
|
23
|
+
const existing = "# superskill:start\nold block\n# superskill:end\n";
|
|
24
|
+
expect(insertTomlBlock(existing, BLOCK, false)).toBeNull();
|
|
25
|
+
});
|
|
26
|
+
it("replaces existing block when force=true", () => {
|
|
27
|
+
const existing = "# superskill:start\nold block\n# superskill:end\n";
|
|
28
|
+
const result = insertTomlBlock(existing, BLOCK, true);
|
|
29
|
+
expect(result).not.toBeNull();
|
|
30
|
+
expect(result).not.toContain("old block");
|
|
31
|
+
expect(result).toContain('[mcp_servers.superskill]');
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
describe("removeTomlBlock", () => {
|
|
35
|
+
it("removes block between markers", () => {
|
|
36
|
+
const content = `[other]\nkey = "value"\n\n# superskill:start\n${BLOCK}\n# superskill:end\n`;
|
|
37
|
+
const result = removeTomlBlock(content);
|
|
38
|
+
expect(result.content).not.toContain("superskill");
|
|
39
|
+
expect(result.content).toContain('[other]');
|
|
40
|
+
expect(result.removed).toBe(true);
|
|
41
|
+
});
|
|
42
|
+
it("returns removed=false when no markers found", () => {
|
|
43
|
+
const content = '[other]\nkey = "value"\n';
|
|
44
|
+
const result = removeTomlBlock(content);
|
|
45
|
+
expect(result.removed).toBe(false);
|
|
46
|
+
expect(result.content).toBe(content);
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=toml-config.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toml-config.test.js","sourceRoot":"","sources":["../../src/setup/toml-config.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEpE,MAAM,KAAK,GAAG;;;;;2BAKa,CAAC;AAE5B,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,eAAe,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,QAAQ,GAAG,0BAA0B,CAAC;QAC5C,MAAM,MAAM,GAAG,eAAe,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,QAAQ,GAAG,mDAAmD,CAAC;QACrE,MAAM,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,QAAQ,GAAG,mDAAmD,CAAC;QACrE,MAAM,MAAM,GAAG,eAAe,CAAC,QAAQ,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACtD,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAC1C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,OAAO,GAAG,iDAAiD,KAAK,sBAAsB,CAAC;QAC7F,MAAM,MAAM,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACnD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC5C,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,OAAO,GAAG,0BAA0B,CAAC;QAC3C,MAAM,MAAM,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
export type Platform = "darwin" | "linux" | "win32";
|
|
2
|
+
export type InstructionStrategy = "markdown-file" | "mdc-file" | "config-array" | "none";
|
|
3
|
+
export interface ClientConfig {
|
|
4
|
+
name: string;
|
|
5
|
+
slug: string;
|
|
6
|
+
mcpConfigPaths: Record<Platform, string>;
|
|
7
|
+
configFormat: "json" | "toml";
|
|
8
|
+
rootKey: string;
|
|
9
|
+
commandType: "string" | "array";
|
|
10
|
+
envKey: string;
|
|
11
|
+
extraFields?: Record<string, unknown>;
|
|
12
|
+
instructionStrategy: InstructionStrategy;
|
|
13
|
+
instructionPaths?: Record<Platform, string>;
|
|
14
|
+
verified: boolean;
|
|
15
|
+
}
|
|
16
|
+
export interface DetectedClient {
|
|
17
|
+
config: ClientConfig;
|
|
18
|
+
mcpConfigPath: string;
|
|
19
|
+
instructionPath?: string;
|
|
20
|
+
}
|
|
21
|
+
export interface SetupOptions {
|
|
22
|
+
all?: boolean;
|
|
23
|
+
clients?: string[];
|
|
24
|
+
dryRun?: boolean;
|
|
25
|
+
force?: boolean;
|
|
26
|
+
vaultPath?: string;
|
|
27
|
+
}
|
|
28
|
+
export interface TeardownOptions {
|
|
29
|
+
clients?: string[];
|
|
30
|
+
dryRun?: boolean;
|
|
31
|
+
silent?: boolean;
|
|
32
|
+
}
|
|
33
|
+
export interface SetupResult {
|
|
34
|
+
client: string;
|
|
35
|
+
mcpConfigured: boolean;
|
|
36
|
+
instructionConfigured: boolean;
|
|
37
|
+
skipped?: string;
|
|
38
|
+
error?: string;
|
|
39
|
+
}
|
|
40
|
+
export interface TeardownResult {
|
|
41
|
+
client: string;
|
|
42
|
+
mcpRemoved: boolean;
|
|
43
|
+
instructionRemoved: boolean;
|
|
44
|
+
error?: string;
|
|
45
|
+
}
|
|
46
|
+
export declare const INSTRUCTION_TEXT = "You have a SuperSkill knowledge base available via MCP (superskill).\nAlways check it at the start of every session:\n1. Use vault_project_context to load context for the current project\n2. Use vault_search to find relevant decisions, learnings, and tasks\n3. Use vault_session to register your session for coordination\nTreat the vault as your persistent memory across sessions.";
|
|
47
|
+
export declare const MARKER_START_HTML = "<!-- superskill:start -->";
|
|
48
|
+
export declare const MARKER_END_HTML = "<!-- superskill:end -->";
|
|
49
|
+
export declare const MARKER_START_TOML = "# superskill:start";
|
|
50
|
+
export declare const MARKER_END_TOML = "# superskill:end";
|
|
51
|
+
export declare function resolveHome(p: string): string;
|
|
52
|
+
export declare function currentPlatform(): Platform;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-or-later OR Commercial
|
|
2
|
+
import { platform, homedir } from "os";
|
|
3
|
+
import { join } from "path";
|
|
4
|
+
export const INSTRUCTION_TEXT = `You have a SuperSkill knowledge base available via MCP (superskill).
|
|
5
|
+
Always check it at the start of every session:
|
|
6
|
+
1. Use vault_project_context to load context for the current project
|
|
7
|
+
2. Use vault_search to find relevant decisions, learnings, and tasks
|
|
8
|
+
3. Use vault_session to register your session for coordination
|
|
9
|
+
Treat the vault as your persistent memory across sessions.`;
|
|
10
|
+
export const MARKER_START_HTML = "<!-- superskill:start -->";
|
|
11
|
+
export const MARKER_END_HTML = "<!-- superskill:end -->";
|
|
12
|
+
export const MARKER_START_TOML = "# superskill:start";
|
|
13
|
+
export const MARKER_END_TOML = "# superskill:end";
|
|
14
|
+
export function resolveHome(p) {
|
|
15
|
+
return p.startsWith("~") ? join(homedir(), p.slice(1)) : p;
|
|
16
|
+
}
|
|
17
|
+
export function currentPlatform() {
|
|
18
|
+
const p = platform();
|
|
19
|
+
if (p === "darwin" || p === "linux" || p === "win32")
|
|
20
|
+
return p;
|
|
21
|
+
return "linux";
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/setup/types.ts"],"names":[],"mappings":"AAAA,2DAA2D;AAC3D,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,IAAI,CAAC;AACvC,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AA2D5B,MAAM,CAAC,MAAM,gBAAgB,GAAG;;;;;2DAK2B,CAAC;AAE5D,MAAM,CAAC,MAAM,iBAAiB,GAAG,2BAA2B,CAAC;AAC7D,MAAM,CAAC,MAAM,eAAe,GAAG,yBAAyB,CAAC;AACzD,MAAM,CAAC,MAAM,iBAAiB,GAAG,oBAAoB,CAAC;AACtD,MAAM,CAAC,MAAM,eAAe,GAAG,kBAAkB,CAAC;AAElD,MAAM,UAAU,WAAW,CAAC,CAAS;IACnC,OAAO,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC7D,CAAC;AAED,MAAM,UAAU,eAAe;IAC7B,MAAM,CAAC,GAAG,QAAQ,EAAE,CAAC;IACrB,IAAI,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,OAAO,IAAI,CAAC,KAAK,OAAO;QAAE,OAAO,CAAC,CAAC;IAC/D,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { VaultFS } from "./lib/vault-fs.js";
|
|
2
|
+
import type { CommandContext } from "./core/types.js";
|
|
3
|
+
export declare function createTestVault(options?: {
|
|
4
|
+
project?: string;
|
|
5
|
+
setupProject?: boolean;
|
|
6
|
+
}): Promise<{
|
|
7
|
+
vaultRoot: string;
|
|
8
|
+
vaultFs: VaultFS;
|
|
9
|
+
cleanup: () => Promise<void>;
|
|
10
|
+
}>;
|
|
11
|
+
export declare function createCommandContext(vaultFs: VaultFS, overrides?: Partial<CommandContext>): CommandContext;
|
|
12
|
+
export declare function createTestContext(options?: {
|
|
13
|
+
project?: string;
|
|
14
|
+
setupProject?: boolean;
|
|
15
|
+
}): Promise<{
|
|
16
|
+
vaultRoot: string;
|
|
17
|
+
vaultFs: VaultFS;
|
|
18
|
+
ctx: CommandContext;
|
|
19
|
+
cleanup: () => Promise<void>;
|
|
20
|
+
}>;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-or-later OR Commercial
|
|
2
|
+
import { mkdir, rm } from "fs/promises";
|
|
3
|
+
import { tmpdir } from "os";
|
|
4
|
+
import { join } from "path";
|
|
5
|
+
import { vi } from "vitest";
|
|
6
|
+
import { VaultFS } from "./lib/vault-fs.js";
|
|
7
|
+
import { SessionRegistryManager } from "./lib/session-registry.js";
|
|
8
|
+
export async function createTestVault(options) {
|
|
9
|
+
const vaultRoot = join(tmpdir(), `.vault-test-${Date.now()}-${Math.random().toString(36).slice(2)}`);
|
|
10
|
+
await mkdir(vaultRoot, { recursive: true });
|
|
11
|
+
const vaultFs = new VaultFS(vaultRoot);
|
|
12
|
+
if (options?.project || options?.setupProject) {
|
|
13
|
+
const slug = options?.project ?? "test-project";
|
|
14
|
+
const projectMap = { projects: { [slug]: "/tmp/test" } };
|
|
15
|
+
await vaultFs.write("project-map.json", JSON.stringify(projectMap, null, 2));
|
|
16
|
+
await mkdir(join(vaultRoot, `projects/${slug}`), { recursive: true });
|
|
17
|
+
}
|
|
18
|
+
const cleanup = async () => {
|
|
19
|
+
await rm(vaultRoot, { recursive: true, force: true });
|
|
20
|
+
};
|
|
21
|
+
return { vaultRoot, vaultFs, cleanup };
|
|
22
|
+
}
|
|
23
|
+
export function createCommandContext(vaultFs, overrides) {
|
|
24
|
+
return {
|
|
25
|
+
vaultFs,
|
|
26
|
+
vaultPath: vaultFs.root,
|
|
27
|
+
sessionRegistry: new SessionRegistryManager(vaultFs.root, 2),
|
|
28
|
+
config: {
|
|
29
|
+
vaultPath: vaultFs.root,
|
|
30
|
+
maxInjectTokens: 1500,
|
|
31
|
+
sessionTtlHours: 2,
|
|
32
|
+
},
|
|
33
|
+
log: {
|
|
34
|
+
debug: vi.fn(),
|
|
35
|
+
info: vi.fn(),
|
|
36
|
+
warn: vi.fn(),
|
|
37
|
+
error: vi.fn(),
|
|
38
|
+
},
|
|
39
|
+
...overrides,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export async function createTestContext(options) {
|
|
43
|
+
const { vaultRoot, vaultFs, cleanup } = await createTestVault(options);
|
|
44
|
+
const ctx = createCommandContext(vaultFs);
|
|
45
|
+
return { vaultRoot, vaultFs, ctx, cleanup };
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=test-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-helpers.js","sourceRoot":"","sources":["../src/test-helpers.ts"],"names":[],"mappings":"AAAA,2DAA2D;AAC3D,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAC;AAC5B,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAGnE,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAGrC;IACC,MAAM,SAAS,GAAG,IAAI,CACpB,MAAM,EAAE,EACR,eAAe,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CACnE,CAAC;IACF,MAAM,KAAK,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAE5C,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC;IAEvC,IAAI,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,YAAY,EAAE,CAAC;QAC9C,MAAM,IAAI,GAAG,OAAO,EAAE,OAAO,IAAI,cAAc,CAAC;QAChD,MAAM,UAAU,GAAG,EAAE,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,EAAE,CAAC;QACzD,MAAM,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7E,MAAM,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,IAAI,EAAE,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,MAAM,OAAO,GAAG,KAAK,IAAI,EAAE;QACzB,MAAM,EAAE,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACxD,CAAC,CAAC;IAEF,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;AACzC,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,OAAgB,EAChB,SAAmC;IAEnC,OAAO;QACL,OAAO;QACP,SAAS,EAAE,OAAO,CAAC,IAAI;QACvB,eAAe,EAAE,IAAI,sBAAsB,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAiD;QAC5G,MAAM,EAAE;YACN,SAAS,EAAE,OAAO,CAAC,IAAI;YACvB,eAAe,EAAE,IAAI;YACrB,eAAe,EAAE,CAAC;SACnB;QACD,GAAG,EAAE;YACH,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;YACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;YACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;YACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;SACM;QACtB,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,OAGvC;IAMC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC;IACvE,MAAM,GAAG,GAAG,oBAAoB,CAAC,OAAO,CAAC,CAAC;IAC1C,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;AAC9C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { describe, it, expect, afterEach } from "vitest";
|
|
2
|
+
import { createTestVault, createCommandContext, createTestContext } from "./test-helpers.js";
|
|
3
|
+
import { VaultFS } from "./lib/vault-fs.js";
|
|
4
|
+
describe("createTestVault", () => {
|
|
5
|
+
let cleanup;
|
|
6
|
+
afterEach(async () => {
|
|
7
|
+
if (cleanup)
|
|
8
|
+
await cleanup();
|
|
9
|
+
});
|
|
10
|
+
it("creates a vault directory and VaultFS instance", async () => {
|
|
11
|
+
const { vaultRoot, vaultFs, cleanup: c } = await createTestVault();
|
|
12
|
+
cleanup = c;
|
|
13
|
+
expect(vaultRoot).toBeDefined();
|
|
14
|
+
expect(vaultFs).toBeInstanceOf(VaultFS);
|
|
15
|
+
expect(vaultFs.root).toBe(vaultRoot);
|
|
16
|
+
});
|
|
17
|
+
it("sets up project structure when setupProject is true", async () => {
|
|
18
|
+
const { vaultRoot, vaultFs, cleanup: c } = await createTestVault({ setupProject: true });
|
|
19
|
+
cleanup = c;
|
|
20
|
+
const projectMap = JSON.parse(await vaultFs.read("project-map.json"));
|
|
21
|
+
expect(projectMap.projects["test-project"]).toBe("/tmp/test");
|
|
22
|
+
const content = await vaultFs.read("projects/test-project/context.md").catch(() => null);
|
|
23
|
+
expect(content).toBeNull();
|
|
24
|
+
});
|
|
25
|
+
it("sets up custom project when project option is provided", async () => {
|
|
26
|
+
const { vaultFs, cleanup: c } = await createTestVault({ project: "my-app" });
|
|
27
|
+
cleanup = c;
|
|
28
|
+
const projectMap = JSON.parse(await vaultFs.read("project-map.json"));
|
|
29
|
+
expect(projectMap.projects["my-app"]).toBe("/tmp/test");
|
|
30
|
+
});
|
|
31
|
+
it("cleanup removes the vault directory", async () => {
|
|
32
|
+
const { vaultRoot, vaultFs, cleanup: c } = await createTestVault();
|
|
33
|
+
await c;
|
|
34
|
+
await expect(vaultFs.read("project-map.json")).rejects.toThrow();
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
describe("createCommandContext", () => {
|
|
38
|
+
it("creates a context with all required fields", async () => {
|
|
39
|
+
const { vaultFs, cleanup } = await createTestVault();
|
|
40
|
+
try {
|
|
41
|
+
const ctx = createCommandContext(vaultFs);
|
|
42
|
+
expect(ctx.vaultFs).toBe(vaultFs);
|
|
43
|
+
expect(ctx.vaultPath).toBe(vaultFs.root);
|
|
44
|
+
expect(ctx.config.vaultPath).toBe(vaultFs.root);
|
|
45
|
+
expect(ctx.log.debug).toBeDefined();
|
|
46
|
+
expect(ctx.log.info).toBeDefined();
|
|
47
|
+
expect(ctx.log.warn).toBeDefined();
|
|
48
|
+
expect(ctx.log.error).toBeDefined();
|
|
49
|
+
}
|
|
50
|
+
finally {
|
|
51
|
+
await cleanup();
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
it("allows overriding context fields", async () => {
|
|
55
|
+
const { vaultFs, cleanup } = await createTestVault();
|
|
56
|
+
try {
|
|
57
|
+
const customLog = { debug: () => { }, info: () => { }, warn: () => { }, error: () => { } };
|
|
58
|
+
const ctx = createCommandContext(vaultFs, { log: customLog });
|
|
59
|
+
expect(ctx.log).toBe(customLog);
|
|
60
|
+
}
|
|
61
|
+
finally {
|
|
62
|
+
await cleanup();
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
describe("createTestContext", () => {
|
|
67
|
+
it("combines createTestVault and createCommandContext", async () => {
|
|
68
|
+
const { vaultRoot, vaultFs, ctx, cleanup } = await createTestContext();
|
|
69
|
+
try {
|
|
70
|
+
expect(vaultRoot).toBeDefined();
|
|
71
|
+
expect(vaultFs).toBeInstanceOf(VaultFS);
|
|
72
|
+
expect(ctx.vaultFs).toBe(vaultFs);
|
|
73
|
+
expect(ctx.vaultPath).toBe(vaultRoot);
|
|
74
|
+
}
|
|
75
|
+
finally {
|
|
76
|
+
await cleanup();
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
it("passes project option through", async () => {
|
|
80
|
+
const { vaultFs, cleanup } = await createTestContext({ project: "custom" });
|
|
81
|
+
try {
|
|
82
|
+
const projectMap = JSON.parse(await vaultFs.read("project-map.json"));
|
|
83
|
+
expect(projectMap.projects["custom"]).toBe("/tmp/test");
|
|
84
|
+
}
|
|
85
|
+
finally {
|
|
86
|
+
await cleanup();
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
//# sourceMappingURL=test-helpers.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-helpers.test.js","sourceRoot":"","sources":["../src/test-helpers.test.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "superskill",
|
|
3
|
+
"version": "0.2.0",
|
|
4
|
+
"description": "Universal agentic knowledge base + context optimizer + skill marketplace for AI tools",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/mcp-server.js",
|
|
7
|
+
"bin": {
|
|
8
|
+
"superskill": "dist/mcp-server.js",
|
|
9
|
+
"superskill-cli": "dist/cli.js"
|
|
10
|
+
},
|
|
11
|
+
"exports": {
|
|
12
|
+
".": {
|
|
13
|
+
"import": "./dist/mcp-server.js",
|
|
14
|
+
"default": "./dist/mcp-server.js"
|
|
15
|
+
},
|
|
16
|
+
"./cli": {
|
|
17
|
+
"import": "./dist/cli.js",
|
|
18
|
+
"default": "./dist/cli.js"
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
"files": [
|
|
22
|
+
"dist/",
|
|
23
|
+
"README.md",
|
|
24
|
+
"LICENSE",
|
|
25
|
+
"CHANGELOG.md"
|
|
26
|
+
],
|
|
27
|
+
"scripts": {
|
|
28
|
+
"build": "tsc",
|
|
29
|
+
"dev": "tsc --watch",
|
|
30
|
+
"start:mcp": "node dist/mcp-server.js",
|
|
31
|
+
"start:cli": "node dist/cli.js",
|
|
32
|
+
"test": "vitest run",
|
|
33
|
+
"test:coverage": "vitest run --coverage",
|
|
34
|
+
"test:watch": "vitest watch",
|
|
35
|
+
"lint": "tsc --noEmit",
|
|
36
|
+
"prepublishOnly": "npm run build",
|
|
37
|
+
"postinstall": "node dist/setup/postinstall.js || true",
|
|
38
|
+
"preuninstall": "node dist/setup/preuninstall.js || true"
|
|
39
|
+
},
|
|
40
|
+
"dependencies": {
|
|
41
|
+
"@modelcontextprotocol/sdk": "^1.12.1",
|
|
42
|
+
"commander": "^13.1.0",
|
|
43
|
+
"gray-matter": "^4.0.3"
|
|
44
|
+
},
|
|
45
|
+
"devDependencies": {
|
|
46
|
+
"@types/node": "^22.0.0",
|
|
47
|
+
"@vitest/coverage-v8": "^3.0.0",
|
|
48
|
+
"typescript": "^5.7.0",
|
|
49
|
+
"vitest": "^3.0.0"
|
|
50
|
+
},
|
|
51
|
+
"license": "AGPL-3.0-or-later",
|
|
52
|
+
"author": "Permanu (Atharva Pandey)",
|
|
53
|
+
"repository": {
|
|
54
|
+
"type": "git",
|
|
55
|
+
"url": "https://github.com/gopherine/superskill.git"
|
|
56
|
+
},
|
|
57
|
+
"keywords": [
|
|
58
|
+
"mcp",
|
|
59
|
+
"mcp-server",
|
|
60
|
+
"superskill",
|
|
61
|
+
"knowledge-base",
|
|
62
|
+
"ai",
|
|
63
|
+
"cli",
|
|
64
|
+
"agentic",
|
|
65
|
+
"coding-agent",
|
|
66
|
+
"claude",
|
|
67
|
+
"cursor",
|
|
68
|
+
"opencode",
|
|
69
|
+
"codex"
|
|
70
|
+
],
|
|
71
|
+
"engines": {
|
|
72
|
+
"node": ">=20.0.0"
|
|
73
|
+
}
|
|
74
|
+
}
|