forked from angular-architects/ngrx-toolkit
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdevtools.spec.ts
62 lines (54 loc) · 1.59 KB
/
devtools.spec.ts
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
import { test, expect } from '@playwright/test';
import { Action } from '@ngrx/store';
test('has title', async ({ page }) => {
await page.goto('');
await page.evaluate(() => {
window['devtoolsSpy'] = [];
window['__REDUX_DEVTOOLS_EXTENSION__'] = {
connect: () => {
return {
send: (data: Action) => {
window['devtoolsSpy'].push(data);
},
};
},
};
});
await page.getByRole('link', { name: 'DevTools' }).click();
await page
.getByRole('row', { name: 'Go for a walk' })
.getByRole('checkbox')
.click();
await page
.getByRole('row', { name: 'Exercise' })
.getByRole('checkbox')
.click();
await expect(
page.getByRole('region', { name: 'Go for a walk' })
).toBeVisible();
await expect(page.getByRole('region', { name: 'Exercise' })).toBeVisible();
await page
.getByRole('row', { name: 'Go for a walk' })
.getByRole('checkbox')
.click();
await page
.getByRole('row', { name: 'Exercise' })
.getByRole('checkbox')
.click();
await expect(
page.getByRole('region', { name: 'Go for a walk' })
).toBeHidden();
await expect(page.getByRole('region', { name: 'Exercise' })).toBeHidden();
const devtoolsActions = await page.evaluate(() => window['devtoolsSpy']);
expect(devtoolsActions).toEqual([
{ type: 'add todo' },
{ type: 'select todo 1' },
{ type: 'Store Update' },
{ type: 'select todo 4' },
{ type: 'Store Update' },
{ type: 'select todo 1' },
{ type: 'Store Update' },
{ type: 'select todo 4' },
{ type: 'Store Update' },
]);
});