import {Et2Tag} from "../Tag/Et2Tag"; import {assert, elementUpdated, fixture, html, oneEvent} from '@open-wc/testing'; import * as sinon from 'sinon'; import {inputBasicTests} from "../../Et2InputWidget/test/InputBasicTests"; import {Et2Select} from "../Et2Select"; /** * 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: "" }; 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)"); }) }); describe("Multiple", () => { beforeEach(async() => { // Create an element to test with, and wait until it's ready // @ts-ignore element = await fixture(html` One Two `); element.set_value("one,two"); // Stub egw() sinon.stub(element, "egw").returns(window.egw); return element; }); it("Can remove tags", async() => { assert.equal(element.querySelectorAll("sl-menu-item").length, 2, "Did not find options"); assert.sameMembers(element.value, ["one", "two"]); let tags = element.shadowRoot.querySelectorAll('.select__tags > *'); // Await tags to render let tag_updates = [] element.shadowRoot.querySelectorAll(element.tagTag).forEach((t : Et2Tag) => tag_updates.push(t.updateComplete)); await Promise.all(tag_updates); assert.equal(tags.length, 2); assert.equal(tags[0].value, "one"); assert.equal(tags[1].value, "two"); // Set up listener const listener = oneEvent(element, "change"); // Click to remove first tag let removeButton = tags[0].shadowRoot.querySelector("[part='remove-button']"); assert.exists(removeButton, "Could not find tag remove button"); removeButton.dispatchEvent(new Event("click")); await listener; // Wait for widget to update await element.updateComplete; tag_updates = [] element.shadowRoot.querySelectorAll(element.tagTag).forEach((t : Et2Tag) => tag_updates.push(t.updateComplete)); await Promise.all(tag_updates); // Check assert.sameMembers(element.value, ["two"], "Removing tag did not remove value"); tags = element.shadowRoot.querySelectorAll('.select__tags > *'); assert.equal(tags.length, 1, "Removed tag is still there"); }); }); inputBasicTests(before, "", "select");