2022-05-13 08:08:49 -04:00
|
|
|
import { setHTMLFixture, resetHTMLFixture } from 'helpers/fixtures';
|
2020-09-25 17:09:51 -04:00
|
|
|
import { loadStartupCSS } from '~/behaviors/load_startup_css';
|
|
|
|
|
|
|
|
describe('behaviors/load_startup_css', () => {
|
|
|
|
let loadListener;
|
|
|
|
|
|
|
|
const setupListeners = () => {
|
|
|
|
document
|
|
|
|
.querySelectorAll('link')
|
2020-12-23 16:10:24 -05:00
|
|
|
.forEach((x) => x.addEventListener('load', () => loadListener(x)));
|
2020-09-25 17:09:51 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
loadListener = jest.fn();
|
|
|
|
|
|
|
|
setHTMLFixture(`
|
|
|
|
<meta charset="utf-8" />
|
|
|
|
<link media="print" src="./lorem-print.css" />
|
|
|
|
<link media="print" src="./ipsum-print.css" />
|
|
|
|
<link media="all" src="./dolar-all.css" />
|
|
|
|
`);
|
|
|
|
|
|
|
|
setupListeners();
|
|
|
|
|
|
|
|
loadStartupCSS();
|
|
|
|
});
|
|
|
|
|
2022-05-13 08:08:49 -04:00
|
|
|
afterEach(() => {
|
|
|
|
resetHTMLFixture();
|
|
|
|
});
|
|
|
|
|
2020-09-25 17:09:51 -04:00
|
|
|
it('does nothing at first', () => {
|
|
|
|
expect(loadListener).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('on window load', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
window.dispatchEvent(new Event('load'));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('dispatches load to the print links', () => {
|
|
|
|
expect(loadListener.mock.calls.map(([el]) => el.getAttribute('src'))).toEqual([
|
|
|
|
'./lorem-print.css',
|
|
|
|
'./ipsum-print.css',
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|