import {Et2InputWidgetInterface} from "../Et2InputWidget"; import {assert, elementUpdated} from "@open-wc/testing"; /** * Some basic, common tests that any decent input widget should pass * * Have your widget creation in a separate function, and pass it in along with a "good" value. * Checking "bad" values and error conditions are widget-specific, so you have to handle those in your own tests. * This is just a starting point, and to make sure that if a widget doesn't pass these, there's something * wrong. * * @example * async function before() * { * // Create an element to test with, and wait until it's ready * // @ts-ignore * element = await fixture(html` * * `); * } * inputBasicTests(before, "2008-09-22T00:00:00.000Z", "input"); * * @param {Function} beforeEach function to create / setup the widget * @param {string} test_value A "good" value * @param {string} value_selector Passed to document.querySelector() to check that the value is displayed */ // Widget used in each test let element : Et2InputWidgetInterface; export function inputBasicTests(before : Function, test_value : string, value_selector : string) { describe("Readonly tests", () => { beforeEach(async() => { element = await before(); }); it('Does not return a value (via attribute)', async() => { element.readOnly = true; element.set_value(test_value); // wait for asychronous changes to the DOM await elementUpdated(element); // Read-only widget returns null assert.equal(element.getValue(), null); }); it('Does not return a value (via method)', async() => { (element).set_readonly(true); element.set_value(test_value); // wait for asychronous changes to the DOM await elementUpdated(element); // Read-only widget returns null assert.equal(element.getValue(), null); }); it('Does not return a value if it goes readonly after having a value', async() => { element.set_value(test_value); element.set_readonly(true); // wait for asychronous changes to the DOM await elementUpdated(element); // Read-only widget returns null assert.equal(element.getValue(), null); }); }); describe("In/Out value tests", () => { beforeEach(async() => { element = await before(); }); it('No value shows no value', () => { assert.equal((element).querySelector(value_selector).textContent, ""); assert.equal(element.get_value(), null); }); it('Value out matches value in', async() => { element.set_value(test_value); // wait for asychronous changes to the DOM await elementUpdated(element); // widget returns what we gave it assert.equal(element.get_value(), test_value); }); }) }