-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathToggle.test.mjs
73 lines (67 loc) · 1.78 KB
/
Toggle.test.mjs
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
// @ts-check
import React from "react";
import ReactDOMServer from "react-dom/server";
import assertSnapshot from "snapshot-assertion";
import assertBundleSize from "./test/assertBundleSize.mjs";
import Toggle from "./Toggle.mjs";
/**
* Adds `Toggle` tests.
* @param {import("test-director").default} tests Test director.
*/
export default (tests) => {
tests.add("`Toggle` bundle size.", async () => {
await assertBundleSize(new URL("./Toggle.mjs", import.meta.url), 850);
});
tests.add("`Toggle` with minimal props, checkbox input.", async () => {
await assertSnapshot(
ReactDOMServer.renderToStaticMarkup(
React.createElement(Toggle, {
inputProps: {
type: "checkbox",
},
})
),
new URL(
"./test/snapshots/Toggle/minimal-props-checkbox.html",
import.meta.url
)
);
});
tests.add("`Toggle` with minimal props, radio input.", async () => {
await assertSnapshot(
ReactDOMServer.renderToStaticMarkup(
React.createElement(Toggle, {
inputProps: {
type: "checkbox",
},
})
),
new URL(
"./test/snapshots/Toggle/minimal-props-radio.html",
import.meta.url
)
);
});
tests.add("`Toggle` with props.", async () => {
await assertSnapshot(
ReactDOMServer.renderToStaticMarkup(
React.createElement(
Toggle,
{
className: "a",
id: "b",
["data-c"]: "d",
inputProps: {
type: "checkbox",
className: "e",
id: "f",
["data-g"]: "h",
},
},
"Label."
)
),
new URL("./test/snapshots/Toggle/with-props.html", import.meta.url)
);
});
};