egroupware/api/js/etemplate/Et2Switch/test/Et2Switch.test.ts

91 lines
3.2 KiB
TypeScript
Raw Normal View History

2023-01-05 22:06:54 +01:00
/**
* Test file for Etemplate webComponent Et2Switch
*/
import {assert, expect, fixture, html, oneEvent} from '@open-wc/testing';
import * as sinon from 'sinon';
import {Et2Switch} from "../Et2Switch";
describe("Switch widget", () =>
{
// Reference to component under test
let element : Et2Switch;
// Setup run before each test
beforeEach(async() =>
{
// Create an element to test with, and wait until it's ready
element = await fixture<Et2Switch>(html`
<et2-switch label="I'm a switch"></et2-switch>
`);
// Stub egw()
sinon.stub(element, "egw").returns({
tooltipUnbind: () => {},
// Image always give check mark. Use data URL to avoid having to serve an actual image
image: i => ""
});
});
// Make sure it works
it('is defined', () =>
{
assert.instanceOf(element, Et2Switch);
});
it('has a label', () =>
{
element.set_label("Label set");
assert.equal(element.textContent.trim(), "Label set");
})
it("click happens", () =>
{
// Setup
let clickSpy = sinon.spy();
element.onclick = clickSpy;
// Click
element.click();
// Check for once & only once
assert(clickSpy.calledOnce, "Click only once");
});
it("change callback gets called on click", async() =>
{
// Note that we generally don't fire an actual change event
// Setup
const listener = oneEvent(element, "sl-change");
let clickSpy = sinon.spy();
element.onclick = clickSpy;
// Click
element.click();
const event = await listener;
assert(clickSpy.calledOnce, "onchange callback should be called only once");
});
it("shows 'on' label", async() =>
{
element.toggleOn = "On label";
await element.updateComplete;
const label = element.querySelector(".label .on");
expect(label).to.exist;
expect(label.textContent).to.equal("On label");
});
it("shows 'off' label", async() =>
{
element.toggleOff = "Off label";
await element.updateComplete;
const label = element.querySelector(".label .off");
expect(label).to.exist;
expect(label.textContent).to.equal("Off label");
});
});