@herdctl/core 0.0.1 → 0.0.2
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/dist/config/__tests__/agent.test.js +31 -13
- package/dist/config/__tests__/agent.test.js.map +1 -1
- package/dist/config/__tests__/merge.test.js +9 -2
- package/dist/config/__tests__/merge.test.js.map +1 -1
- package/dist/config/__tests__/schema.test.js +350 -1
- package/dist/config/__tests__/schema.test.js.map +1 -1
- package/dist/config/index.d.ts +1 -1
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +3 -1
- package/dist/config/index.js.map +1 -1
- package/dist/config/schema.d.ts +828 -24
- package/dist/config/schema.d.ts.map +1 -1
- package/dist/config/schema.js +118 -6
- package/dist/config/schema.js.map +1 -1
- package/dist/fleet-manager/__tests__/coverage.test.js +11 -332
- package/dist/fleet-manager/__tests__/coverage.test.js.map +1 -1
- package/dist/fleet-manager/__tests__/errors.test.js +1 -49
- package/dist/fleet-manager/__tests__/errors.test.js.map +1 -1
- package/dist/fleet-manager/__tests__/integration.test.js +109 -0
- package/dist/fleet-manager/__tests__/integration.test.js.map +1 -1
- package/dist/fleet-manager/__tests__/reload.test.js +1 -1
- package/dist/fleet-manager/__tests__/reload.test.js.map +1 -1
- package/dist/fleet-manager/config-reload.d.ts +164 -0
- package/dist/fleet-manager/config-reload.d.ts.map +1 -0
- package/dist/fleet-manager/config-reload.js +445 -0
- package/dist/fleet-manager/config-reload.js.map +1 -0
- package/dist/fleet-manager/context.d.ts +76 -0
- package/dist/fleet-manager/context.d.ts.map +1 -0
- package/dist/fleet-manager/context.js +11 -0
- package/dist/fleet-manager/context.js.map +1 -0
- package/dist/fleet-manager/errors.d.ts +0 -25
- package/dist/fleet-manager/errors.d.ts.map +1 -1
- package/dist/fleet-manager/errors.js +0 -38
- package/dist/fleet-manager/errors.js.map +1 -1
- package/dist/fleet-manager/event-emitters.d.ts +123 -0
- package/dist/fleet-manager/event-emitters.d.ts.map +1 -0
- package/dist/fleet-manager/event-emitters.js +136 -0
- package/dist/fleet-manager/event-emitters.js.map +1 -0
- package/dist/fleet-manager/event-types.d.ts +0 -15
- package/dist/fleet-manager/event-types.d.ts.map +1 -1
- package/dist/fleet-manager/fleet-manager.d.ts +40 -653
- package/dist/fleet-manager/fleet-manager.d.ts.map +1 -1
- package/dist/fleet-manager/fleet-manager.js +95 -1720
- package/dist/fleet-manager/fleet-manager.js.map +1 -1
- package/dist/fleet-manager/index.d.ts +13 -2
- package/dist/fleet-manager/index.d.ts.map +1 -1
- package/dist/fleet-manager/index.js +19 -6
- package/dist/fleet-manager/index.js.map +1 -1
- package/dist/fleet-manager/job-control.d.ts +64 -0
- package/dist/fleet-manager/job-control.d.ts.map +1 -0
- package/dist/fleet-manager/job-control.js +296 -0
- package/dist/fleet-manager/job-control.js.map +1 -0
- package/dist/fleet-manager/log-streaming.d.ts +171 -0
- package/dist/fleet-manager/log-streaming.d.ts.map +1 -0
- package/dist/fleet-manager/log-streaming.js +503 -0
- package/dist/fleet-manager/log-streaming.js.map +1 -0
- package/dist/fleet-manager/schedule-executor.d.ts +63 -0
- package/dist/fleet-manager/schedule-executor.d.ts.map +1 -0
- package/dist/fleet-manager/schedule-executor.js +209 -0
- package/dist/fleet-manager/schedule-executor.js.map +1 -0
- package/dist/fleet-manager/schedule-management.d.ts +71 -0
- package/dist/fleet-manager/schedule-management.d.ts.map +1 -0
- package/dist/fleet-manager/schedule-management.js +171 -0
- package/dist/fleet-manager/schedule-management.js.map +1 -0
- package/dist/fleet-manager/status-queries.d.ts +105 -0
- package/dist/fleet-manager/status-queries.d.ts.map +1 -0
- package/dist/fleet-manager/status-queries.js +247 -0
- package/dist/fleet-manager/status-queries.js.map +1 -0
- package/dist/fleet-manager/types.d.ts +0 -39
- package/dist/fleet-manager/types.d.ts.map +1 -1
- package/dist/runner/__tests__/job-executor.test.js +206 -1
- package/dist/runner/__tests__/job-executor.test.js.map +1 -1
- package/dist/runner/job-executor.d.ts +9 -0
- package/dist/runner/job-executor.d.ts.map +1 -1
- package/dist/runner/job-executor.js +78 -4
- package/dist/runner/job-executor.js.map +1 -1
- package/dist/runner/types.d.ts +2 -0
- package/dist/runner/types.d.ts.map +1 -1
- package/dist/scheduler/__tests__/cron.test.d.ts +2 -0
- package/dist/scheduler/__tests__/cron.test.d.ts.map +1 -0
- package/dist/scheduler/__tests__/cron.test.js +867 -0
- package/dist/scheduler/__tests__/cron.test.js.map +1 -0
- package/dist/scheduler/__tests__/scheduler.test.js +164 -5
- package/dist/scheduler/__tests__/scheduler.test.js.map +1 -1
- package/dist/scheduler/cron.d.ts +126 -0
- package/dist/scheduler/cron.d.ts.map +1 -0
- package/dist/scheduler/cron.js +390 -0
- package/dist/scheduler/cron.js.map +1 -0
- package/dist/scheduler/errors.d.ts +81 -1
- package/dist/scheduler/errors.d.ts.map +1 -1
- package/dist/scheduler/errors.js +81 -6
- package/dist/scheduler/errors.js.map +1 -1
- package/dist/scheduler/index.d.ts +1 -0
- package/dist/scheduler/index.d.ts.map +1 -1
- package/dist/scheduler/index.js +2 -0
- package/dist/scheduler/index.js.map +1 -1
- package/dist/scheduler/schedule-runner.d.ts +2 -2
- package/dist/scheduler/schedule-runner.d.ts.map +1 -1
- package/dist/scheduler/schedule-runner.js +20 -8
- package/dist/scheduler/schedule-runner.js.map +1 -1
- package/dist/scheduler/scheduler.d.ts +4 -4
- package/dist/scheduler/scheduler.d.ts.map +1 -1
- package/dist/scheduler/scheduler.js +86 -20
- package/dist/scheduler/scheduler.js.map +1 -1
- package/dist/scheduler/types.d.ts +1 -1
- package/dist/scheduler/types.d.ts.map +1 -1
- package/dist/state/schemas/job-metadata.d.ts +2 -2
- package/package.json +33 -8
- package/.turbo/turbo-build.log +0 -4
- package/.turbo/turbo-test.log +0 -219
- package/.turbo/turbo-typecheck.log +0 -4
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/coverage-final.json +0 -51
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -251
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -210
- package/coverage/src/config/index.html +0 -191
- package/coverage/src/config/index.ts.html +0 -442
- package/coverage/src/config/interpolate.ts.html +0 -652
- package/coverage/src/config/loader.ts.html +0 -1501
- package/coverage/src/config/merge.ts.html +0 -823
- package/coverage/src/config/parser.ts.html +0 -1213
- package/coverage/src/config/schema.ts.html +0 -1123
- package/coverage/src/fleet-manager/errors.ts.html +0 -2326
- package/coverage/src/fleet-manager/event-types.ts.html +0 -1219
- package/coverage/src/fleet-manager/fleet-manager.ts.html +0 -7030
- package/coverage/src/fleet-manager/index.html +0 -206
- package/coverage/src/fleet-manager/index.ts.html +0 -469
- package/coverage/src/fleet-manager/job-manager.ts.html +0 -2074
- package/coverage/src/fleet-manager/job-queue.ts.html +0 -2479
- package/coverage/src/fleet-manager/types.ts.html +0 -2602
- package/coverage/src/index.html +0 -116
- package/coverage/src/index.ts.html +0 -181
- package/coverage/src/runner/errors.ts.html +0 -1006
- package/coverage/src/runner/index.html +0 -191
- package/coverage/src/runner/index.ts.html +0 -256
- package/coverage/src/runner/job-executor.ts.html +0 -1429
- package/coverage/src/runner/message-processor.ts.html +0 -1150
- package/coverage/src/runner/sdk-adapter.ts.html +0 -658
- package/coverage/src/runner/types.ts.html +0 -559
- package/coverage/src/scheduler/errors.ts.html +0 -388
- package/coverage/src/scheduler/index.html +0 -206
- package/coverage/src/scheduler/index.ts.html +0 -244
- package/coverage/src/scheduler/interval.ts.html +0 -652
- package/coverage/src/scheduler/schedule-runner.ts.html +0 -1411
- package/coverage/src/scheduler/schedule-state.ts.html +0 -718
- package/coverage/src/scheduler/scheduler.ts.html +0 -1795
- package/coverage/src/scheduler/types.ts.html +0 -733
- package/coverage/src/state/directory.ts.html +0 -736
- package/coverage/src/state/errors.ts.html +0 -376
- package/coverage/src/state/fleet-state.ts.html +0 -937
- package/coverage/src/state/index.html +0 -221
- package/coverage/src/state/index.ts.html +0 -322
- package/coverage/src/state/job-metadata.ts.html +0 -1420
- package/coverage/src/state/job-output.ts.html +0 -1033
- package/coverage/src/state/schemas/fleet-state.ts.html +0 -445
- package/coverage/src/state/schemas/index.html +0 -176
- package/coverage/src/state/schemas/index.ts.html +0 -286
- package/coverage/src/state/schemas/job-metadata.ts.html +0 -628
- package/coverage/src/state/schemas/job-output.ts.html +0 -616
- package/coverage/src/state/schemas/session-info.ts.html +0 -361
- package/coverage/src/state/session.ts.html +0 -844
- package/coverage/src/state/types.ts.html +0 -262
- package/coverage/src/state/utils/atomic.ts.html +0 -748
- package/coverage/src/state/utils/index.html +0 -146
- package/coverage/src/state/utils/index.ts.html +0 -103
- package/coverage/src/state/utils/reads.ts.html +0 -1621
- package/coverage/src/work-sources/adapters/github.ts.html +0 -3583
- package/coverage/src/work-sources/adapters/index.html +0 -131
- package/coverage/src/work-sources/adapters/index.ts.html +0 -277
- package/coverage/src/work-sources/errors.ts.html +0 -298
- package/coverage/src/work-sources/index.html +0 -176
- package/coverage/src/work-sources/index.ts.html +0 -529
- package/coverage/src/work-sources/manager.ts.html +0 -1324
- package/coverage/src/work-sources/registry.ts.html +0 -619
- package/coverage/src/work-sources/types.ts.html +0 -568
- package/dist/fleet-manager/__tests__/event-helpers.test.d.ts +0 -7
- package/dist/fleet-manager/__tests__/event-helpers.test.d.ts.map +0 -1
- package/dist/fleet-manager/__tests__/event-helpers.test.js +0 -368
- package/dist/fleet-manager/__tests__/event-helpers.test.js.map +0 -1
- package/src/config/__tests__/agent.test.ts +0 -864
- package/src/config/__tests__/interpolate.test.ts +0 -644
- package/src/config/__tests__/loader.test.ts +0 -784
- package/src/config/__tests__/merge.test.ts +0 -751
- package/src/config/__tests__/parser.test.ts +0 -533
- package/src/config/__tests__/schema.test.ts +0 -873
- package/src/config/index.ts +0 -119
- package/src/config/interpolate.ts +0 -189
- package/src/config/loader.ts +0 -472
- package/src/config/merge.ts +0 -246
- package/src/config/parser.ts +0 -376
- package/src/config/schema.ts +0 -346
- package/src/fleet-manager/__tests__/coverage.test.ts +0 -2869
- package/src/fleet-manager/__tests__/errors.test.ts +0 -660
- package/src/fleet-manager/__tests__/event-helpers.test.ts +0 -448
- package/src/fleet-manager/__tests__/integration.test.ts +0 -1209
- package/src/fleet-manager/__tests__/job-control.test.ts +0 -283
- package/src/fleet-manager/__tests__/job-manager.test.ts +0 -869
- package/src/fleet-manager/__tests__/job-queue.test.ts +0 -401
- package/src/fleet-manager/__tests__/reload.test.ts +0 -751
- package/src/fleet-manager/__tests__/status-queries.test.ts +0 -595
- package/src/fleet-manager/__tests__/trigger.test.ts +0 -601
- package/src/fleet-manager/errors.ts +0 -747
- package/src/fleet-manager/event-types.ts +0 -378
- package/src/fleet-manager/fleet-manager.ts +0 -2315
- package/src/fleet-manager/index.ts +0 -128
- package/src/fleet-manager/job-manager.ts +0 -663
- package/src/fleet-manager/job-queue.ts +0 -798
- package/src/fleet-manager/types.ts +0 -839
- package/src/index.ts +0 -32
- package/src/runner/__tests__/errors.test.ts +0 -382
- package/src/runner/__tests__/job-executor.test.ts +0 -1708
- package/src/runner/__tests__/message-processor.test.ts +0 -960
- package/src/runner/__tests__/sdk-adapter.test.ts +0 -626
- package/src/runner/errors.ts +0 -307
- package/src/runner/index.ts +0 -57
- package/src/runner/job-executor.ts +0 -448
- package/src/runner/message-processor.ts +0 -355
- package/src/runner/sdk-adapter.ts +0 -191
- package/src/runner/types.ts +0 -158
- package/src/scheduler/__tests__/errors.test.ts +0 -159
- package/src/scheduler/__tests__/interval.test.ts +0 -515
- package/src/scheduler/__tests__/schedule-runner.test.ts +0 -798
- package/src/scheduler/__tests__/schedule-state.test.ts +0 -671
- package/src/scheduler/__tests__/scheduler.test.ts +0 -1280
- package/src/scheduler/errors.ts +0 -101
- package/src/scheduler/index.ts +0 -53
- package/src/scheduler/interval.ts +0 -189
- package/src/scheduler/schedule-runner.ts +0 -442
- package/src/scheduler/schedule-state.ts +0 -211
- package/src/scheduler/scheduler.ts +0 -570
- package/src/scheduler/types.ts +0 -216
- package/src/state/__tests__/directory.test.ts +0 -595
- package/src/state/__tests__/fleet-state.test.ts +0 -868
- package/src/state/__tests__/job-metadata-schema.test.ts +0 -414
- package/src/state/__tests__/job-metadata.test.ts +0 -831
- package/src/state/__tests__/job-output.test.ts +0 -856
- package/src/state/__tests__/session-schema.test.ts +0 -378
- package/src/state/__tests__/session.test.ts +0 -604
- package/src/state/directory.ts +0 -217
- package/src/state/errors.ts +0 -97
- package/src/state/fleet-state.ts +0 -284
- package/src/state/index.ts +0 -79
- package/src/state/job-metadata.ts +0 -445
- package/src/state/job-output.ts +0 -316
- package/src/state/schemas/__tests__/job-output.test.ts +0 -338
- package/src/state/schemas/fleet-state.ts +0 -120
- package/src/state/schemas/index.ts +0 -67
- package/src/state/schemas/job-metadata.ts +0 -181
- package/src/state/schemas/job-output.ts +0 -177
- package/src/state/schemas/session-info.ts +0 -92
- package/src/state/session.ts +0 -253
- package/src/state/types.ts +0 -59
- package/src/state/utils/__tests__/atomic.test.ts +0 -723
- package/src/state/utils/__tests__/reads.test.ts +0 -1071
- package/src/state/utils/atomic.ts +0 -221
- package/src/state/utils/index.ts +0 -6
- package/src/state/utils/reads.ts +0 -512
- package/src/work-sources/__tests__/github.test.ts +0 -1800
- package/src/work-sources/__tests__/manager.test.ts +0 -529
- package/src/work-sources/__tests__/registry.test.ts +0 -477
- package/src/work-sources/__tests__/types.test.ts +0 -479
- package/src/work-sources/adapters/github.ts +0 -1166
- package/src/work-sources/adapters/index.ts +0 -64
- package/src/work-sources/errors.ts +0 -71
- package/src/work-sources/index.ts +0 -148
- package/src/work-sources/manager.ts +0 -413
- package/src/work-sources/registry.ts +0 -178
- package/src/work-sources/types.ts +0 -161
- package/tsconfig.json +0 -9
- package/vitest.config.ts +0 -19
|
@@ -1,479 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from "vitest";
|
|
2
|
-
import type {
|
|
3
|
-
WorkItem,
|
|
4
|
-
WorkItemPriority,
|
|
5
|
-
FetchOptions,
|
|
6
|
-
FetchResult,
|
|
7
|
-
ClaimResult,
|
|
8
|
-
ClaimFailureReason,
|
|
9
|
-
WorkResult,
|
|
10
|
-
WorkOutcome,
|
|
11
|
-
ReleaseOptions,
|
|
12
|
-
ReleaseResult,
|
|
13
|
-
WorkSourceAdapter,
|
|
14
|
-
} from "../index.js";
|
|
15
|
-
|
|
16
|
-
// =============================================================================
|
|
17
|
-
// WorkItem type tests
|
|
18
|
-
// =============================================================================
|
|
19
|
-
|
|
20
|
-
describe("WorkItem", () => {
|
|
21
|
-
it("captures all required fields", () => {
|
|
22
|
-
const workItem: WorkItem = {
|
|
23
|
-
id: "github-123",
|
|
24
|
-
source: "github",
|
|
25
|
-
externalId: "123",
|
|
26
|
-
title: "Fix authentication bug",
|
|
27
|
-
description: "Users are being logged out unexpectedly",
|
|
28
|
-
priority: "high",
|
|
29
|
-
labels: ["bug", "auth"],
|
|
30
|
-
metadata: { milestone: "v1.0" },
|
|
31
|
-
url: "https://github.com/org/repo/issues/123",
|
|
32
|
-
createdAt: new Date("2024-01-01"),
|
|
33
|
-
updatedAt: new Date("2024-01-02"),
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
expect(workItem.id).toBe("github-123");
|
|
37
|
-
expect(workItem.source).toBe("github");
|
|
38
|
-
expect(workItem.externalId).toBe("123");
|
|
39
|
-
expect(workItem.title).toBe("Fix authentication bug");
|
|
40
|
-
expect(workItem.description).toBe("Users are being logged out unexpectedly");
|
|
41
|
-
expect(workItem.priority).toBe("high");
|
|
42
|
-
expect(workItem.labels).toEqual(["bug", "auth"]);
|
|
43
|
-
expect(workItem.metadata).toEqual({ milestone: "v1.0" });
|
|
44
|
-
expect(workItem.url).toBe("https://github.com/org/repo/issues/123");
|
|
45
|
-
expect(workItem.createdAt).toEqual(new Date("2024-01-01"));
|
|
46
|
-
expect(workItem.updatedAt).toEqual(new Date("2024-01-02"));
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it("supports all priority levels", () => {
|
|
50
|
-
const priorities: WorkItemPriority[] = ["critical", "high", "medium", "low"];
|
|
51
|
-
priorities.forEach((priority) => {
|
|
52
|
-
const workItem: WorkItem = {
|
|
53
|
-
id: "test-1",
|
|
54
|
-
source: "test",
|
|
55
|
-
externalId: "1",
|
|
56
|
-
title: "Test",
|
|
57
|
-
description: "Test description",
|
|
58
|
-
priority,
|
|
59
|
-
labels: [],
|
|
60
|
-
metadata: {},
|
|
61
|
-
url: "https://example.com",
|
|
62
|
-
createdAt: new Date(),
|
|
63
|
-
updatedAt: new Date(),
|
|
64
|
-
};
|
|
65
|
-
expect(workItem.priority).toBe(priority);
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
it("supports empty labels array", () => {
|
|
70
|
-
const workItem: WorkItem = {
|
|
71
|
-
id: "test-1",
|
|
72
|
-
source: "test",
|
|
73
|
-
externalId: "1",
|
|
74
|
-
title: "Test",
|
|
75
|
-
description: "",
|
|
76
|
-
priority: "low",
|
|
77
|
-
labels: [],
|
|
78
|
-
metadata: {},
|
|
79
|
-
url: "https://example.com",
|
|
80
|
-
createdAt: new Date(),
|
|
81
|
-
updatedAt: new Date(),
|
|
82
|
-
};
|
|
83
|
-
expect(workItem.labels).toEqual([]);
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
it("supports complex metadata", () => {
|
|
87
|
-
const workItem: WorkItem = {
|
|
88
|
-
id: "linear-abc",
|
|
89
|
-
source: "linear",
|
|
90
|
-
externalId: "abc",
|
|
91
|
-
title: "Implement feature",
|
|
92
|
-
description: "Feature description",
|
|
93
|
-
priority: "medium",
|
|
94
|
-
labels: ["feature"],
|
|
95
|
-
metadata: {
|
|
96
|
-
project: { id: "proj-1", name: "Main Project" },
|
|
97
|
-
cycle: { number: 5, name: "Sprint 5" },
|
|
98
|
-
estimate: 3,
|
|
99
|
-
assignees: ["user1", "user2"],
|
|
100
|
-
},
|
|
101
|
-
url: "https://linear.app/team/issue/abc",
|
|
102
|
-
createdAt: new Date(),
|
|
103
|
-
updatedAt: new Date(),
|
|
104
|
-
};
|
|
105
|
-
expect(workItem.metadata.project).toEqual({ id: "proj-1", name: "Main Project" });
|
|
106
|
-
expect(workItem.metadata.estimate).toBe(3);
|
|
107
|
-
});
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
// =============================================================================
|
|
111
|
-
// FetchOptions and FetchResult type tests
|
|
112
|
-
// =============================================================================
|
|
113
|
-
|
|
114
|
-
describe("FetchOptions", () => {
|
|
115
|
-
it("supports filtering by labels", () => {
|
|
116
|
-
const options: FetchOptions = {
|
|
117
|
-
labels: ["agent-ready", "bug"],
|
|
118
|
-
};
|
|
119
|
-
expect(options.labels).toEqual(["agent-ready", "bug"]);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
it("supports filtering by priority", () => {
|
|
123
|
-
const options: FetchOptions = {
|
|
124
|
-
priority: ["critical", "high"],
|
|
125
|
-
};
|
|
126
|
-
expect(options.priority).toEqual(["critical", "high"]);
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
it("supports pagination with limit and cursor", () => {
|
|
130
|
-
const options: FetchOptions = {
|
|
131
|
-
limit: 10,
|
|
132
|
-
cursor: "eyJwYWdlIjogMn0=",
|
|
133
|
-
};
|
|
134
|
-
expect(options.limit).toBe(10);
|
|
135
|
-
expect(options.cursor).toBe("eyJwYWdlIjogMn0=");
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
it("supports includeClaimed option", () => {
|
|
139
|
-
const options: FetchOptions = {
|
|
140
|
-
includeClaimed: true,
|
|
141
|
-
};
|
|
142
|
-
expect(options.includeClaimed).toBe(true);
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
it("supports all options together", () => {
|
|
146
|
-
const options: FetchOptions = {
|
|
147
|
-
labels: ["ready"],
|
|
148
|
-
priority: ["high", "medium"],
|
|
149
|
-
limit: 25,
|
|
150
|
-
cursor: "abc123",
|
|
151
|
-
includeClaimed: false,
|
|
152
|
-
};
|
|
153
|
-
expect(options.labels).toEqual(["ready"]);
|
|
154
|
-
expect(options.priority).toEqual(["high", "medium"]);
|
|
155
|
-
expect(options.limit).toBe(25);
|
|
156
|
-
expect(options.cursor).toBe("abc123");
|
|
157
|
-
expect(options.includeClaimed).toBe(false);
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it("allows empty options object", () => {
|
|
161
|
-
const options: FetchOptions = {};
|
|
162
|
-
expect(options.labels).toBeUndefined();
|
|
163
|
-
expect(options.priority).toBeUndefined();
|
|
164
|
-
expect(options.limit).toBeUndefined();
|
|
165
|
-
expect(options.cursor).toBeUndefined();
|
|
166
|
-
});
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
describe("FetchResult", () => {
|
|
170
|
-
it("returns items with pagination info", () => {
|
|
171
|
-
const workItem: WorkItem = {
|
|
172
|
-
id: "github-1",
|
|
173
|
-
source: "github",
|
|
174
|
-
externalId: "1",
|
|
175
|
-
title: "Test issue",
|
|
176
|
-
description: "Description",
|
|
177
|
-
priority: "medium",
|
|
178
|
-
labels: [],
|
|
179
|
-
metadata: {},
|
|
180
|
-
url: "https://github.com/test",
|
|
181
|
-
createdAt: new Date(),
|
|
182
|
-
updatedAt: new Date(),
|
|
183
|
-
};
|
|
184
|
-
|
|
185
|
-
const result: FetchResult = {
|
|
186
|
-
items: [workItem],
|
|
187
|
-
nextCursor: "next-page-cursor",
|
|
188
|
-
totalCount: 100,
|
|
189
|
-
};
|
|
190
|
-
|
|
191
|
-
expect(result.items).toHaveLength(1);
|
|
192
|
-
expect(result.nextCursor).toBe("next-page-cursor");
|
|
193
|
-
expect(result.totalCount).toBe(100);
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
it("handles last page with no next cursor", () => {
|
|
197
|
-
const result: FetchResult = {
|
|
198
|
-
items: [],
|
|
199
|
-
nextCursor: undefined,
|
|
200
|
-
};
|
|
201
|
-
expect(result.items).toHaveLength(0);
|
|
202
|
-
expect(result.nextCursor).toBeUndefined();
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
it("totalCount is optional", () => {
|
|
206
|
-
const result: FetchResult = {
|
|
207
|
-
items: [],
|
|
208
|
-
};
|
|
209
|
-
expect(result.totalCount).toBeUndefined();
|
|
210
|
-
});
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
// =============================================================================
|
|
214
|
-
// ClaimResult type tests
|
|
215
|
-
// =============================================================================
|
|
216
|
-
|
|
217
|
-
describe("ClaimResult", () => {
|
|
218
|
-
it("represents successful claim with work item", () => {
|
|
219
|
-
const workItem: WorkItem = {
|
|
220
|
-
id: "github-123",
|
|
221
|
-
source: "github",
|
|
222
|
-
externalId: "123",
|
|
223
|
-
title: "Claimed issue",
|
|
224
|
-
description: "Description",
|
|
225
|
-
priority: "high",
|
|
226
|
-
labels: ["in-progress"],
|
|
227
|
-
metadata: {},
|
|
228
|
-
url: "https://github.com/test",
|
|
229
|
-
createdAt: new Date(),
|
|
230
|
-
updatedAt: new Date(),
|
|
231
|
-
};
|
|
232
|
-
|
|
233
|
-
const result: ClaimResult = {
|
|
234
|
-
success: true,
|
|
235
|
-
workItem,
|
|
236
|
-
};
|
|
237
|
-
|
|
238
|
-
expect(result.success).toBe(true);
|
|
239
|
-
expect(result.workItem).toBe(workItem);
|
|
240
|
-
expect(result.reason).toBeUndefined();
|
|
241
|
-
expect(result.message).toBeUndefined();
|
|
242
|
-
});
|
|
243
|
-
|
|
244
|
-
it("represents failed claim with reason", () => {
|
|
245
|
-
const result: ClaimResult = {
|
|
246
|
-
success: false,
|
|
247
|
-
reason: "already_claimed",
|
|
248
|
-
message: "This issue is already being worked on by another agent",
|
|
249
|
-
};
|
|
250
|
-
|
|
251
|
-
expect(result.success).toBe(false);
|
|
252
|
-
expect(result.workItem).toBeUndefined();
|
|
253
|
-
expect(result.reason).toBe("already_claimed");
|
|
254
|
-
expect(result.message).toBe("This issue is already being worked on by another agent");
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
it("supports all failure reasons", () => {
|
|
258
|
-
const reasons: ClaimFailureReason[] = [
|
|
259
|
-
"already_claimed",
|
|
260
|
-
"not_found",
|
|
261
|
-
"permission_denied",
|
|
262
|
-
"source_error",
|
|
263
|
-
"invalid_state",
|
|
264
|
-
];
|
|
265
|
-
|
|
266
|
-
reasons.forEach((reason) => {
|
|
267
|
-
const result: ClaimResult = {
|
|
268
|
-
success: false,
|
|
269
|
-
reason,
|
|
270
|
-
};
|
|
271
|
-
expect(result.reason).toBe(reason);
|
|
272
|
-
});
|
|
273
|
-
});
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
// =============================================================================
|
|
277
|
-
// WorkResult type tests
|
|
278
|
-
// =============================================================================
|
|
279
|
-
|
|
280
|
-
describe("WorkResult", () => {
|
|
281
|
-
it("represents successful completion", () => {
|
|
282
|
-
const result: WorkResult = {
|
|
283
|
-
outcome: "success",
|
|
284
|
-
summary: "Fixed the authentication bug by updating the session timeout logic",
|
|
285
|
-
details: "Updated SessionManager.ts to handle edge cases in token refresh",
|
|
286
|
-
artifacts: ["src/SessionManager.ts", "tests/SessionManager.test.ts"],
|
|
287
|
-
};
|
|
288
|
-
|
|
289
|
-
expect(result.outcome).toBe("success");
|
|
290
|
-
expect(result.summary).toContain("Fixed");
|
|
291
|
-
expect(result.details).toContain("SessionManager");
|
|
292
|
-
expect(result.artifacts).toHaveLength(2);
|
|
293
|
-
expect(result.error).toBeUndefined();
|
|
294
|
-
});
|
|
295
|
-
|
|
296
|
-
it("represents failed completion", () => {
|
|
297
|
-
const result: WorkResult = {
|
|
298
|
-
outcome: "failure",
|
|
299
|
-
summary: "Unable to reproduce the bug",
|
|
300
|
-
error: "Could not find the reported behavior in the codebase",
|
|
301
|
-
};
|
|
302
|
-
|
|
303
|
-
expect(result.outcome).toBe("failure");
|
|
304
|
-
expect(result.summary).toBe("Unable to reproduce the bug");
|
|
305
|
-
expect(result.error).toBe("Could not find the reported behavior in the codebase");
|
|
306
|
-
});
|
|
307
|
-
|
|
308
|
-
it("represents partial completion", () => {
|
|
309
|
-
const result: WorkResult = {
|
|
310
|
-
outcome: "partial",
|
|
311
|
-
summary: "Implemented core feature but tests are failing",
|
|
312
|
-
details: "Feature implementation complete, but 3 tests need review",
|
|
313
|
-
error: "Test failures in integration tests",
|
|
314
|
-
};
|
|
315
|
-
|
|
316
|
-
expect(result.outcome).toBe("partial");
|
|
317
|
-
expect(result.error).toBeDefined();
|
|
318
|
-
});
|
|
319
|
-
|
|
320
|
-
it("supports all outcome types", () => {
|
|
321
|
-
const outcomes: WorkOutcome[] = ["success", "failure", "partial"];
|
|
322
|
-
outcomes.forEach((outcome) => {
|
|
323
|
-
const result: WorkResult = {
|
|
324
|
-
outcome,
|
|
325
|
-
summary: "Test summary",
|
|
326
|
-
};
|
|
327
|
-
expect(result.outcome).toBe(outcome);
|
|
328
|
-
});
|
|
329
|
-
});
|
|
330
|
-
|
|
331
|
-
it("has optional details and artifacts", () => {
|
|
332
|
-
const result: WorkResult = {
|
|
333
|
-
outcome: "success",
|
|
334
|
-
summary: "Quick fix",
|
|
335
|
-
};
|
|
336
|
-
|
|
337
|
-
expect(result.details).toBeUndefined();
|
|
338
|
-
expect(result.artifacts).toBeUndefined();
|
|
339
|
-
});
|
|
340
|
-
});
|
|
341
|
-
|
|
342
|
-
// =============================================================================
|
|
343
|
-
// ReleaseOptions and ReleaseResult type tests
|
|
344
|
-
// =============================================================================
|
|
345
|
-
|
|
346
|
-
describe("ReleaseOptions", () => {
|
|
347
|
-
it("supports reason and comment options", () => {
|
|
348
|
-
const options: ReleaseOptions = {
|
|
349
|
-
reason: "Agent timeout",
|
|
350
|
-
addComment: true,
|
|
351
|
-
};
|
|
352
|
-
|
|
353
|
-
expect(options.reason).toBe("Agent timeout");
|
|
354
|
-
expect(options.addComment).toBe(true);
|
|
355
|
-
});
|
|
356
|
-
|
|
357
|
-
it("allows empty options", () => {
|
|
358
|
-
const options: ReleaseOptions = {};
|
|
359
|
-
expect(options.reason).toBeUndefined();
|
|
360
|
-
expect(options.addComment).toBeUndefined();
|
|
361
|
-
});
|
|
362
|
-
});
|
|
363
|
-
|
|
364
|
-
describe("ReleaseResult", () => {
|
|
365
|
-
it("represents successful release", () => {
|
|
366
|
-
const result: ReleaseResult = {
|
|
367
|
-
success: true,
|
|
368
|
-
};
|
|
369
|
-
|
|
370
|
-
expect(result.success).toBe(true);
|
|
371
|
-
expect(result.message).toBeUndefined();
|
|
372
|
-
});
|
|
373
|
-
|
|
374
|
-
it("represents failed release", () => {
|
|
375
|
-
const result: ReleaseResult = {
|
|
376
|
-
success: false,
|
|
377
|
-
message: "Work item was already completed by another agent",
|
|
378
|
-
};
|
|
379
|
-
|
|
380
|
-
expect(result.success).toBe(false);
|
|
381
|
-
expect(result.message).toBe("Work item was already completed by another agent");
|
|
382
|
-
});
|
|
383
|
-
});
|
|
384
|
-
|
|
385
|
-
// =============================================================================
|
|
386
|
-
// WorkSource interface tests
|
|
387
|
-
// =============================================================================
|
|
388
|
-
|
|
389
|
-
describe("WorkSourceAdapter interface", () => {
|
|
390
|
-
it("defines required interface shape", () => {
|
|
391
|
-
// This test verifies the interface contract at compile time
|
|
392
|
-
// and provides a reference implementation for documentation
|
|
393
|
-
const mockWorkSource: WorkSourceAdapter = {
|
|
394
|
-
type: "mock",
|
|
395
|
-
|
|
396
|
-
async fetchAvailableWork(options?: FetchOptions): Promise<FetchResult> {
|
|
397
|
-
return { items: [] };
|
|
398
|
-
},
|
|
399
|
-
|
|
400
|
-
async claimWork(workItemId: string): Promise<ClaimResult> {
|
|
401
|
-
return { success: true };
|
|
402
|
-
},
|
|
403
|
-
|
|
404
|
-
async completeWork(workItemId: string, result: WorkResult): Promise<void> {
|
|
405
|
-
// Implementation would update external system
|
|
406
|
-
},
|
|
407
|
-
|
|
408
|
-
async releaseWork(
|
|
409
|
-
workItemId: string,
|
|
410
|
-
options?: ReleaseOptions
|
|
411
|
-
): Promise<ReleaseResult> {
|
|
412
|
-
return { success: true };
|
|
413
|
-
},
|
|
414
|
-
|
|
415
|
-
async getWork(workItemId: string): Promise<WorkItem | undefined> {
|
|
416
|
-
return undefined;
|
|
417
|
-
},
|
|
418
|
-
};
|
|
419
|
-
|
|
420
|
-
expect(mockWorkSource.type).toBe("mock");
|
|
421
|
-
expect(typeof mockWorkSource.fetchAvailableWork).toBe("function");
|
|
422
|
-
expect(typeof mockWorkSource.claimWork).toBe("function");
|
|
423
|
-
expect(typeof mockWorkSource.completeWork).toBe("function");
|
|
424
|
-
expect(typeof mockWorkSource.releaseWork).toBe("function");
|
|
425
|
-
expect(typeof mockWorkSource.getWork).toBe("function");
|
|
426
|
-
});
|
|
427
|
-
|
|
428
|
-
it("supports async workflow operations", async () => {
|
|
429
|
-
// Simulates a full workflow using the interface
|
|
430
|
-
const mockItem: WorkItem = {
|
|
431
|
-
id: "mock-1",
|
|
432
|
-
source: "mock",
|
|
433
|
-
externalId: "1",
|
|
434
|
-
title: "Test task",
|
|
435
|
-
description: "A test task",
|
|
436
|
-
priority: "medium",
|
|
437
|
-
labels: [],
|
|
438
|
-
metadata: {},
|
|
439
|
-
url: "https://example.com/1",
|
|
440
|
-
createdAt: new Date(),
|
|
441
|
-
updatedAt: new Date(),
|
|
442
|
-
};
|
|
443
|
-
|
|
444
|
-
const mockWorkSource: WorkSourceAdapter = {
|
|
445
|
-
type: "mock",
|
|
446
|
-
async fetchAvailableWork() {
|
|
447
|
-
return { items: [mockItem] };
|
|
448
|
-
},
|
|
449
|
-
async claimWork(id: string) {
|
|
450
|
-
return { success: true, workItem: mockItem };
|
|
451
|
-
},
|
|
452
|
-
async completeWork() {},
|
|
453
|
-
async releaseWork() {
|
|
454
|
-
return { success: true };
|
|
455
|
-
},
|
|
456
|
-
async getWork(id: string) {
|
|
457
|
-
return id === mockItem.id ? mockItem : undefined;
|
|
458
|
-
},
|
|
459
|
-
};
|
|
460
|
-
|
|
461
|
-
// Fetch
|
|
462
|
-
const fetchResult = await mockWorkSource.fetchAvailableWork();
|
|
463
|
-
expect(fetchResult.items).toHaveLength(1);
|
|
464
|
-
|
|
465
|
-
// Claim
|
|
466
|
-
const claimResult = await mockWorkSource.claimWork(fetchResult.items[0].id);
|
|
467
|
-
expect(claimResult.success).toBe(true);
|
|
468
|
-
|
|
469
|
-
// Complete
|
|
470
|
-
await mockWorkSource.completeWork(mockItem.id, {
|
|
471
|
-
outcome: "success",
|
|
472
|
-
summary: "Done",
|
|
473
|
-
});
|
|
474
|
-
|
|
475
|
-
// Get
|
|
476
|
-
const retrieved = await mockWorkSource.getWork(mockItem.id);
|
|
477
|
-
expect(retrieved).toBe(mockItem);
|
|
478
|
-
});
|
|
479
|
-
});
|