bigbuffet-rw/app/soapbox/features/emoji/__tests__/emoji_index.test.ts

152 lines
3.6 KiB
TypeScript
Raw Normal View History

2022-07-04 23:37:07 -07:00
// import { emojiIndex } from 'emoji-mart';
import pick from 'lodash/pick';
2022-07-04 23:37:07 -07:00
import search from '../search';
2020-03-27 13:59:38 -07:00
2022-07-06 10:31:11 -07:00
const trimEmojis = (emoji: any) => pick(emoji, ['id', 'unified', 'native', 'custom']);
2020-03-27 13:59:38 -07:00
describe('emoji_index', () => {
it('should give same result for emoji_index_light and emoji-mart', () => {
const expected = [
{
id: 'pineapple',
unified: '1f34d',
native: '🍍',
},
];
expect(search('pineapple').map(trimEmojis)).toEqual(expected);
});
it('orders search results correctly', () => {
const expected = [
{
id: 'pineapple',
unified: '1f34d',
native: '🍍',
},
2022-07-07 17:52:29 -07:00
{
id: 'apple',
unified: '1f34e',
native: '🍎',
},
2020-03-27 13:59:38 -07:00
{
id: 'green_apple',
unified: '1f34f',
native: '🍏',
},
];
expect(search('apple').map(trimEmojis)).toEqual(expected);
});
it('(different behavior from emoji-mart) do not erases custom emoji if not passed again', () => {
const custom = [
{
id: 'mastodon',
name: 'mastodon',
short_names: ['mastodon'],
2020-03-27 13:59:38 -07:00
text: '',
emoticons: [],
keywords: ['mastodon'],
2020-03-27 13:59:38 -07:00
imageUrl: 'http://example.com',
custom: true,
},
];
2022-07-04 23:37:07 -07:00
search('', { custom });
// emojiIndex.search('', { custom });
// const expected = [];
2020-03-27 13:59:38 -07:00
const lightExpected = [
{
id: 'mastodon',
2020-03-27 13:59:38 -07:00
custom: true,
},
];
expect(search('masto').map(trimEmojis)).toEqual(lightExpected);
2020-03-27 13:59:38 -07:00
});
it('(different behavior from emoji-mart) erases custom emoji if another is passed', () => {
const custom = [
{
id: 'mastodon',
name: 'mastodon',
short_names: ['mastodon'],
2020-03-27 13:59:38 -07:00
text: '',
emoticons: [],
keywords: ['mastodon'],
2020-03-27 13:59:38 -07:00
imageUrl: 'http://example.com',
custom: true,
},
];
2022-07-04 23:37:07 -07:00
search('', { custom });
// emojiIndex.search('', { custom });
2022-07-04 23:37:57 -07:00
const expected = [];
2022-07-04 23:37:07 -07:00
expect(search('masto', { custom: [] }).map(trimEmojis)).toEqual(expected);
2020-03-27 13:59:38 -07:00
});
it('handles custom emoji', () => {
const custom = [
{
id: 'mastodon',
name: 'mastodon',
short_names: ['mastodon'],
2020-03-27 13:59:38 -07:00
text: '',
emoticons: [],
keywords: ['mastodon'],
2020-03-27 13:59:38 -07:00
imageUrl: 'http://example.com',
custom: true,
},
];
2022-07-04 23:37:07 -07:00
search('', { custom });
// emojiIndex.search('', { custom });
2020-03-27 13:59:38 -07:00
const expected = [
{
id: 'mastodon',
2020-03-27 13:59:38 -07:00
custom: true,
},
];
2022-07-04 23:37:07 -07:00
expect(search('masto', { custom }).map(trimEmojis)).toEqual(expected);
2020-03-27 13:59:38 -07:00
});
it('does an emoji whose unified name is irregular', () => {
const expected = [
{
'id': 'water_polo',
'unified': '1f93d',
'native': '🤽',
},
{
'id': 'man-playing-water-polo',
'unified': '1f93d-200d-2642-fe0f',
'native': '🤽‍♂️',
},
{
'id': 'woman-playing-water-polo',
'unified': '1f93d-200d-2640-fe0f',
'native': '🤽‍♀️',
},
];
expect(search('polo').map(trimEmojis)).toEqual(expected);
});
it('can search for thinking_face', () => {
const expected = [
{
id: 'thinking_face',
unified: '1f914',
native: '🤔',
},
];
expect(search('thinking_fac').map(trimEmojis)).toEqual(expected);
});
it('can search for woman-facepalming', () => {
const expected = [
{
id: 'woman-facepalming',
unified: '1f926-200d-2640-fe0f',
native: '🤦‍♀️',
},
];
expect(search('woman-facep').map(trimEmojis)).toEqual(expected);
});
});