2019-01-13 23:03:31 +01:00
|
|
|
import React from 'react';
|
|
|
|
import { shallow } from 'enzyme';
|
|
|
|
import createScrollToTop from '../../src/common/ScrollToTop';
|
|
|
|
|
|
|
|
describe('<ScrollToTop />', () => {
|
|
|
|
let wrapper;
|
|
|
|
const window = {
|
2019-04-19 10:29:49 +02:00
|
|
|
scrollTo: jest.fn(),
|
2019-01-13 23:03:31 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const ScrollToTop = createScrollToTop(window);
|
|
|
|
|
|
|
|
wrapper = shallow(<ScrollToTop locaction={{ href: 'foo' }}>Foobar</ScrollToTop>);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
wrapper.unmount();
|
2019-04-19 10:29:49 +02:00
|
|
|
window.scrollTo.mockReset();
|
2019-01-13 23:03:31 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
it('just renders children', () => expect(wrapper.text()).toEqual('Foobar'));
|
|
|
|
|
|
|
|
it('scrolls to top when location changes', () => {
|
|
|
|
wrapper.instance().componentDidUpdate({ location: { href: 'bar' } });
|
2019-04-19 10:29:49 +02:00
|
|
|
expect(window.scrollTo).toHaveBeenCalledTimes(1);
|
2019-01-13 23:03:31 +01:00
|
|
|
});
|
|
|
|
});
|