mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-11 02:37:22 +03:00
Created TagsSelector test
This commit is contained in:
parent
d4236b914d
commit
770ba624c2
2 changed files with 74 additions and 11 deletions
|
@ -25,9 +25,9 @@ const TagsSelector = (colorGenerator: ColorGenerator) => (
|
||||||
listTags();
|
listTags();
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
const renderTag = ({ tag, onDelete }: TagComponentProps) =>
|
const ReactTagsTag = ({ tag, onDelete }: TagComponentProps) =>
|
||||||
<Tag colorGenerator={colorGenerator} text={tag.name} clearable className="react-tags__tag" onClose={onDelete} />;
|
<Tag colorGenerator={colorGenerator} text={tag.name} clearable className="react-tags__tag" onClose={onDelete} />;
|
||||||
const renderSuggestion = ({ item }: SuggestionComponentProps) => (
|
const ReactTagsSuggestion = ({ item }: SuggestionComponentProps) => (
|
||||||
<>
|
<>
|
||||||
<TagBullet tag={`${item.name}`} colorGenerator={colorGenerator} />
|
<TagBullet tag={`${item.name}`} colorGenerator={colorGenerator} />
|
||||||
{item.name}
|
{item.name}
|
||||||
|
@ -37,23 +37,20 @@ const TagsSelector = (colorGenerator: ColorGenerator) => (
|
||||||
return (
|
return (
|
||||||
<ReactTags
|
<ReactTags
|
||||||
tags={selectedTags.map(toComponentTag)}
|
tags={selectedTags.map(toComponentTag)}
|
||||||
tagComponent={renderTag}
|
tagComponent={ReactTagsTag}
|
||||||
suggestions={tagsList.tags.filter((tag) => !selectedTags.includes(tag)).map(toComponentTag)}
|
suggestions={tagsList.tags.filter((tag) => !selectedTags.includes(tag)).map(toComponentTag)}
|
||||||
suggestionComponent={renderSuggestion}
|
suggestionComponent={ReactTagsSuggestion}
|
||||||
allowNew
|
allowNew
|
||||||
addOnBlur
|
addOnBlur
|
||||||
placeholderText={placeholder}
|
placeholderText={placeholder}
|
||||||
minQueryLength={1}
|
minQueryLength={1}
|
||||||
onDelete={(removedTagIndex) => {
|
onDelete={(removedTagIndex) => {
|
||||||
selectedTags.splice(removedTagIndex, 1);
|
const tagsCopy = [ ...selectedTags ];
|
||||||
|
|
||||||
onChange(selectedTags);
|
tagsCopy.splice(removedTagIndex, 1);
|
||||||
}}
|
onChange(tagsCopy);
|
||||||
onAddition={({ name: newTag }) => {
|
|
||||||
const tags = [ ...selectedTags, newTag.toLowerCase() ]; // eslint-disable-line @typescript-eslint/no-unsafe-call
|
|
||||||
|
|
||||||
onChange(tags);
|
|
||||||
}}
|
}}
|
||||||
|
onAddition={({ name: newTag }) => onChange([ ...selectedTags, newTag.toLowerCase() ])}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
66
test/tags/helpers/TagsSelector.test.tsx
Normal file
66
test/tags/helpers/TagsSelector.test.tsx
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
import { shallow, ShallowWrapper } from 'enzyme';
|
||||||
|
import { Mock } from 'ts-mockery';
|
||||||
|
import createTagsSelector from '../../../src/tags/helpers/TagsSelector';
|
||||||
|
import ColorGenerator from '../../../src/utils/services/ColorGenerator';
|
||||||
|
import { TagsList } from '../../../src/tags/reducers/tagsList';
|
||||||
|
|
||||||
|
describe('<TagsSelector />', () => {
|
||||||
|
const onChange = jest.fn();
|
||||||
|
const TagsSelector = createTagsSelector(Mock.all<ColorGenerator>());
|
||||||
|
const tags = [ 'foo', 'bar' ];
|
||||||
|
const tagsList = Mock.of<TagsList>({ tags: [ ...tags, 'baz' ] });
|
||||||
|
let wrapper: ShallowWrapper;
|
||||||
|
|
||||||
|
beforeEach(jest.clearAllMocks);
|
||||||
|
beforeEach(() => {
|
||||||
|
wrapper = shallow(
|
||||||
|
<TagsSelector selectedTags={tags} tagsList={tagsList} listTags={jest.fn()} onChange={onChange} />,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => wrapper?.unmount());
|
||||||
|
|
||||||
|
it('has expected props', () => {
|
||||||
|
expect(wrapper.prop('placeholderText')).toEqual('Add tags to the URL');
|
||||||
|
expect(wrapper.prop('allowNew')).toEqual(true);
|
||||||
|
expect(wrapper.prop('addOnBlur')).toEqual(true);
|
||||||
|
expect(wrapper.prop('minQueryLength')).toEqual(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('contains expected tags', () => {
|
||||||
|
expect(wrapper.prop('tags')).toEqual([
|
||||||
|
{
|
||||||
|
id: 'foo',
|
||||||
|
name: 'foo',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'bar',
|
||||||
|
name: 'bar',
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('contains expected suggestions', () => {
|
||||||
|
expect(wrapper.prop('suggestions')).toEqual([
|
||||||
|
{
|
||||||
|
id: 'baz',
|
||||||
|
name: 'baz',
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('invokes onChange when new tags are added', () => {
|
||||||
|
wrapper.simulate('addition', { name: 'The-New-Tag' });
|
||||||
|
|
||||||
|
expect(onChange).toHaveBeenCalledWith([ ...tags, 'the-new-tag' ]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it.each([
|
||||||
|
[ 0, 'bar' ],
|
||||||
|
[ 1, 'foo' ],
|
||||||
|
])('invokes onChange when tags are deleted', (index, expected) => {
|
||||||
|
wrapper.simulate('delete', index);
|
||||||
|
|
||||||
|
expect(onChange).toHaveBeenCalledWith([ expected ]);
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue