@lhremote/mcp 0.8.0 → 0.9.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/README.md +6 -3
- package/dist/helpers.d.ts +2 -15
- package/dist/helpers.d.ts.map +1 -1
- package/dist/helpers.js +11 -15
- package/dist/helpers.js.map +1 -1
- package/dist/tools/add-people-to-collection.test.d.ts +2 -0
- package/dist/tools/add-people-to-collection.test.d.ts.map +1 -0
- package/dist/tools/add-people-to-collection.test.js +61 -0
- package/dist/tools/add-people-to-collection.test.js.map +1 -0
- package/dist/tools/check-replies.d.ts.map +1 -1
- package/dist/tools/check-replies.js +11 -3
- package/dist/tools/check-replies.js.map +1 -1
- package/dist/tools/check-replies.test.js +10 -10
- package/dist/tools/check-replies.test.js.map +1 -1
- package/dist/tools/comment-on-post.test.d.ts +2 -0
- package/dist/tools/comment-on-post.test.d.ts.map +1 -0
- package/dist/tools/comment-on-post.test.js +64 -0
- package/dist/tools/comment-on-post.test.js.map +1 -0
- package/dist/tools/create-collection.test.d.ts +2 -0
- package/dist/tools/create-collection.test.d.ts.map +1 -0
- package/dist/tools/create-collection.test.js +55 -0
- package/dist/tools/create-collection.test.js.map +1 -0
- package/dist/tools/delete-collection.test.d.ts +2 -0
- package/dist/tools/delete-collection.test.d.ts.map +1 -0
- package/dist/tools/delete-collection.test.js +55 -0
- package/dist/tools/delete-collection.test.js.map +1 -0
- package/dist/tools/find-app.test.js +1 -1
- package/dist/tools/find-app.test.js.map +1 -1
- package/dist/tools/get-feed.test.js +0 -1
- package/dist/tools/get-feed.test.js.map +1 -1
- package/dist/tools/get-post.d.ts.map +1 -1
- package/dist/tools/get-post.js +4 -12
- package/dist/tools/get-post.js.map +1 -1
- package/dist/tools/get-post.test.d.ts +2 -0
- package/dist/tools/get-post.test.d.ts.map +1 -0
- package/dist/tools/get-post.test.js +90 -0
- package/dist/tools/get-post.test.js.map +1 -0
- package/dist/tools/get-profile-activity.d.ts.map +1 -1
- package/dist/tools/get-profile-activity.js +9 -12
- package/dist/tools/get-profile-activity.js.map +1 -1
- package/dist/tools/get-profile-activity.test.js +4 -5
- package/dist/tools/get-profile-activity.test.js.map +1 -1
- package/dist/tools/import-people-from-collection.test.d.ts +2 -0
- package/dist/tools/import-people-from-collection.test.d.ts.map +1 -0
- package/dist/tools/import-people-from-collection.test.js +86 -0
- package/dist/tools/import-people-from-collection.test.js.map +1 -0
- package/dist/tools/list-accounts.d.ts.map +1 -1
- package/dist/tools/list-accounts.js +19 -13
- package/dist/tools/list-accounts.js.map +1 -1
- package/dist/tools/list-collections.test.d.ts +2 -0
- package/dist/tools/list-collections.test.d.ts.map +1 -0
- package/dist/tools/list-collections.test.js +56 -0
- package/dist/tools/list-collections.test.js.map +1 -0
- package/dist/tools/react-to-post.test.d.ts +2 -0
- package/dist/tools/react-to-post.test.d.ts.map +1 -0
- package/dist/tools/react-to-post.test.js +64 -0
- package/dist/tools/react-to-post.test.js.map +1 -0
- package/dist/tools/remove-people-from-collection.test.d.ts +2 -0
- package/dist/tools/remove-people-from-collection.test.d.ts.map +1 -0
- package/dist/tools/remove-people-from-collection.test.js +60 -0
- package/dist/tools/remove-people-from-collection.test.js.map +1 -0
- package/dist/tools/scrape-messaging-history.d.ts.map +1 -1
- package/dist/tools/scrape-messaging-history.js +6 -2
- package/dist/tools/scrape-messaging-history.js.map +1 -1
- package/dist/tools/search-posts.d.ts.map +1 -1
- package/dist/tools/search-posts.js +9 -10
- package/dist/tools/search-posts.js.map +1 -1
- package/dist/tools/search-posts.test.js +12 -8
- package/dist/tools/search-posts.test.js.map +1 -1
- package/dist/tools/start-instance.d.ts.map +1 -1
- package/dist/tools/start-instance.js +32 -26
- package/dist/tools/start-instance.js.map +1 -1
- package/dist/tools/stop-instance.d.ts.map +1 -1
- package/dist/tools/stop-instance.js +28 -22
- package/dist/tools/stop-instance.js.map +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
MCP server for [lhremote](https://github.com/alexey-pelykh/lhremote) — LinkedHelper automation toolkit.
|
|
4
4
|
|
|
5
|
-
This package exposes the full LinkedHelper automation surface as a [Model Context Protocol](https://modelcontextprotocol.io) server. AI assistants (Claude, etc.) connect over stdio and use the
|
|
5
|
+
This package exposes the full LinkedHelper automation surface as a [Model Context Protocol](https://modelcontextprotocol.io) server. AI assistants (Claude, etc.) connect over stdio and use the 68 registered tools to control LinkedHelper.
|
|
6
6
|
|
|
7
7
|
Built on [`@lhremote/core`](../core).
|
|
8
8
|
|
|
@@ -50,13 +50,16 @@ await runStdioServer();
|
|
|
50
50
|
|----------|-------|
|
|
51
51
|
| App Management | `find-app`, `launch-app`, `quit-app` |
|
|
52
52
|
| Account & Instance | `list-accounts`, `start-instance`, `stop-instance`, `check-status` |
|
|
53
|
-
| Campaigns | `campaign-list`, `campaign-create`, `campaign-get`, `campaign-export`, `campaign-update`, `campaign-delete`, `campaign-start`, `campaign-stop` |
|
|
53
|
+
| Campaigns | `campaign-list`, `campaign-create`, `campaign-get`, `campaign-export`, `campaign-update`, `campaign-delete`, `campaign-erase`, `campaign-start`, `campaign-stop` |
|
|
54
54
|
| Campaign Status | `campaign-status`, `campaign-statistics`, `campaign-retry` |
|
|
55
55
|
| Campaign Actions | `campaign-add-action`, `campaign-remove-action`, `campaign-update-action`, `campaign-reorder-actions`, `campaign-move-next` |
|
|
56
56
|
| Campaign Targeting | `campaign-exclude-list`, `campaign-exclude-add`, `campaign-exclude-remove`, `campaign-list-people`, `campaign-remove-people`, `import-people-from-urls`, `collect-people` |
|
|
57
57
|
| Collections | `list-collections`, `create-collection`, `delete-collection`, `add-people-to-collection`, `remove-people-from-collection`, `import-people-from-collection` |
|
|
58
|
+
| LinkedIn Actions | `visit-profile`, `endorse-skills`, `enrich-profile`, `follow-person`, `like-person-posts`, `message-person`, `send-invite`, `send-inmail`, `remove-connection` |
|
|
59
|
+
| Feed & Posts | `get-feed`, `get-post`, `get-post-stats`, `get-post-engagers`, `get-profile-activity`, `search-posts`, `comment-on-post`, `react-to-post` |
|
|
60
|
+
| LinkedIn Search & Reference | `build-linkedin-url`, `resolve-linkedin-entity`, `list-linkedin-reference-data` |
|
|
58
61
|
| Profiles & Messaging | `query-profile`, `query-profiles`, `query-profiles-bulk`, `query-messages`, `check-replies`, `scrape-messaging-history` |
|
|
59
|
-
| Utilities | `describe-actions`, `get-errors` |
|
|
62
|
+
| Utilities | `describe-actions`, `get-errors`, `dismiss-errors`, `get-action-budget`, `get-throttle-status` |
|
|
60
63
|
|
|
61
64
|
See the [root README](https://github.com/alexey-pelykh/lhremote#mcp-tools) for parameter details on each tool.
|
|
62
65
|
|
package/dist/helpers.d.ts
CHANGED
|
@@ -16,23 +16,11 @@ type McpResult = {
|
|
|
16
16
|
* ```
|
|
17
17
|
*/
|
|
18
18
|
export declare const cdpConnectionSchema: {
|
|
19
|
-
cdpPort: z.
|
|
19
|
+
cdpPort: z.ZodOptional<z.ZodNumber>;
|
|
20
20
|
cdpHost: z.ZodOptional<z.ZodString>;
|
|
21
21
|
allowRemote: z.ZodOptional<z.ZodBoolean>;
|
|
22
22
|
};
|
|
23
|
-
|
|
24
|
-
* Build the CDP connection options object from parsed tool arguments.
|
|
25
|
-
*
|
|
26
|
-
* Replaces the inline conditional-spread pattern used by tools that
|
|
27
|
-
* call `resolveAccount` or construct a `LauncherService`.
|
|
28
|
-
*/
|
|
29
|
-
export declare function buildCdpOptions(args: {
|
|
30
|
-
cdpHost?: string | undefined;
|
|
31
|
-
allowRemote?: boolean | undefined;
|
|
32
|
-
}): {
|
|
33
|
-
host?: string;
|
|
34
|
-
allowRemote?: boolean;
|
|
35
|
-
};
|
|
23
|
+
export { buildCdpOptions } from "@lhremote/core";
|
|
36
24
|
/**
|
|
37
25
|
* Build an MCP error response from a plain message string.
|
|
38
26
|
*/
|
|
@@ -55,5 +43,4 @@ export declare function mapErrorToMcpResponse(error: unknown): McpResult | undef
|
|
|
55
43
|
* contextual prefix (e.g. "Failed to create campaign").
|
|
56
44
|
*/
|
|
57
45
|
export declare function mcpCatchAll(error: unknown, prefix: string): McpResult;
|
|
58
|
-
export {};
|
|
59
46
|
//# sourceMappingURL=helpers.d.ts.map
|
package/dist/helpers.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,KAAK,WAAW,GAAG;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC;AAClD,KAAK,SAAS,GAAG;IAAE,OAAO,CAAC,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,WAAW,EAAE,CAAA;CAAE,CAAC;AAE/D;;;;;;;GAOG;AACH,eAAO,MAAM,mBAAmB;;;;CAe/B,CAAC;AAGF,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD;;GAEG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAKhD;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAIlD;AAED;;;;;;;GAOG;AACH,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,SAAS,CAuC3E;AAED;;;GAGG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,GAAG,SAAS,CAMrE"}
|
package/dist/helpers.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
2
|
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
-
import { AccountResolutionError, BudgetExceededError, CampaignNotFoundError,
|
|
3
|
+
import { AccountResolutionError, BudgetExceededError, CampaignNotFoundError, errorMessage, LinkedHelperNotRunningError, LinkedHelperUnreachableError, UIBlockedError, } from "@lhremote/core";
|
|
4
4
|
import { z } from "zod";
|
|
5
5
|
/**
|
|
6
6
|
* Shared Zod schema fields for CDP connection parameters.
|
|
@@ -16,8 +16,7 @@ export const cdpConnectionSchema = {
|
|
|
16
16
|
.int()
|
|
17
17
|
.positive()
|
|
18
18
|
.optional()
|
|
19
|
-
.
|
|
20
|
-
.describe("CDP port"),
|
|
19
|
+
.describe("CDP port (auto-discovered from running LinkedHelper processes when omitted)"),
|
|
21
20
|
cdpHost: z
|
|
22
21
|
.string()
|
|
23
22
|
.optional()
|
|
@@ -27,18 +26,8 @@ export const cdpConnectionSchema = {
|
|
|
27
26
|
.optional()
|
|
28
27
|
.describe("SECURITY: Allow non-loopback CDP connections. Enables remote code execution on target host. Only use if network path is secured."),
|
|
29
28
|
};
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
*
|
|
33
|
-
* Replaces the inline conditional-spread pattern used by tools that
|
|
34
|
-
* call `resolveAccount` or construct a `LauncherService`.
|
|
35
|
-
*/
|
|
36
|
-
export function buildCdpOptions(args) {
|
|
37
|
-
return {
|
|
38
|
-
...(args.cdpHost !== undefined && { host: args.cdpHost }),
|
|
39
|
-
...(args.allowRemote !== undefined && { allowRemote: args.allowRemote }),
|
|
40
|
-
};
|
|
41
|
-
}
|
|
29
|
+
// Re-export from core so existing MCP tool files keep working.
|
|
30
|
+
export { buildCdpOptions } from "@lhremote/core";
|
|
42
31
|
/**
|
|
43
32
|
* Build an MCP error response from a plain message string.
|
|
44
33
|
*/
|
|
@@ -67,6 +56,13 @@ export function mcpSuccess(text) {
|
|
|
67
56
|
export function mapErrorToMcpResponse(error) {
|
|
68
57
|
if (error instanceof LinkedHelperUnreachableError) {
|
|
69
58
|
const pids = error.processes.map((p) => String(p.pid)).join(", ");
|
|
59
|
+
const connectableInstances = error.processes.filter((p) => p.role === "instance" && p.connectable && p.cdpPort !== null);
|
|
60
|
+
if (connectableInstances.length > 0) {
|
|
61
|
+
return mcpError(`Launcher CDP not available (PID ${pids}). ` +
|
|
62
|
+
"Instance(s) detected — instance-level operations work, " +
|
|
63
|
+
"but launcher operations (list-accounts, start/stop-instance) are unavailable. " +
|
|
64
|
+
"Relaunch LinkedHelper with --remote-debugging-port or use launch-app.");
|
|
65
|
+
}
|
|
70
66
|
return mcpError(`LinkedHelper is running (PID ${pids}) but CDP is not reachable. ` +
|
|
71
67
|
"Restart LinkedHelper or use launch-app with force: true.");
|
|
72
68
|
}
|
package/dist/helpers.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EACL,sBAAsB,EACtB,mBAAmB,EACnB,qBAAqB,EACrB,
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-people-to-collection.test.d.ts","sourceRoot":"","sources":["../../src/tools/add-people-to-collection.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
vi.mock("@lhremote/core", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return { ...actual, addPeopleToCollection: vi.fn() };
|
|
7
|
+
});
|
|
8
|
+
import { addPeopleToCollection } from "@lhremote/core";
|
|
9
|
+
import { registerAddPeopleToCollection } from "./add-people-to-collection.js";
|
|
10
|
+
import { describeInfrastructureErrors } from "./testing/infrastructure-errors.js";
|
|
11
|
+
import { createMockServer } from "./testing/mock-server.js";
|
|
12
|
+
const MOCK_RESULT = {
|
|
13
|
+
success: true,
|
|
14
|
+
collectionId: 1,
|
|
15
|
+
added: 2,
|
|
16
|
+
alreadyInCollection: 0,
|
|
17
|
+
};
|
|
18
|
+
describe("registerAddPeopleToCollection", () => {
|
|
19
|
+
beforeEach(() => {
|
|
20
|
+
vi.clearAllMocks();
|
|
21
|
+
});
|
|
22
|
+
afterEach(() => {
|
|
23
|
+
vi.restoreAllMocks();
|
|
24
|
+
});
|
|
25
|
+
it("registers a tool named add-people-to-collection", () => {
|
|
26
|
+
const { server } = createMockServer();
|
|
27
|
+
registerAddPeopleToCollection(server);
|
|
28
|
+
expect(server.tool).toHaveBeenCalledOnce();
|
|
29
|
+
expect(server.tool).toHaveBeenCalledWith("add-people-to-collection", expect.any(String), expect.any(Object), expect.any(Function));
|
|
30
|
+
});
|
|
31
|
+
it("returns result as JSON on success", async () => {
|
|
32
|
+
const { server, getHandler } = createMockServer();
|
|
33
|
+
registerAddPeopleToCollection(server);
|
|
34
|
+
vi.mocked(addPeopleToCollection).mockResolvedValue(MOCK_RESULT);
|
|
35
|
+
const handler = getHandler("add-people-to-collection");
|
|
36
|
+
const result = await handler({
|
|
37
|
+
collectionId: 1,
|
|
38
|
+
personIds: [100, 200],
|
|
39
|
+
cdpPort: 9222,
|
|
40
|
+
});
|
|
41
|
+
expect(result).toEqual({
|
|
42
|
+
content: [{ type: "text", text: JSON.stringify(MOCK_RESULT, null, 2) }],
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
it("returns error on failure", async () => {
|
|
46
|
+
const { server, getHandler } = createMockServer();
|
|
47
|
+
registerAddPeopleToCollection(server);
|
|
48
|
+
vi.mocked(addPeopleToCollection).mockRejectedValue(new Error("connection refused"));
|
|
49
|
+
const handler = getHandler("add-people-to-collection");
|
|
50
|
+
const result = (await handler({
|
|
51
|
+
collectionId: 1,
|
|
52
|
+
personIds: [100, 200],
|
|
53
|
+
cdpPort: 9222,
|
|
54
|
+
}));
|
|
55
|
+
expect(result.isError).toBe(true);
|
|
56
|
+
const text = result.content[0].text;
|
|
57
|
+
expect(text).toContain("Failed to add people to collection");
|
|
58
|
+
});
|
|
59
|
+
describeInfrastructureErrors(registerAddPeopleToCollection, "add-people-to-collection", () => ({ collectionId: 1, personIds: [100, 200], cdpPort: 9222 }), (error) => vi.mocked(addPeopleToCollection).mockRejectedValue(error), "Failed to add people to collection");
|
|
60
|
+
});
|
|
61
|
+
//# sourceMappingURL=add-people-to-collection.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-people-to-collection.test.js","sourceRoot":"","sources":["../../src/tools/add-people-to-collection.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-replies.d.ts","sourceRoot":"","sources":["../../src/tools/check-replies.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAOzE,6GAA6G;AAC7G,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"check-replies.d.ts","sourceRoot":"","sources":["../../src/tools/check-replies.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAOzE,6GAA6G;AAC7G,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAgC5D"}
|
|
@@ -5,15 +5,23 @@ import { z } from "zod";
|
|
|
5
5
|
import { cdpConnectionSchema, mcpCatchAll, mcpSuccess } from "../helpers.js";
|
|
6
6
|
/** Register the {@link https://github.com/alexey-pelykh/lhremote#check-replies | check-replies} MCP tool. */
|
|
7
7
|
export function registerCheckReplies(server) {
|
|
8
|
-
server.tool("check-replies", "Trigger LinkedHelper to check for new message replies on LinkedIn, then return any new messages found. If `since` is omitted, returns messages from the last 24 hours.", {
|
|
8
|
+
server.tool("check-replies", "Trigger LinkedHelper to check for new message replies on LinkedIn for the specified people, then return any new messages found. If `since` is omitted, returns messages from the last 24 hours.", {
|
|
9
|
+
personIds: z
|
|
10
|
+
.array(z.number().int().positive())
|
|
11
|
+
.nonempty()
|
|
12
|
+
.describe("Person IDs whose replies should be checked"),
|
|
9
13
|
since: z
|
|
10
14
|
.string()
|
|
11
15
|
.optional()
|
|
12
16
|
.describe("ISO timestamp; only return messages after this time. If omitted, returns messages from the last 24 hours"),
|
|
17
|
+
pauseOthers: z
|
|
18
|
+
.boolean()
|
|
19
|
+
.optional()
|
|
20
|
+
.describe("Pause all other campaigns during execution to ensure the runner is available, then restore them"),
|
|
13
21
|
...cdpConnectionSchema,
|
|
14
|
-
}, async ({ since, cdpPort, cdpHost, allowRemote }) => {
|
|
22
|
+
}, async ({ personIds, since, pauseOthers, cdpPort, cdpHost, allowRemote }) => {
|
|
15
23
|
try {
|
|
16
|
-
const result = await checkReplies({ since, cdpPort, cdpHost, allowRemote });
|
|
24
|
+
const result = await checkReplies({ personIds, since, pauseOthers, cdpPort, cdpHost, allowRemote });
|
|
17
25
|
return mcpSuccess(JSON.stringify(result, null, 2));
|
|
18
26
|
}
|
|
19
27
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-replies.js","sourceRoot":"","sources":["../../src/tools/check-replies.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EACL,YAAY,GACb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE7E,6GAA6G;AAC7G,MAAM,UAAU,oBAAoB,CAAC,MAAiB;IACpD,MAAM,CAAC,IAAI,CACT,eAAe,EACf,
|
|
1
|
+
{"version":3,"file":"check-replies.js","sourceRoot":"","sources":["../../src/tools/check-replies.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAGpC,OAAO,EACL,YAAY,GACb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE7E,6GAA6G;AAC7G,MAAM,UAAU,oBAAoB,CAAC,MAAiB;IACpD,MAAM,CAAC,IAAI,CACT,eAAe,EACf,iMAAiM,EACjM;QACE,SAAS,EAAE,CAAC;aACT,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC;aAClC,QAAQ,EAAE;aACV,QAAQ,CAAC,4CAA4C,CAAC;QACzD,KAAK,EAAE,CAAC;aACL,MAAM,EAAE;aACR,QAAQ,EAAE;aACV,QAAQ,CACP,0GAA0G,CAC3G;QACH,WAAW,EAAE,CAAC;aACX,OAAO,EAAE;aACT,QAAQ,EAAE;aACV,QAAQ,CACP,iGAAiG,CAClG;QACH,GAAG,mBAAmB;KACvB,EACD,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,EAAE,EAAE;QACzE,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC,CAAC;YACpG,OAAO,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,WAAW,CAAC,KAAK,EAAE,yBAAyB,CAAC,CAAC;QACvD,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -83,7 +83,7 @@ describe("registerCheckReplies", () => {
|
|
|
83
83
|
checkedAt: "2025-01-15T12:00:00.000Z",
|
|
84
84
|
});
|
|
85
85
|
const handler = getHandler("check-replies");
|
|
86
|
-
const result = await handler({ cdpPort: 9222 });
|
|
86
|
+
const result = await handler({ personIds: [456, 790], cdpPort: 9222 });
|
|
87
87
|
expect(result).toEqual({
|
|
88
88
|
content: [
|
|
89
89
|
{
|
|
@@ -106,8 +106,8 @@ describe("registerCheckReplies", () => {
|
|
|
106
106
|
checkedAt: "2025-01-15T12:00:00.000Z",
|
|
107
107
|
});
|
|
108
108
|
const handler = getHandler("check-replies");
|
|
109
|
-
await handler({ since: "2025-01-14T00:00:00Z", cdpPort: 9222 });
|
|
110
|
-
expect(checkReplies).toHaveBeenCalledWith(expect.objectContaining({ since: "2025-01-14T00:00:00Z", cdpPort: 9222 }));
|
|
109
|
+
await handler({ personIds: [456], since: "2025-01-14T00:00:00Z", cdpPort: 9222 });
|
|
110
|
+
expect(checkReplies).toHaveBeenCalledWith(expect.objectContaining({ personIds: [456], since: "2025-01-14T00:00:00Z", cdpPort: 9222 }));
|
|
111
111
|
});
|
|
112
112
|
it("passes since as undefined when omitted", async () => {
|
|
113
113
|
const { server, getHandler } = createMockServer();
|
|
@@ -118,8 +118,8 @@ describe("registerCheckReplies", () => {
|
|
|
118
118
|
checkedAt: "2025-01-15T12:00:00.000Z",
|
|
119
119
|
});
|
|
120
120
|
const handler = getHandler("check-replies");
|
|
121
|
-
await handler({ cdpPort: 9222 });
|
|
122
|
-
expect(checkReplies).toHaveBeenCalledWith(expect.objectContaining({ cdpPort: 9222 }));
|
|
121
|
+
await handler({ personIds: [456], cdpPort: 9222 });
|
|
122
|
+
expect(checkReplies).toHaveBeenCalledWith(expect.objectContaining({ personIds: [456], cdpPort: 9222 }));
|
|
123
123
|
});
|
|
124
124
|
it("returns empty results when no new messages", async () => {
|
|
125
125
|
const { server, getHandler } = createMockServer();
|
|
@@ -130,7 +130,7 @@ describe("registerCheckReplies", () => {
|
|
|
130
130
|
checkedAt: "2025-01-15T12:00:00.000Z",
|
|
131
131
|
});
|
|
132
132
|
const handler = getHandler("check-replies");
|
|
133
|
-
const result = await handler({ cdpPort: 9222 });
|
|
133
|
+
const result = await handler({ personIds: [456], cdpPort: 9222 });
|
|
134
134
|
expect(result).toEqual({
|
|
135
135
|
content: [
|
|
136
136
|
{
|
|
@@ -149,7 +149,7 @@ describe("registerCheckReplies", () => {
|
|
|
149
149
|
registerCheckReplies(server);
|
|
150
150
|
vi.mocked(checkReplies).mockRejectedValue(new AccountResolutionError("no-accounts"));
|
|
151
151
|
const handler = getHandler("check-replies");
|
|
152
|
-
const result = await handler({ cdpPort: 9222 });
|
|
152
|
+
const result = await handler({ personIds: [456], cdpPort: 9222 });
|
|
153
153
|
expect(result).toEqual({
|
|
154
154
|
isError: true,
|
|
155
155
|
content: [{ type: "text", text: "No accounts found." }],
|
|
@@ -160,7 +160,7 @@ describe("registerCheckReplies", () => {
|
|
|
160
160
|
registerCheckReplies(server);
|
|
161
161
|
vi.mocked(checkReplies).mockRejectedValue(new AccountResolutionError("multiple-accounts"));
|
|
162
162
|
const handler = getHandler("check-replies");
|
|
163
|
-
const result = await handler({ cdpPort: 9222 });
|
|
163
|
+
const result = await handler({ personIds: [456], cdpPort: 9222 });
|
|
164
164
|
expect(result).toEqual({
|
|
165
165
|
isError: true,
|
|
166
166
|
content: [
|
|
@@ -176,7 +176,7 @@ describe("registerCheckReplies", () => {
|
|
|
176
176
|
registerCheckReplies(server);
|
|
177
177
|
vi.mocked(checkReplies).mockRejectedValue(new Error("action timed out"));
|
|
178
178
|
const handler = getHandler("check-replies");
|
|
179
|
-
const result = await handler({ cdpPort: 9222 });
|
|
179
|
+
const result = await handler({ personIds: [456], cdpPort: 9222 });
|
|
180
180
|
expect(result).toEqual({
|
|
181
181
|
isError: true,
|
|
182
182
|
content: [
|
|
@@ -187,6 +187,6 @@ describe("registerCheckReplies", () => {
|
|
|
187
187
|
],
|
|
188
188
|
});
|
|
189
189
|
});
|
|
190
|
-
describeInfrastructureErrors(registerCheckReplies, "check-replies", () => ({ cdpPort: 9222 }), (error) => vi.mocked(checkReplies).mockRejectedValue(error), "Failed to check replies");
|
|
190
|
+
describeInfrastructureErrors(registerCheckReplies, "check-replies", () => ({ personIds: [456], cdpPort: 9222 }), (error) => vi.mocked(checkReplies).mockRejectedValue(error), "Failed to check replies");
|
|
191
191
|
});
|
|
192
192
|
//# sourceMappingURL=check-replies.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-replies.test.js","sourceRoot":"","sources":["../../src/tools/check-replies.test.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"check-replies.test.js","sourceRoot":"","sources":["../../src/tools/check-replies.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment-on-post.test.d.ts","sourceRoot":"","sources":["../../src/tools/comment-on-post.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
vi.mock("@lhremote/core", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return { ...actual, commentOnPost: vi.fn() };
|
|
7
|
+
});
|
|
8
|
+
import { commentOnPost } from "@lhremote/core";
|
|
9
|
+
import { registerCommentOnPost } from "./comment-on-post.js";
|
|
10
|
+
import { describeInfrastructureErrors } from "./testing/infrastructure-errors.js";
|
|
11
|
+
import { createMockServer } from "./testing/mock-server.js";
|
|
12
|
+
const MOCK_RESULT = {
|
|
13
|
+
success: true,
|
|
14
|
+
postUrl: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
15
|
+
commentText: "Great post!",
|
|
16
|
+
};
|
|
17
|
+
describe("registerCommentOnPost", () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
afterEach(() => {
|
|
22
|
+
vi.restoreAllMocks();
|
|
23
|
+
});
|
|
24
|
+
it("registers a tool named comment-on-post", () => {
|
|
25
|
+
const { server } = createMockServer();
|
|
26
|
+
registerCommentOnPost(server);
|
|
27
|
+
expect(server.tool).toHaveBeenCalledOnce();
|
|
28
|
+
expect(server.tool).toHaveBeenCalledWith("comment-on-post", expect.any(String), expect.any(Object), expect.any(Function));
|
|
29
|
+
});
|
|
30
|
+
it("returns result as JSON on success", async () => {
|
|
31
|
+
const { server, getHandler } = createMockServer();
|
|
32
|
+
registerCommentOnPost(server);
|
|
33
|
+
vi.mocked(commentOnPost).mockResolvedValue(MOCK_RESULT);
|
|
34
|
+
const handler = getHandler("comment-on-post");
|
|
35
|
+
const result = await handler({
|
|
36
|
+
postUrl: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
37
|
+
text: "Great post!",
|
|
38
|
+
cdpPort: 9222,
|
|
39
|
+
});
|
|
40
|
+
expect(result).toEqual({
|
|
41
|
+
content: [{ type: "text", text: JSON.stringify(MOCK_RESULT, null, 2) }],
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
it("returns error on failure", async () => {
|
|
45
|
+
const { server, getHandler } = createMockServer();
|
|
46
|
+
registerCommentOnPost(server);
|
|
47
|
+
vi.mocked(commentOnPost).mockRejectedValue(new Error("connection refused"));
|
|
48
|
+
const handler = getHandler("comment-on-post");
|
|
49
|
+
const result = (await handler({
|
|
50
|
+
postUrl: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
51
|
+
text: "Great post!",
|
|
52
|
+
cdpPort: 9222,
|
|
53
|
+
}));
|
|
54
|
+
expect(result.isError).toBe(true);
|
|
55
|
+
const text = result.content[0].text;
|
|
56
|
+
expect(text).toContain("Failed to comment on post");
|
|
57
|
+
});
|
|
58
|
+
describeInfrastructureErrors(registerCommentOnPost, "comment-on-post", () => ({
|
|
59
|
+
postUrl: "https://www.linkedin.com/feed/update/urn:li:activity:123/",
|
|
60
|
+
text: "Great post!",
|
|
61
|
+
cdpPort: 9222,
|
|
62
|
+
}), (error) => vi.mocked(commentOnPost).mockRejectedValue(error), "Failed to comment on post");
|
|
63
|
+
});
|
|
64
|
+
//# sourceMappingURL=comment-on-post.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment-on-post.test.js","sourceRoot":"","sources":["../../src/tools/comment-on-post.test.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEzE,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE;IACjD,MAAM,MAAM,GAAG,MAAM,cAAc,EAAmC,CAAC;IACvE,OAAO,EAAE,GAAG,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;AAC/C,CAAC,CAAC,CAAC;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,4BAA4B,EAAE,MAAM,oCAAoC,CAAC;AAClF,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAE5D,MAAM,WAAW,GAAG;IAClB,OAAO,EAAE,IAAa;IACtB,OAAO,EACL,2DAA2D;IAC7D,WAAW,EAAE,aAAa;CAC3B,CAAC;AAEF,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,UAAU,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,aAAa,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,EAAE,CAAC,eAAe,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;QAChD,MAAM,EAAE,MAAM,EAAE,GAAG,gBAAgB,EAAE,CAAC;QACtC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,oBAAoB,EAAE,CAAC;QAC3C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,oBAAoB,CACtC,iBAAiB,EACjB,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,EAClB,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,EAClB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CACrB,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,gBAAgB,EAAE,CAAC;QAClD,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAC9B,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAExD,MAAM,OAAO,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC;YAC3B,OAAO,EACL,2DAA2D;YAC7D,IAAI,EAAE,aAAa;YACnB,OAAO,EAAE,IAAI;SACd,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC;SACxE,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,gBAAgB,EAAE,CAAC;QAClD,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAC9B,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,iBAAiB,CACxC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAChC,CAAC;QAEF,MAAM,OAAO,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,CAAC,MAAM,OAAO,CAAC;YAC5B,OAAO,EACL,2DAA2D;YAC7D,IAAI,EAAE,aAAa;YACnB,OAAO,EAAE,IAAI;SACd,CAAC,CAAuD,CAAC;QAE1D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,IAAI,GAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAsB,CAAC,IAAI,CAAC;QAC1D,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,2BAA2B,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,4BAA4B,CAC1B,qBAAqB,EACrB,iBAAiB,EACjB,GAAG,EAAE,CAAC,CAAC;QACL,OAAO,EACL,2DAA2D;QAC7D,IAAI,EAAE,aAAa;QACnB,OAAO,EAAE,IAAI;KACd,CAAC,EACF,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAC5D,2BAA2B,CAC5B,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-collection.test.d.ts","sourceRoot":"","sources":["../../src/tools/create-collection.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
vi.mock("@lhremote/core", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return { ...actual, createCollection: vi.fn() };
|
|
7
|
+
});
|
|
8
|
+
import { createCollection } from "@lhremote/core";
|
|
9
|
+
import { registerCreateCollection } from "./create-collection.js";
|
|
10
|
+
import { describeInfrastructureErrors } from "./testing/infrastructure-errors.js";
|
|
11
|
+
import { createMockServer } from "./testing/mock-server.js";
|
|
12
|
+
const MOCK_RESULT = {
|
|
13
|
+
success: true,
|
|
14
|
+
collectionId: 42,
|
|
15
|
+
name: "My List",
|
|
16
|
+
};
|
|
17
|
+
describe("registerCreateCollection", () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
afterEach(() => {
|
|
22
|
+
vi.restoreAllMocks();
|
|
23
|
+
});
|
|
24
|
+
it("registers a tool named create-collection", () => {
|
|
25
|
+
const { server } = createMockServer();
|
|
26
|
+
registerCreateCollection(server);
|
|
27
|
+
expect(server.tool).toHaveBeenCalledOnce();
|
|
28
|
+
expect(server.tool).toHaveBeenCalledWith("create-collection", expect.any(String), expect.any(Object), expect.any(Function));
|
|
29
|
+
});
|
|
30
|
+
it("returns result as JSON on success", async () => {
|
|
31
|
+
const { server, getHandler } = createMockServer();
|
|
32
|
+
registerCreateCollection(server);
|
|
33
|
+
vi.mocked(createCollection).mockResolvedValue(MOCK_RESULT);
|
|
34
|
+
const handler = getHandler("create-collection");
|
|
35
|
+
const result = await handler({ name: "My List", cdpPort: 9222 });
|
|
36
|
+
expect(result).toEqual({
|
|
37
|
+
content: [{ type: "text", text: JSON.stringify(MOCK_RESULT, null, 2) }],
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
it("returns error on failure", async () => {
|
|
41
|
+
const { server, getHandler } = createMockServer();
|
|
42
|
+
registerCreateCollection(server);
|
|
43
|
+
vi.mocked(createCollection).mockRejectedValue(new Error("connection refused"));
|
|
44
|
+
const handler = getHandler("create-collection");
|
|
45
|
+
const result = (await handler({
|
|
46
|
+
name: "My List",
|
|
47
|
+
cdpPort: 9222,
|
|
48
|
+
}));
|
|
49
|
+
expect(result.isError).toBe(true);
|
|
50
|
+
const text = result.content[0].text;
|
|
51
|
+
expect(text).toContain("Failed to create collection");
|
|
52
|
+
});
|
|
53
|
+
describeInfrastructureErrors(registerCreateCollection, "create-collection", () => ({ name: "My List", cdpPort: 9222 }), (error) => vi.mocked(createCollection).mockRejectedValue(error), "Failed to create collection");
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=create-collection.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-collection.test.js","sourceRoot":"","sources":["../../src/tools/create-collection.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-collection.test.d.ts","sourceRoot":"","sources":["../../src/tools/delete-collection.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
// SPDX-License-Identifier: AGPL-3.0-only
|
|
2
|
+
// Copyright (C) 2026 Oleksii PELYKH
|
|
3
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
4
|
+
vi.mock("@lhremote/core", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return { ...actual, deleteCollection: vi.fn() };
|
|
7
|
+
});
|
|
8
|
+
import { deleteCollection } from "@lhremote/core";
|
|
9
|
+
import { registerDeleteCollection } from "./delete-collection.js";
|
|
10
|
+
import { describeInfrastructureErrors } from "./testing/infrastructure-errors.js";
|
|
11
|
+
import { createMockServer } from "./testing/mock-server.js";
|
|
12
|
+
const MOCK_RESULT = {
|
|
13
|
+
success: true,
|
|
14
|
+
collectionId: 42,
|
|
15
|
+
deleted: true,
|
|
16
|
+
};
|
|
17
|
+
describe("registerDeleteCollection", () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
afterEach(() => {
|
|
22
|
+
vi.restoreAllMocks();
|
|
23
|
+
});
|
|
24
|
+
it("registers a tool named delete-collection", () => {
|
|
25
|
+
const { server } = createMockServer();
|
|
26
|
+
registerDeleteCollection(server);
|
|
27
|
+
expect(server.tool).toHaveBeenCalledOnce();
|
|
28
|
+
expect(server.tool).toHaveBeenCalledWith("delete-collection", expect.any(String), expect.any(Object), expect.any(Function));
|
|
29
|
+
});
|
|
30
|
+
it("returns result as JSON on success", async () => {
|
|
31
|
+
const { server, getHandler } = createMockServer();
|
|
32
|
+
registerDeleteCollection(server);
|
|
33
|
+
vi.mocked(deleteCollection).mockResolvedValue(MOCK_RESULT);
|
|
34
|
+
const handler = getHandler("delete-collection");
|
|
35
|
+
const result = await handler({ collectionId: 42, cdpPort: 9222 });
|
|
36
|
+
expect(result).toEqual({
|
|
37
|
+
content: [{ type: "text", text: JSON.stringify(MOCK_RESULT, null, 2) }],
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
it("returns error on failure", async () => {
|
|
41
|
+
const { server, getHandler } = createMockServer();
|
|
42
|
+
registerDeleteCollection(server);
|
|
43
|
+
vi.mocked(deleteCollection).mockRejectedValue(new Error("connection refused"));
|
|
44
|
+
const handler = getHandler("delete-collection");
|
|
45
|
+
const result = (await handler({
|
|
46
|
+
collectionId: 42,
|
|
47
|
+
cdpPort: 9222,
|
|
48
|
+
}));
|
|
49
|
+
expect(result.isError).toBe(true);
|
|
50
|
+
const text = result.content[0].text;
|
|
51
|
+
expect(text).toContain("Failed to delete collection");
|
|
52
|
+
});
|
|
53
|
+
describeInfrastructureErrors(registerDeleteCollection, "delete-collection", () => ({ collectionId: 42, cdpPort: 9222 }), (error) => vi.mocked(deleteCollection).mockRejectedValue(error), "Failed to delete collection");
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=delete-collection.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-collection.test.js","sourceRoot":"","sources":["../../src/tools/delete-collection.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -29,7 +29,7 @@ describe("registerFindApp", () => {
|
|
|
29
29
|
const { server, getHandler } = createMockServer();
|
|
30
30
|
registerFindApp(server);
|
|
31
31
|
const apps = [
|
|
32
|
-
{ pid: 1234, cdpPort: 9222, connectable: true },
|
|
32
|
+
{ pid: 1234, cdpPort: 9222, connectable: true, role: "launcher" },
|
|
33
33
|
];
|
|
34
34
|
mockedFindApp.mockResolvedValue(apps);
|
|
35
35
|
const handler = getHandler("find-app");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"find-app.test.js","sourceRoot":"","sources":["../../src/tools/find-app.test.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,oCAAoC;AAEpC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEzE,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE;IACjD,MAAM,MAAM,GAAG,MAAM,cAAc,EAAmC,CAAC;IACvE,OAAO;QACL,GAAG,MAAM;QACT,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE;KACjB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,OAAO,EAAsB,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAE7D,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAE5D,MAAM,aAAa,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;AAEzC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,UAAU,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,aAAa,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,EAAE,CAAC,eAAe,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,EAAE,MAAM,EAAE,GAAG,gBAAgB,EAAE,CAAC;QACtC,eAAe,CAAC,MAAM,CAAC,CAAC;QAExB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,oBAAoB,EAAE,CAAC;QAC3C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,oBAAoB,CACtC,UAAU,EACV,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,EAClB,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,EAClB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CACrB,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,gBAAgB,EAAE,CAAC;QAClD,eAAe,CAAC,MAAM,CAAC,CAAC;QAExB,MAAM,IAAI,GAAoB;YAC5B,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE;
|
|
1
|
+
{"version":3,"file":"find-app.test.js","sourceRoot":"","sources":["../../src/tools/find-app.test.ts"],"names":[],"mappings":"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"}
|