2020-08-30 19:45:17 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
|
|
|
import { Mock } from 'ts-mockery';
|
2018-12-17 22:32:51 +01:00
|
|
|
import searchBarCreator from '../../src/short-urls/SearchBar';
|
2018-09-16 12:18:02 +02:00
|
|
|
import SearchField from '../../src/utils/SearchField';
|
2018-12-18 11:28:15 +01:00
|
|
|
import Tag from '../../src/tags/helpers/Tag';
|
2020-12-14 23:35:31 +01:00
|
|
|
import { DateRangeSelector } from '../../src/utils/dates/DateRangeSelector';
|
2020-08-30 19:45:17 +02:00
|
|
|
import ColorGenerator from '../../src/utils/services/ColorGenerator';
|
2018-09-16 12:18:02 +02:00
|
|
|
|
|
|
|
describe('<SearchBar />', () => {
|
2020-08-30 19:45:17 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
2019-04-19 12:41:59 +02:00
|
|
|
const listShortUrlsMock = jest.fn();
|
2020-12-12 13:33:21 +01:00
|
|
|
const SearchBar = searchBarCreator(Mock.all<ColorGenerator>());
|
2018-09-16 12:18:02 +02:00
|
|
|
|
2020-08-30 19:45:17 +02:00
|
|
|
afterEach(jest.clearAllMocks);
|
|
|
|
afterEach(() => wrapper?.unmount());
|
2018-09-16 12:18:02 +02:00
|
|
|
|
|
|
|
it('renders a SearchField', () => {
|
2020-08-30 19:45:17 +02:00
|
|
|
wrapper = shallow(<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} />);
|
2018-09-16 12:18:02 +02:00
|
|
|
|
|
|
|
expect(wrapper.find(SearchField)).toHaveLength(1);
|
|
|
|
});
|
|
|
|
|
2020-12-14 23:35:31 +01:00
|
|
|
it('renders a DateRangeSelector', () => {
|
2020-08-30 19:45:17 +02:00
|
|
|
wrapper = shallow(<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} />);
|
2020-01-28 19:46:36 +01:00
|
|
|
|
2020-12-14 23:35:31 +01:00
|
|
|
expect(wrapper.find(DateRangeSelector)).toHaveLength(1);
|
2020-01-14 20:12:30 +01:00
|
|
|
});
|
|
|
|
|
2018-09-16 12:18:02 +02:00
|
|
|
it('renders no tags when the list of tags is empty', () => {
|
2020-08-30 19:45:17 +02:00
|
|
|
wrapper = shallow(<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} />);
|
2018-09-16 12:18:02 +02:00
|
|
|
|
|
|
|
expect(wrapper.find(Tag)).toHaveLength(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders the proper amount of tags', () => {
|
|
|
|
const tags = [ 'foo', 'bar', 'baz' ];
|
|
|
|
|
2020-08-30 19:45:17 +02:00
|
|
|
wrapper = shallow(<SearchBar shortUrlsListParams={{ tags }} listShortUrls={listShortUrlsMock} />);
|
2018-09-16 12:18:02 +02:00
|
|
|
|
|
|
|
expect(wrapper.find(Tag)).toHaveLength(tags.length);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('updates short URLs list when search field changes', () => {
|
2018-12-17 22:32:51 +01:00
|
|
|
wrapper = shallow(<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} />);
|
2018-09-16 12:18:02 +02:00
|
|
|
const searchField = wrapper.find(SearchField);
|
|
|
|
|
2019-04-19 12:41:59 +02:00
|
|
|
expect(listShortUrlsMock).not.toHaveBeenCalled();
|
2018-09-16 12:18:02 +02:00
|
|
|
searchField.simulate('change');
|
2019-04-19 12:41:59 +02:00
|
|
|
expect(listShortUrlsMock).toHaveBeenCalledTimes(1);
|
2018-09-16 12:18:02 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('updates short URLs list when a tag is removed', () => {
|
|
|
|
wrapper = shallow(
|
2020-08-22 08:10:31 +02:00
|
|
|
<SearchBar shortUrlsListParams={{ tags: [ 'foo' ] }} listShortUrls={listShortUrlsMock} />,
|
2018-09-16 12:18:02 +02:00
|
|
|
);
|
|
|
|
const tag = wrapper.find(Tag).first();
|
|
|
|
|
2019-04-19 12:41:59 +02:00
|
|
|
expect(listShortUrlsMock).not.toHaveBeenCalled();
|
2018-09-16 12:18:02 +02:00
|
|
|
tag.simulate('close');
|
2019-04-19 12:41:59 +02:00
|
|
|
expect(listShortUrlsMock).toHaveBeenCalledTimes(1);
|
2018-09-16 12:18:02 +02:00
|
|
|
});
|
2020-01-14 20:12:30 +01:00
|
|
|
|
2020-12-14 23:35:31 +01:00
|
|
|
it('updates short URLs list when date range changes', () => {
|
2020-01-19 21:25:45 +01:00
|
|
|
wrapper = shallow(
|
2020-08-22 08:10:31 +02:00
|
|
|
<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} />,
|
2020-01-19 21:25:45 +01:00
|
|
|
);
|
2020-12-14 23:35:31 +01:00
|
|
|
const dateRange = wrapper.find(DateRangeSelector);
|
2020-01-14 20:12:30 +01:00
|
|
|
|
|
|
|
expect(listShortUrlsMock).not.toHaveBeenCalled();
|
2020-12-14 23:35:31 +01:00
|
|
|
dateRange.simulate('datesChange', {});
|
2020-01-14 20:12:30 +01:00
|
|
|
expect(listShortUrlsMock).toHaveBeenCalledTimes(1);
|
|
|
|
});
|
2018-09-16 12:18:02 +02:00
|
|
|
});
|