/** * Test file for Etemplate webComponent Select * * In here we test just the simple, basic widget stuff. */ // Stub global egw for cssImage to find // @ts-ignore window.egw = { image: () => "" }; import {assert, fixture} from '@open-wc/testing'; import {html} from "lit-element"; import * as sinon from 'sinon'; import {inputBasicTests} from "../../Et2InputWidget/test/InputBasicTests"; import {Et2Select} from "../Et2Select"; let element : Et2Select; async function before() { // Create an element to test with, and wait until it's ready // @ts-ignore 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 }); return element; } describe("Select widget basics", () => { // Setup run before each test beforeEach(before); // Make sure it works it('is defined', () => { assert.instanceOf(element, Et2Select); }); it('has a label', () => { element.set_label("Label set"); assert.equal(element.querySelector("[slot='label']").textContent, "Label set"); }) it("starts empty", () => { assert.notExists(element.querySelector("option"), "Static option not found in DOM"); assert.deepEqual(element.get_select_options(), [], "Unexpected option(s)"); }) }); inputBasicTests(before, "", "select");