mirror of
https://github.com/tenrok/OverlayScrollbars.git
synced 2026-05-17 03:59:39 +03:00
124 lines
2.8 KiB
TypeScript
124 lines
2.8 KiB
TypeScript
import { attr, removeAttr, val, scrollLeft, scrollTop } from 'support/dom/attribute';
|
|
|
|
const testElm = document.body;
|
|
const setAttribute = (name: string, value: string) => {
|
|
testElm.setAttribute(name, value);
|
|
};
|
|
const setScrollLeft = (value: number) => {
|
|
testElm.scrollLeft = value;
|
|
};
|
|
const setScrollTop = (value: number) => {
|
|
testElm.scrollTop = value;
|
|
};
|
|
const removeAttribute = (name: string) => {
|
|
testElm.removeAttribute(name);
|
|
};
|
|
|
|
describe('dom attributes', () => {
|
|
describe('attr', () => {
|
|
test('get', () => {
|
|
const attrName = 'data-test-get';
|
|
|
|
setAttribute(attrName, '123');
|
|
expect(attr(testElm, attrName)).toBe('123');
|
|
|
|
setAttribute(attrName, 'abc');
|
|
expect(attr(testElm, attrName)).toBe('abc');
|
|
|
|
removeAttribute(attrName);
|
|
});
|
|
|
|
test('set', () => {
|
|
const attrName = 'data-test-set';
|
|
|
|
attr(testElm, attrName, '123');
|
|
expect(attr(testElm, attrName)).toBe('123');
|
|
|
|
attr(testElm, attrName, 'abc');
|
|
expect(attr(testElm, attrName)).toBe('abc');
|
|
|
|
removeAttribute(attrName);
|
|
});
|
|
|
|
test('null', () => {
|
|
expect(attr(null, 'hi')).toBe(null);
|
|
expect(attr(null, 'hi', '123')).toBe(undefined);
|
|
});
|
|
});
|
|
|
|
describe('scrollLeft', () => {
|
|
test('get', () => {
|
|
setScrollLeft(100);
|
|
expect(scrollLeft(testElm)).toBe(100);
|
|
setScrollLeft(0);
|
|
});
|
|
|
|
test('set', () => {
|
|
scrollLeft(testElm, 100);
|
|
expect(scrollLeft(testElm)).toBe(100);
|
|
setScrollLeft(0);
|
|
});
|
|
|
|
test('null', () => {
|
|
expect(scrollLeft(null)).toBe(0);
|
|
expect(scrollLeft(null, 0)).toBe(undefined);
|
|
});
|
|
});
|
|
|
|
describe('scrollTop', () => {
|
|
test('get', () => {
|
|
setScrollTop(100);
|
|
expect(scrollTop(testElm)).toBe(100);
|
|
setScrollTop(0);
|
|
});
|
|
|
|
test('set', () => {
|
|
scrollTop(testElm, 100);
|
|
expect(scrollTop(testElm)).toBe(100);
|
|
setScrollTop(0);
|
|
});
|
|
|
|
test('null', () => {
|
|
expect(scrollTop(null)).toBe(0);
|
|
expect(scrollTop(null, 0)).toBe(undefined);
|
|
});
|
|
});
|
|
|
|
describe('val', () => {
|
|
const input = document.createElement('input');
|
|
|
|
test('get', () => {
|
|
input.value = 'hi';
|
|
expect(val(input)).toBe('hi');
|
|
input.value = '';
|
|
});
|
|
|
|
test('set', () => {
|
|
val(input, 'hi2');
|
|
expect(val(input)).toBe('hi2');
|
|
val(input, '');
|
|
expect(val(input)).toBe('');
|
|
});
|
|
|
|
test('null', () => {
|
|
expect(val(null)).toBe('');
|
|
expect(val(null, '123')).toBe(undefined);
|
|
});
|
|
});
|
|
|
|
describe('remove attribute', () => {
|
|
test('normal', () => {
|
|
const attrName = 'data-test-remove';
|
|
|
|
setAttribute(attrName, '123');
|
|
removeAttr(testElm, attrName);
|
|
|
|
expect(attr(testElm, attrName)).toBeNull();
|
|
});
|
|
|
|
test('null', () => {
|
|
expect(removeAttr(null, 'hi')).toBe(undefined);
|
|
});
|
|
});
|
|
});
|