/** * Test file for Etemplate webComponent base widget Et2Box */ import {assert, fixture} from '@open-wc/testing'; import {Et2Button} from "../Et2Button"; import type {Et2Widget} from "../../Et2Widget/Et2Widget"; import {html} from "lit-element"; import * as sinon from 'sinon'; describe("Button widget", () => { // Reference to component under test let element : Et2Button; // Setup run before each test beforeEach(async() => { // Create an element to test with, and wait until it's ready element = await fixture(html` `); // 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, Et2Button); }); it('has a label', () => { element.set_label("Label set"); assert.equal(element.textContent, "Label set"); }) it("click happens", () => { // Setup let clickSpy = sinon.spy(); element.onclick = clickSpy; // Click element.dispatchEvent(new MouseEvent("click")); // Check for once & only once assert(clickSpy.calledOnce, "Click only once"); }) it("gets an icon", async() => { element.image = "check"; // Wait for the render to finish await element.updateComplete; let image = element.querySelectorAll("img"); assert.equal(image.length, 1); assert.equal(image[0].src, element.egw().image("check")); }) });