mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-11 02:37:22 +03:00
Created TagsTable test
This commit is contained in:
parent
a90287ed02
commit
40ef51a348
1 changed files with 100 additions and 0 deletions
100
test/tags/TagsTable.test.tsx
Normal file
100
test/tags/TagsTable.test.tsx
Normal file
|
@ -0,0 +1,100 @@
|
|||
import { Mock } from 'ts-mockery';
|
||||
import { shallow, ShallowWrapper } from 'enzyme';
|
||||
import { match } from 'react-router';
|
||||
import { Location, History } from 'history';
|
||||
import ColorGenerator from '../../src/utils/services/ColorGenerator';
|
||||
import { TagsTable as createTagsTable } from '../../src/tags/TagsTable';
|
||||
import { SelectedServer } from '../../src/servers/data';
|
||||
import { TagsList } from '../../src/tags/reducers/tagsList';
|
||||
import { rangeOf } from '../../src/utils/utils';
|
||||
import SimplePaginator from '../../src/common/SimplePaginator';
|
||||
|
||||
describe('<TagsTable />', () => {
|
||||
const colorGenerator = Mock.all<ColorGenerator>();
|
||||
const TagsTableRow = () => null;
|
||||
const TagsTable = createTagsTable(colorGenerator, TagsTableRow);
|
||||
const tags = (amount: number) => rangeOf(amount, (i) => `tag_${i}`);
|
||||
let wrapper: ShallowWrapper;
|
||||
const createWrapper = (filteredTags: string[] = [], search = '') => {
|
||||
wrapper = shallow(
|
||||
<TagsTable
|
||||
tagsList={Mock.of<TagsList>({ stats: {}, filteredTags })}
|
||||
selectedServer={Mock.all<SelectedServer>()}
|
||||
history={Mock.all<History>()}
|
||||
location={Mock.of<Location>({ search })}
|
||||
match={Mock.all<match>()}
|
||||
/>,
|
||||
);
|
||||
|
||||
return wrapper;
|
||||
};
|
||||
|
||||
beforeEach(() => {
|
||||
(global as any).location = { search: '', pathname: '' };
|
||||
(global as any).history = { pushState: jest.fn() };
|
||||
});
|
||||
|
||||
afterEach(() => wrapper?.unmount());
|
||||
|
||||
it('renders empty result if there are no tags', () => {
|
||||
const wrapper = createWrapper();
|
||||
const regularRows = wrapper.find('tbody').find('tr');
|
||||
const tagRows = wrapper.find(TagsTableRow);
|
||||
|
||||
expect(regularRows).toHaveLength(1);
|
||||
expect(tagRows).toHaveLength(0);
|
||||
});
|
||||
|
||||
it.each([
|
||||
[[ 'foo', 'bar', 'baz' ], 3 ],
|
||||
[[ 'foo' ], 1 ],
|
||||
[ tags(19), 19 ],
|
||||
[ tags(20), 20 ],
|
||||
[ tags(30), 20 ],
|
||||
[ tags(100), 20 ],
|
||||
])('renders as many rows as there are in current page', (filteredTags, expectedRows) => {
|
||||
const wrapper = createWrapper(filteredTags);
|
||||
const tagRows = wrapper.find(TagsTableRow);
|
||||
|
||||
expect(tagRows).toHaveLength(expectedRows);
|
||||
});
|
||||
|
||||
it.each([
|
||||
[[ 'foo', 'bar', 'baz' ], 0 ],
|
||||
[[ 'foo' ], 0 ],
|
||||
[ tags(19), 0 ],
|
||||
[ tags(20), 0 ],
|
||||
[ tags(30), 1 ],
|
||||
[ tags(100), 1 ],
|
||||
])('renders paginator if there are more than one page', (filteredTags, expectedPaginators) => {
|
||||
const wrapper = createWrapper(filteredTags);
|
||||
const paginator = wrapper.find(SimplePaginator);
|
||||
|
||||
expect(paginator).toHaveLength(expectedPaginators);
|
||||
});
|
||||
|
||||
it.each([
|
||||
[ 1, 20, 0 ],
|
||||
[ 2, 20, 20 ],
|
||||
[ 3, 20, 40 ],
|
||||
[ 4, 20, 60 ],
|
||||
[ 5, 7, 80 ],
|
||||
[ 6, 0, 0 ],
|
||||
])('renders page from query if present', (page, expectedRows, offset) => {
|
||||
const wrapper = createWrapper(tags(87), `page=${page}`);
|
||||
const tagRows = wrapper.find(TagsTableRow);
|
||||
|
||||
expect(tagRows).toHaveLength(expectedRows);
|
||||
tagRows.forEach((row, index) => {
|
||||
expect(row.prop('tag')).toEqual(`tag_${index + offset + 1}`);
|
||||
});
|
||||
});
|
||||
|
||||
it('allows changing current page in paginator', () => {
|
||||
const wrapper = createWrapper(tags(100));
|
||||
|
||||
expect(wrapper.find(SimplePaginator).prop('currentPage')).toEqual(1);
|
||||
(wrapper.find(SimplePaginator).prop('setCurrentPage') as Function)(5);
|
||||
expect(wrapper.find(SimplePaginator).prop('currentPage')).toEqual(5);
|
||||
});
|
||||
});
|
Loading…
Reference in a new issue