/** * Test file for search actions. * Currently just checking to make sure onchange is only called once. */ import {SelectOption} from "../FindSelectOptions"; import {assert, elementUpdated, fixture, html} from '@open-wc/testing'; import * as sinon from 'sinon'; import {Et2Box} from "../../Layout/Et2Box/Et2Box"; import {Et2Select} from "../Et2Select"; // Stub global egw for cssImage to find // @ts-ignore window.egw = { //image: () => "", lang: i => i + "*", tooltipUnbind: () => {}, webserverUrl: "", window: window }; let parser = new window.DOMParser(); let container : Et2Box; const options = [ {value: "1", label: "Option 1"}, {value: "2", label: "Option 2"} ]; async function before() { // This stuff because otherwise Et2Select isn't actually loaded when testing let element = await fixture(html` `); // Stub egw() sinon.stub(element, "egw").returns(window.egw); assert.instanceOf(element, Et2Select); element.remove(); container = await fixture(html` `); // Stub egw() sinon.stub(container, "egw").returns(window.egw); assert.instanceOf(container, Et2Box); } describe("Search actions", () => { // Setup run before each test beforeEach(before); it('onChange is called when value changes', async() => { /** SETUP **/ // Create an element to test with, and wait until it's ready // Set onchange="true" to make sure something is set before we override it let node = '' + '' + '' + ''; container.loadFromXML(parser.parseFromString(node, "text/xml")); const change = sinon.spy(); let element = container.getWidgetById('select'); element.onchange = change; await elementUpdated(element); element.value = "two"; await elementUpdated(element); // For some reason in the test change gets called twice, even though in normal operation it gets called once. sinon.assert.called(change); }); });