emoji_input.spec.js (5401B)
- import { h } from 'vue'
 - import { shallowMount } from '@vue/test-utils'
 - import EmojiInput from 'src/components/emoji_input/emoji_input.vue'
 - import vClickOutside from 'click-outside-vue3'
 - const generateInput = (value, padEmoji = true) => {
 - const wrapper = shallowMount(EmojiInput, {
 - global: {
 - renderStubDefaultSlot: true,
 - mocks: {
 - $store: {
 - getters: {
 - mergedConfig: {
 - padEmoji
 - }
 - }
 - },
 - $t: (msg) => msg
 - },
 - stubs: {
 - FAIcon: true
 - },
 - directives: {
 - 'click-outside': vClickOutside
 - }
 - },
 - props: {
 - suggest: () => [],
 - enableEmojiPicker: true,
 - modelValue: value
 - },
 - slots: {
 - default: () => h('input', '')
 - }
 - })
 - return wrapper
 - }
 - describe('EmojiInput', () => {
 - describe('insertion mechanism', () => {
 - it('inserts string at the end with trailing space', () => {
 - const initialString = 'Testing'
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: initialString.length })
 - wrapper.vm.insert({ insertion: '(test)', keepOpen: false })
 - const inputEvents = wrapper.emitted()['update:modelValue']
 - expect(inputEvents[inputEvents.length - 1][0]).to.eql('Testing (test) ')
 - })
 - it('inserts string at the end with trailing space (source has a trailing space)', () => {
 - const initialString = 'Testing '
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: initialString.length })
 - wrapper.vm.insert({ insertion: '(test)', keepOpen: false })
 - const inputEvents = wrapper.emitted()['update:modelValue']
 - expect(inputEvents[inputEvents.length - 1][0]).to.eql('Testing (test) ')
 - })
 - it('inserts string at the begginning without leading space', () => {
 - const initialString = 'Testing'
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: 0 })
 - wrapper.vm.insert({ insertion: '(test)', keepOpen: false })
 - const inputEvents = wrapper.emitted()['update:modelValue']
 - expect(inputEvents[inputEvents.length - 1][0]).to.eql('(test) Testing')
 - })
 - it('inserts string between words without creating extra spaces', () => {
 - const initialString = 'Spurdo Sparde'
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: 6 })
 - wrapper.vm.insert({ insertion: ':ebin:', keepOpen: false })
 - const inputEvents = wrapper.emitted()['update:modelValue']
 - expect(inputEvents[inputEvents.length - 1][0]).to.eql('Spurdo :ebin: Sparde')
 - })
 - it('inserts string between words without creating extra spaces (other caret)', () => {
 - const initialString = 'Spurdo Sparde'
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: 7 })
 - wrapper.vm.insert({ insertion: ':ebin:', keepOpen: false })
 - const inputEvents = wrapper.emitted()['update:modelValue']
 - expect(inputEvents[inputEvents.length - 1][0]).to.eql('Spurdo :ebin: Sparde')
 - })
 - it('inserts string without any padding if padEmoji setting is set to false', () => {
 - const initialString = 'Eat some spam!'
 - const wrapper = generateInput(initialString, false)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: initialString.length, keepOpen: false })
 - wrapper.vm.insert({ insertion: ':spam:' })
 - const inputEvents = wrapper.emitted()['update:modelValue']
 - expect(inputEvents[inputEvents.length - 1][0]).to.eql('Eat some spam!:spam:')
 - })
 - it('correctly sets caret after insertion at beginning', (done) => {
 - const initialString = '1234'
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: 0 })
 - wrapper.vm.insert({ insertion: '1234', keepOpen: false })
 - wrapper.vm.$nextTick(() => {
 - expect(wrapper.vm.caret).to.eql(5)
 - done()
 - })
 - })
 - it('correctly sets caret after insertion at end', (done) => {
 - const initialString = '1234'
 - const wrapper = generateInput(initialString)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: initialString.length })
 - wrapper.vm.insert({ insertion: '1234', keepOpen: false })
 - wrapper.vm.$nextTick(() => {
 - expect(wrapper.vm.caret).to.eql(10)
 - done()
 - })
 - })
 - it('correctly sets caret after insertion if padEmoji setting is set to false', (done) => {
 - const initialString = '1234'
 - const wrapper = generateInput(initialString, false)
 - const input = wrapper.find('input')
 - input.setValue(initialString)
 - wrapper.setData({ caret: initialString.length })
 - wrapper.vm.insert({ insertion: '1234', keepOpen: false })
 - wrapper.vm.$nextTick(() => {
 - expect(wrapper.vm.caret).to.eql(8)
 - done()
 - })
 - })
 - })
 - })