blessing-skin-server/resources/assets/tests/views/admin/Translations.test.ts

88 lines
2.4 KiB
TypeScript
Raw Normal View History

2019-09-08 18:57:19 +08:00
import Vue from 'vue'
import { mount } from '@vue/test-utils'
import { flushPromises } from '../../utils'
import { showModal, toast } from '@/scripts/notify'
2019-09-08 18:57:19 +08:00
import Translations from '@/views/admin/Translations.vue'
jest.mock('@/scripts/notify')
2019-09-08 18:57:19 +08:00
test('fetch data', async () => {
Vue.prototype.$http.get.mockResolvedValue([
{
id: 1, group: 'general', key: 'submit', text: '',
},
])
const wrapper = mount(Translations)
await flushPromises()
expect(Vue.prototype.$http.get).toBeCalledWith('/admin/i18n/list')
expect(wrapper.text()).toContain('admin.i18n.empty')
})
test('modify line', async () => {
Vue.prototype.$http.get.mockResolvedValue([
{
id: 1, group: 'general', key: 'submit', text: '',
},
])
Vue.prototype.$http.put
.mockResolvedValueOnce({ code: 1, message: 'failed' })
.mockResolvedValueOnce({ code: 0, message: 'ok' })
showModal
2019-09-08 18:57:19 +08:00
.mockRejectedValueOnce(null)
.mockResolvedValueOnce({ value: '' })
.mockResolvedValueOnce({ value: 'wanshengwei' })
2019-09-08 18:57:19 +08:00
const wrapper = mount(Translations)
await flushPromises()
2019-11-24 14:32:58 +08:00
const button = wrapper.find('.btn-default')
2019-09-08 18:57:19 +08:00
button.trigger('click')
await flushPromises()
expect(Vue.prototype.$http.put).not.toBeCalled()
button.trigger('click')
await flushPromises()
expect(Vue.prototype.$http.put).toBeCalledWith(
'/admin/i18n',
2019-11-25 23:30:51 +08:00
{ id: 1, text: '' },
2019-09-08 18:57:19 +08:00
)
expect(toast.error).toBeCalledWith('failed')
2019-09-08 18:57:19 +08:00
expect(wrapper.text()).not.toContain('wanshengwei')
button.trigger('click')
await flushPromises()
expect(Vue.prototype.$http.put).toBeCalledWith(
'/admin/i18n',
2019-11-25 23:30:51 +08:00
{ id: 1, text: 'wanshengwei' },
2019-09-08 18:57:19 +08:00
)
expect(toast.success).toBeCalledWith('ok')
2019-09-08 18:57:19 +08:00
expect(wrapper.text()).toContain('wanshengwei')
})
test('delete line', async () => {
Vue.prototype.$http.get.mockResolvedValue([
{
id: 1, group: 'general', key: 'submit', text: '',
},
])
Vue.prototype.$http.del.mockResolvedValueOnce({ message: 'ok' })
showModal
2019-09-08 18:57:19 +08:00
.mockRejectedValueOnce(null)
.mockResolvedValueOnce({ value: '' })
2019-09-08 18:57:19 +08:00
const wrapper = mount(Translations)
await flushPromises()
2019-11-24 14:32:58 +08:00
const button = wrapper.find('.btn-danger')
2019-09-08 18:57:19 +08:00
button.trigger('click')
await flushPromises()
expect(Vue.prototype.$http.del).not.toBeCalled()
button.trigger('click')
await flushPromises()
expect(Vue.prototype.$http.del).toBeCalledWith('/admin/i18n', { id: 1 })
expect(toast.success).toBeCalledWith('ok')
2019-09-08 18:57:19 +08:00
expect(wrapper.text()).not.toContain('general')
})