/
islands_test.ts
83 lines (70 loc) · 2.44 KB
/
islands_test.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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import {
assert,
assertStringIncludes,
delay,
puppeteer,
TextLineStream,
} from "./deps.ts";
Deno.test({
name: "island tests",
async fn(t) {
// Preparation
const serverProcess = Deno.run({
cmd: ["deno", "run", "-A", "./tests/fixture/main.ts"],
stdout: "piped",
stderr: "inherit",
});
const decoder = new TextDecoderStream();
const lines = serverProcess.stdout.readable
.pipeThrough(decoder)
.pipeThrough(new TextLineStream());
let started = false;
for await (const line of lines) {
console.log(line);
if (line.includes("Server listening on http://")) {
started = true;
break;
}
}
if (!started) {
throw new Error("Server didn't start up");
}
await delay(100);
const browser = await puppeteer.launch({ args: ["--no-sandbox"] });
const page = await browser.newPage();
async function counterTest(counterId: string, originalValue: number) {
const pElem = await page.waitForSelector(`#${counterId} > p`);
let value = await pElem?.evaluate((el) => el.textContent);
assert(value === `${originalValue}`, `${counterId} first value`);
const buttonPlus = await page.$(`#b-${counterId}`);
await buttonPlus?.click();
value = await pElem?.evaluate((el) => el.textContent);
assert(value === `${originalValue + 1}`, `${counterId} click`);
}
await page.goto("http://localhost:8000/islands", {
waitUntil: "networkidle2",
});
await t.step("Ensure 2 islands on 1 page are revived", async () => {
await counterTest("counter1", 3);
await counterTest("counter2", 10);
});
await t.step("Ensure an island revive an img 'hash' path", async () => {
// Ensure src path has __frsh_c=
const pElem = await page.waitForSelector(`#img-in-island`);
const srcString = (await pElem?.getProperty("src"))?.toString()!;
assertStringIncludes(srcString, "image.png?__frsh_c=");
// Ensure src path is the same as server rendered
const resp = await fetch(new Request("http://localhost:8000/islands"));
const body = await resp.text();
const imgFilePath = body.match(/img id="img-in-island" src="(.*?)"/)
?.[1]!;
assertStringIncludes(srcString, imgFilePath);
});
await browser.close();
await lines.cancel();
serverProcess.kill("SIGTERM");
serverProcess.close();
},
sanitizeOps: false,
sanitizeResources: false,
});