2020-03-20 15:07:47 +08:00
|
|
|
import { sleep } from '../../../tests/utils';
|
2022-06-22 14:57:09 +08:00
|
|
|
import scrollTo from '../scrollTo';
|
2019-07-24 22:56:20 +08:00
|
|
|
|
|
|
|
describe('Test ScrollTo function', () => {
|
2022-08-21 23:25:00 +08:00
|
|
|
let dateNowMock: jest.SpyInstance;
|
2019-08-08 20:32:06 +08:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
dateNowMock = jest
|
|
|
|
.spyOn(Date, 'now')
|
|
|
|
.mockImplementationOnce(() => 0)
|
|
|
|
.mockImplementationOnce(() => 1000);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
dateNowMock.mockRestore();
|
|
|
|
});
|
|
|
|
|
2019-07-24 22:56:20 +08:00
|
|
|
it('test scrollTo', async () => {
|
2022-08-21 23:25:00 +08:00
|
|
|
const scrollToSpy = jest.spyOn(window, 'scrollTo').mockImplementation((_, y) => {
|
2019-08-06 16:23:53 +08:00
|
|
|
window.scrollY = y;
|
|
|
|
window.pageYOffset = y;
|
2019-07-24 22:56:20 +08:00
|
|
|
});
|
2019-08-08 20:32:06 +08:00
|
|
|
|
2019-07-30 12:34:12 +08:00
|
|
|
scrollTo(1000);
|
2020-03-20 15:07:47 +08:00
|
|
|
await sleep(20);
|
2019-08-08 20:32:06 +08:00
|
|
|
|
2019-07-24 22:56:20 +08:00
|
|
|
expect(window.pageYOffset).toBe(1000);
|
2019-08-08 20:32:06 +08:00
|
|
|
|
2019-07-24 22:56:20 +08:00
|
|
|
scrollToSpy.mockRestore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('test callback - option', async () => {
|
|
|
|
const cbMock = jest.fn();
|
2019-07-30 12:49:32 +08:00
|
|
|
scrollTo(1000, {
|
2019-07-24 22:56:20 +08:00
|
|
|
callback: cbMock,
|
|
|
|
});
|
2020-03-20 15:07:47 +08:00
|
|
|
await sleep(20);
|
2019-07-24 22:56:20 +08:00
|
|
|
expect(cbMock).toHaveBeenCalledTimes(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('test getContainer - option', async () => {
|
|
|
|
const div = document.createElement('div');
|
2019-07-30 12:34:12 +08:00
|
|
|
scrollTo(1000, {
|
2019-07-24 22:56:20 +08:00
|
|
|
getContainer: () => div,
|
|
|
|
});
|
2020-03-20 15:07:47 +08:00
|
|
|
await sleep(20);
|
2019-07-24 22:56:20 +08:00
|
|
|
expect(div.scrollTop).toBe(1000);
|
|
|
|
});
|
2020-05-15 14:57:12 +08:00
|
|
|
|
|
|
|
it('test getContainer document - option', async () => {
|
|
|
|
scrollTo(1000, {
|
|
|
|
getContainer: () => document,
|
|
|
|
});
|
|
|
|
await sleep(20);
|
|
|
|
expect(document.documentElement.scrollTop).toBe(1000);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('test duration - option', async () => {
|
|
|
|
scrollTo(1000, {
|
|
|
|
duration: 1100,
|
|
|
|
getContainer: () => document,
|
|
|
|
});
|
|
|
|
await sleep(20);
|
|
|
|
expect(document.documentElement.scrollTop).toBe(1000);
|
|
|
|
});
|
2019-07-24 22:56:20 +08:00
|
|
|
});
|