-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Expand file tree
/
Copy pathstreaming_fidelity.test.ts
More file actions
113 lines (91 loc) · 4.2 KB
/
streaming_fidelity.test.ts
File metadata and controls
113 lines (91 loc) · 4.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
*--------------------------------------------------------------------------------------------*/
import { describe, expect, it, onTestFinished } from "vitest";
import { CopilotClient, SessionEvent, approveAll } from "../../src/index.js";
import { createSdkTestContext, isCI } from "./harness/sdkTestContext";
describe("Streaming Fidelity", async () => {
const { copilotClient: client, env } = await createSdkTestContext();
it("should produce delta events when streaming is enabled", async () => {
const session = await client.createSession({
onPermissionRequest: approveAll,
streaming: true,
});
const events: SessionEvent[] = [];
session.on((event) => {
events.push(event);
});
await session.sendAndWait({
prompt: "Count from 1 to 5, separated by commas.",
});
const types = events.map((e) => e.type);
// Should have streaming deltas before the final message
const deltaEvents = events.filter((e) => e.type === "assistant.message_delta");
expect(deltaEvents.length).toBeGreaterThanOrEqual(1);
// Deltas should have content
for (const delta of deltaEvents) {
expect(delta.data.deltaContent).toBeDefined();
expect(typeof delta.data.deltaContent).toBe("string");
}
// Should still have a final assistant.message
expect(types).toContain("assistant.message");
// Deltas should come before the final message
const firstDeltaIdx = types.indexOf("assistant.message_delta");
const lastAssistantIdx = types.lastIndexOf("assistant.message");
expect(firstDeltaIdx).toBeLessThan(lastAssistantIdx);
await session.disconnect();
});
it("should not produce deltas when streaming is disabled", async () => {
const session = await client.createSession({
onPermissionRequest: approveAll,
streaming: false,
});
const events: SessionEvent[] = [];
session.on((event) => {
events.push(event);
});
await session.sendAndWait({
prompt: "Say 'hello world'.",
});
const deltaEvents = events.filter((e) => e.type === "assistant.message_delta");
// No deltas when streaming is off
expect(deltaEvents.length).toBe(0);
// But should still have a final assistant.message
const assistantEvents = events.filter((e) => e.type === "assistant.message");
expect(assistantEvents.length).toBeGreaterThanOrEqual(1);
await session.disconnect();
});
it("should produce deltas after session resume", async () => {
const session = await client.createSession({
onPermissionRequest: approveAll,
streaming: false,
});
await session.sendAndWait({ prompt: "What is 3 + 6?" });
await session.disconnect();
// Resume using a new client
const newClient = new CopilotClient({
env,
githubToken: isCI ? "fake-token-for-e2e-tests" : undefined,
});
onTestFinished(() => newClient.forceStop());
const session2 = await newClient.resumeSession(session.sessionId, {
onPermissionRequest: approveAll,
streaming: true,
});
const events: SessionEvent[] = [];
session2.on((event) => events.push(event));
const secondAssistantMessage = await session2.sendAndWait({
prompt: "Now if you double that, what do you get?",
});
expect(secondAssistantMessage?.data.content).toContain("18");
// Should have streaming deltas before the final message
const deltaEvents = events.filter((e) => e.type === "assistant.message_delta");
expect(deltaEvents.length).toBeGreaterThanOrEqual(1);
// Deltas should have content
for (const delta of deltaEvents) {
expect(delta.data.deltaContent).toBeDefined();
expect(typeof delta.data.deltaContent).toBe("string");
}
await session2.disconnect();
});
});