-
Notifications
You must be signed in to change notification settings - Fork 0
/
html_sync.test.ts
41 lines (34 loc) · 1.15 KB
/
html_sync.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
import { assertStrictEq, prepareTest } from "../test.mod.ts";
import { helloWorld, peopleList } from "./CONSTANTS.ts";
import { htmlSync as html } from "./mod.ts";
function willRender() {
assertStrictEq(
html`${helloWorld}`,
`<!DOCTYPE html><html><head></head><body><h1>Hello, World!</h1></body></html>`
);
}
function willRenderWithSyncTasks() {
const syncTask = () => helloWorld;
const syncLiteral = "John Doe";
assertStrictEq(
html`<section>${syncTask}<h2>${syncLiteral}</h2></section>`,
// tslint:disable-next-line: max-line-length
`<!DOCTYPE html><html><head></head><body><section><h1>Hello, World!</h1><h2>John Doe</h2></section></body></html>`
);
}
function willRenderAListOfSyncTasks() {
assertStrictEq(
html`${helloWorld}<ul>${peopleList.map(n => `<li>${n}</li>`)}</ul>`,
// tslint:disable-next-line: max-line-length
`<!DOCTYPE html><html><head></head><body><h1>Hello, World!</h1><ul><li>John Doe</li><li>Michael CEO</li><li>Vict Fisherman</li><li>Cash Black</li></ul></body></html>`
);
}
prepareTest(
[
willRender,
willRenderAListOfSyncTasks,
willRenderWithSyncTasks
],
"lit_ntml",
"htmlSync"
);