forked from CopilotKit/CopilotKit
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdeclarative-json-render.spec.ts
More file actions
76 lines (65 loc) · 2.6 KB
/
Copy pathdeclarative-json-render.spec.ts
File metadata and controls
76 lines (65 loc) · 2.6 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
import { test, expect } from "@playwright/test";
/**
* E2E spec for the Declarative UI: json-render demo. Structurally
* mirrors `gen-ui-tool-based.spec.ts` so the dashboard's BYOC rows
* exercise the same surfaces (json-render-root + metric-card + chart).
*/
test.describe("Declarative UI: json-render", () => {
test.beforeEach(async ({ page }) => {
await page.goto("/demos/declarative-json-render");
});
test("page loads with chat composer and suggestion pills", async ({
page,
}) => {
// Chat composer
await expect(
page.locator('textarea, [placeholder*="message"]').first(),
).toBeVisible({ timeout: 10000 });
// Suggestion pills driven by useConfigureSuggestions. The
// CopilotChat welcome screen renders titles as buttons/links.
await expect(page.getByText("Sales dashboard")).toBeVisible({
timeout: 10000,
});
await expect(page.getByText("Revenue by category")).toBeVisible();
await expect(page.getByText("Expense trend")).toBeVisible();
});
test("sales dashboard request renders a json-render tree", async ({
page,
}) => {
const input = page.locator('textarea, [placeholder*="message"]').first();
await input.fill(
"Show me the sales dashboard with metrics and a revenue chart",
);
await input.press("Enter");
// The JsonRenderAssistantMessage slot wraps renders in this testid.
await expect(
page.locator('[data-testid="json-render-root"]').first(),
).toBeVisible({ timeout: 60000 });
// A MetricCard should appear in the rendered tree.
await expect(
page.locator('[data-testid="metric-card"]').first(),
).toBeVisible({ timeout: 60000 });
// ...plus at least one chart (either shape).
await expect(
page
.locator('[data-testid="bar-chart"], [data-testid="pie-chart"]')
.first(),
).toBeVisible({ timeout: 60000 });
});
test("revenue-by-category request renders a pie chart", async ({ page }) => {
const input = page.locator('textarea, [placeholder*="message"]').first();
await input.fill("Break down revenue by category as a pie chart");
await input.press("Enter");
await expect(page.locator('[data-testid="pie-chart"]').first()).toBeVisible(
{ timeout: 60000 },
);
});
test("expense-trend request renders a bar chart", async ({ page }) => {
const input = page.locator('textarea, [placeholder*="message"]').first();
await input.fill("Show me monthly expenses as a bar chart");
await input.press("Enter");
await expect(page.locator('[data-testid="bar-chart"]').first()).toBeVisible(
{ timeout: 60000 },
);
});
});