-
-
Notifications
You must be signed in to change notification settings - Fork 376
/
client.test.js
74 lines (60 loc) 路 2.01 KB
/
client.test.js
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
const { join } = require('path');
const startChrome = require('./lib/chrome');
const { subject } = require('./lib/output');
const { sleep } = require('./lib/utils');
const { build } = require('./lib/cli');
const { getServer } = require('./server');
const getPort = require('get-port');
let chrome;
let PORT;
describe('client-side tests', () => {
beforeAll(async () => {
chrome = await startChrome();
});
afterAll(async () => {
await chrome.close();
});
beforeEach(async () => {
PORT = await getPort();
});
it('should hydrate routes progressively with preact8.', async () => {
let dir = await subject('progressive-hydration-preact8');
await build(dir, {}, true);
const server = getServer(join(dir, 'build'), PORT);
// let page = await loadPage(chrome, `http://127.0.0.1:${PORT}/`);
const page = await chrome.newPage();
page.on('console', consoleMessage => {
// eslint-disable-next-line
console[consoleMessage.type()](consoleMessage.text());
});
await page.goto(`http://127.0.0.1:${PORT}/`);
// await waitUntilExpression(page, `window.booted`);
await sleep(500);
const mutations = await page.evaluate('window.ROOT_MUTATION_COUNT');
expect(mutations).toEqual(0);
expect(await page.evaluate('window.CHANGED_VAR')).toEqual(undefined);
await page.click('button');
expect(await page.evaluate('window.CHANGED_VAR')).toEqual(1);
server.server.close();
});
it('should hydrate for pre-rendered URLs only', async () => {
let dir = await subject('prerendering-hydration');
await build(dir, {});
const server = getServer(join(dir, 'build'), PORT, true);
const page = await chrome.newPage();
await page.goto(`http://127.0.0.1:${PORT}/`);
await sleep(500);
expect(
await page.evaluate(
'document.querySelector("div").getAttribute("rendered-on")'
)
).toEqual('server');
await page.goto(`http://127.0.0.1:${PORT}/foo`);
expect(
await page.evaluate(
'document.querySelector("div").getAttribute("rendered-on")'
)
).toEqual('client');
server.server.close();
});
});