-
Notifications
You must be signed in to change notification settings - Fork 31
/
banner.test.ts
43 lines (37 loc) · 1.34 KB
/
banner.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
import "../banner";
import "../button";
import "../icon";
import { assignedNodesMap, createContainer, removeContainer, waitForElement } from "../../test/testing-helpers";
import { Banner } from "./banner";
describe("wl-banner", () => {
const { expect } = chai;
let $banner: Banner;
let $container: HTMLElement;
before(() => {
$container = createContainer();
});
beforeEach(async () => {
$container.innerHTML = `
<wl-banner>
<wl-icon slot="icon">account_box</wl-icon>
<wl-button slot="action" flat inverted>Continue as guest</wl-button>
<wl-button slot="action" flat inverted>Sign in</wl-button>
<span>Your password was updated on your other device. Please sign in again.</span>
</wl-banner>`;
await waitForElement("wl-banner");
$banner = $container.querySelector<Banner>("wl-banner")!;
});
after(() => removeContainer($container));
it("should render the slots", async () => {
const assignedNodes = assignedNodesMap($banner.shadowRoot!);
expect(assignedNodes["icon"].length).to.be.above(0);
expect(assignedNodes["action"].length).to.be.above(0);
expect(assignedNodes[""].length).to.be.above(0);
});
/**
* ARIA TESTS: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/Banner_role
*/
it("should have a banner role", () => {
expect($banner.getAttribute("role")).to.equal("banner");
});
});