Skip to content

Instantly share code, notes, and snippets.

@YonatanKra
Created October 21, 2018 13:30
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save YonatanKra/11ff862993352301e8f195291dfa3488 to your computer and use it in GitHub Desktop.
Save YonatanKra/11ff862993352301e8f195291dfa3488 to your computer and use it in GitHub Desktop.
import { CEModalWindow } from './ce-modal-window';
window.customElements.define('ce-tested-modal-window', CEModalWindow);
describe('app integration tests', () => {
let element, shadowRoot;
beforeEach(() => {
element = document.createElement('ce-tested-modal-window');
shadowRoot = element.shadowRoot;
document.body.append(element);
});
// check that the exposed API works
describe('init', () => {
it('should add a div with the overlay and overlay-hidden classes under the shadow root', () => {
expect(shadowRoot.querySelector('.overlay.overlay-hidden')).toBeTruthy();
});
});
describe('open', () => {
it('should remove the hidden class from overlay', () => {
const overlay = shadowRoot.querySelector('.overlay.overlay-hidden');
element.open({});
expect(overlay.classList.contains('overlay-hidden')).toBeFalsy();
});
it('should add class transparent to the overlay if config.hideOverlay is true', () => {
const overlay = shadowRoot.querySelector('.overlay.overlay-hidden');
element.open({
hideOverlay: true
});
expect(overlay.classList.contains('transparent')).toBeFalsy();
});
it('should insert the content string as HTML to the content element', () => {
const randId = Math.random().toString(2);
const content = shadowRoot.querySelector('.overlay-content');
const htmlBefore = content.innerHTML;
const config = {
content: `<div id="${randId}">Hello CE!</div>`
};
element.open(config);
expect(htmlBefore).toEqual("");
expect(content.innerHTML).toEqual(config.content);
});
it('should set width and height according to config values', () => {
const content = shadowRoot.querySelector('.overlay-content');
const config = {
height: Math.round(Math.random() * 100 + 50),
width: Math.round(Math.random() * 100 + 50)
};
element.open(config);
const overlayBoundingBox = content.getBoundingClientRect();
expect(overlayBoundingBox.width).toEqual(config.width);
expect(overlayBoundingBox.height).toEqual(config.height);
});
});
describe('close', () => {
it('should add the overlay-hidden class', () => {
const overlay = shadowRoot.querySelector('.overlay');
element.open({}); // we already know it removes the class
element.close();
expect(overlay.classList.contains('overlay-hidden'));
});
});
afterEach(() => {
document.body.removeChild(element);
})
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment