/** * Test file for Etemplate webComponent Date */ import {assert, fixture} from '@open-wc/testing'; import {Et2Date} from "../Et2Date"; import {html} from "lit-element"; import * as sinon from 'sinon'; describe("Date widget", () => { // Reference to component under test let element : Et2Date; // Setup run before each test beforeEach(async() => { // 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 image: i => "" }); }); // Make sure it works it('is defined', () => { assert.instanceOf(element, Et2Date); }); it('has a label', () => { element.set_label("Label set"); assert.equal(element.querySelector("[slot='label']").textContent, "Label set"); }) const tz_list = ['US/Pacific','UTC','Australia/Adelaide']; for(let tz of tz_list) { // TODO: Figure out how to mock timezone... describe("Timezone: " + tz, () => { let test_time_string = '2008-09-22 12:00:00Z'; let test_time = new Date(test_time_string); it('Can accept a value', () => { element.set_value(test_time_string); // Widget gives time as a string so we can send to server assert(element.getValue(), test_time_string); }); }); } });