Files
OverlayScrollbars/packages/overlayscrollbars/tests/jest/support/dom/class.test.ts
T
Rene Haas 0e0deb8550 fix test
2022-07-02 11:49:07 +02:00

125 lines
3.4 KiB
TypeScript

import { addClass, removeClass, hasClass, diffClass } from 'support/dom/class';
const testElm = document.body;
const removeAllClassNames = () => {
while (testElm.classList.length > 0) {
const classToRemove = testElm.classList.item(0);
if (classToRemove) {
testElm.classList.remove(classToRemove);
}
}
};
const hasClassName = (className: string) => testElm.classList.contains(className);
describe('dom class names', () => {
afterEach(() => {
removeAllClassNames();
});
describe('add', () => {
test('none', () => {
addClass(testElm, '');
// @ts-ignore
addClass(testElm, null);
// @ts-ignore
addClass(testElm, 2);
expect(testElm.classList.length).toBe(0);
});
test('single', () => {
const remove = addClass(testElm, 'test-class');
expect(hasClassName('test-class')).toBe(true);
remove();
expect(hasClassName('test-class')).toBe(false);
});
test('multiple', () => {
const remove = addClass(testElm, 'test-class test-class2');
expect(hasClassName('test-class')).toBe(true);
expect(hasClassName('test-class2')).toBe(true);
remove();
expect(hasClassName('test-class')).toBe(false);
expect(hasClassName('test-class2')).toBe(false);
});
test('null', () => {
expect(typeof addClass(null, 'abc')).toBe('function');
});
});
describe('remove', () => {
test('none', () => {
addClass(testElm, 'test-class');
removeClass(testElm, '');
// @ts-ignore
removeClass(testElm, null);
// @ts-ignore
removeClass(testElm, 2);
expect(testElm.classList.length).toBe(1);
});
test('single', () => {
addClass(testElm, 'test-class');
expect(hasClassName('test-class')).toBe(true);
removeClass(testElm, 'test-class');
expect(hasClassName('test-class')).toBe(false);
});
test('multiple', () => {
addClass(testElm, 'test-class test-class2');
removeClass(testElm, 'test-class test-class2');
expect(hasClassName('test-class')).toBe(false);
expect(hasClassName('test-class2')).toBe(false);
});
test('null', () => {
expect(removeClass(null, 'abc')).toBe(undefined);
});
});
describe('has', () => {
test('none', () => {
expect(hasClass(testElm, '')).toBe(false);
});
test('single', () => {
addClass(testElm, 'test-class');
expect(hasClass(testElm, 'test-class')).toBe(true);
});
test('multiple', () => {
addClass(testElm, 'test-class test-class2');
expect(hasClass(testElm, 'test-class test-class2')).toBe(true);
expect(hasClass(testElm, 'test-class test-class2 test-class3')).toBe(false);
});
test('null', () => {
expect(hasClass(null, 'abc')).toBe(false);
});
});
describe('diff', () => {
test('none', () => {
expect(diffClass('', '')).toEqual([]);
});
test('single', () => {
expect(diffClass('test', '')).toEqual(['test']);
expect(diffClass('', 'test')).toEqual(['test']);
});
test('multiple', () => {
expect(diffClass('a b c d', 'a c')).toEqual(['b', 'd']);
expect(diffClass('d b', 'a b c d')).toEqual(['a', 'c']);
});
test('null', () => {
expect(diffClass(null, null)).toEqual([]);
expect(diffClass('a c', null)).toEqual(['a', 'c']);
expect(diffClass('d b', null)).toEqual(['d', 'b']);
});
});
});