mirror of
https://github.com/hodgef/simple-keyboard.git
synced 2026-04-11 00:02:15 +08:00
75 lines
1.7 KiB
JavaScript
75 lines
1.7 KiB
JavaScript
import { setDOM } from '../../utils/TestUtility';
|
|
import ButtonThemeDemo from '../ButtonThemeDemo';
|
|
|
|
it('Demo will load', () => {
|
|
setDOM();
|
|
|
|
new ButtonThemeDemo();
|
|
});
|
|
|
|
it('Demo onDOMLoaded will work', () => {
|
|
setDOM();
|
|
|
|
const demo = new ButtonThemeDemo();
|
|
|
|
expect(demo.keyboard).toBeTruthy();
|
|
});
|
|
|
|
it('Demo onChange will work', () => {
|
|
setDOM();
|
|
|
|
const demo = new ButtonThemeDemo();
|
|
|
|
demo.onChange("test");
|
|
|
|
expect(document.body.querySelector('.input').value).toBe("test");
|
|
});
|
|
|
|
it('Demo onChange will work', () => {
|
|
setDOM();
|
|
|
|
const demo = new ButtonThemeDemo();
|
|
|
|
demo.keyboard.getButtonElement("q").onclick();
|
|
|
|
expect(document.body.querySelector('.input').value).toBe("q");
|
|
});
|
|
|
|
it('Demo input change will work', () => {
|
|
setDOM();
|
|
|
|
const demo = new ButtonThemeDemo();
|
|
|
|
document.body.querySelector('.input').value = "test";
|
|
document.body.querySelector('.input').dispatchEvent(new Event('input'));
|
|
|
|
expect(demo.keyboard.getInput()).toBe("test");
|
|
});
|
|
|
|
it('Demo handleShiftButton will work', () => {
|
|
setDOM();
|
|
|
|
const demo = new ButtonThemeDemo();
|
|
|
|
demo.keyboard.getButtonElement("{shift}")[0].onclick();
|
|
expect(demo.keyboard.options.layoutName).toBe("shift");
|
|
|
|
demo.keyboard.getButtonElement("{shift}")[0].onclick();
|
|
expect(demo.keyboard.options.layoutName).toBe("default");
|
|
});
|
|
|
|
it('Demo buttons will have proper attributes and classes', () => {
|
|
setDOM();
|
|
|
|
const demo = new ButtonThemeDemo();
|
|
|
|
const buttonDOM = demo.keyboard.getButtonElement("b");
|
|
|
|
console.log("buttonDOM", buttonDOM.outerHTML);
|
|
|
|
const hasAttribute = buttonDOM.hasAttribute("aria-label");
|
|
expect(hasAttribute).toBeTruthy();
|
|
|
|
const hasClass = buttonDOM.classList.contains("my-button-outline");
|
|
expect(hasClass).toBeTruthy();
|
|
}); |