/** * 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: () => "", lang: i => i + "*", tooltipUnbind: () => {}, webserverUrl: "" }; import {assert, elementUpdated, fixture, html} from '@open-wc/testing'; 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(window.egw); 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', async() => { element.set_label("Label set"); // @ts-ignore TypeScript doesn't recognize widgets as Elements await elementUpdated(element); 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.select_options, [], "Unexpected option(s)"); }) }); inputBasicTests(before, "", "select");