blessing-skin-server/resources/assets/tests/components/SkinLibItem.test.ts

109 lines
3.1 KiB
TypeScript
Raw Normal View History

2019-03-15 11:42:41 +08:00
import Vue from 'vue'
import { mount } from '@vue/test-utils'
2019-03-18 15:00:18 +08:00
import SkinLibItem from '@/components/SkinLibItem.vue'
2019-03-25 22:01:57 +08:00
import { MessageBoxData } from 'element-ui/types/message-box'
2019-03-18 15:00:18 +08:00
import { flushPromises } from '../utils'
2018-08-14 23:27:36 +08:00
test('urls', () => {
2019-03-15 11:42:41 +08:00
const wrapper = mount(SkinLibItem, {
propsData: { tid: 1 },
})
expect(wrapper.find('a').attributes('href')).toBe('/skinlib/show/1')
expect(wrapper.find('img').attributes('src')).toBe('/preview/1.png')
})
2019-03-17 10:21:18 +08:00
2018-08-14 23:27:36 +08:00
test('render basic information', () => {
2019-03-15 11:42:41 +08:00
const wrapper = mount(SkinLibItem, {
propsData: {
tid: 1,
name: 'test',
type: 'steve',
},
})
expect(wrapper.text()).toContain('test')
expect(wrapper.text()).toContain('skinlib.filter.steve')
})
2019-03-17 10:21:18 +08:00
2018-08-14 23:27:36 +08:00
test('anonymous user', () => {
2019-03-15 11:42:41 +08:00
const wrapper = mount(SkinLibItem, {
propsData: { anonymous: true },
})
const button = wrapper.find('.more')
expect(button.attributes('title')).toBe('skinlib.anonymous')
button.trigger('click')
expect(Vue.prototype.$http.post).not.toBeCalled()
})
2019-03-17 10:21:18 +08:00
2018-08-14 23:27:36 +08:00
test('private texture', () => {
2019-03-15 11:42:41 +08:00
const wrapper = mount(SkinLibItem, {
propsData: { isPublic: false },
})
expect(wrapper.text()).toContain('skinlib.private')
wrapper.setProps({ isPublic: true })
expect(wrapper.text()).not.toContain('skinlib.private')
})
2019-03-17 10:21:18 +08:00
2018-08-14 23:27:36 +08:00
test('liked state', () => {
2019-03-15 11:42:41 +08:00
const wrapper = mount(SkinLibItem, {
propsData: { liked: true, anonymous: false },
})
const button = wrapper.find('.like')
expect(button.attributes('title')).toBe('skinlib.removeFromCloset')
expect(button.classes('liked')).toBeTrue()
wrapper.setProps({ liked: false })
expect(button.attributes('title')).toBe('skinlib.addToCloset')
expect(button.classes('liked')).toBeFalse()
})
2019-03-17 10:21:18 +08:00
2018-08-14 23:27:36 +08:00
test('remove from closet', async () => {
2019-04-23 11:47:45 +08:00
Vue.prototype.$http.post.mockResolvedValue({ code: 0 })
2019-03-25 22:01:57 +08:00
Vue.prototype.$confirm.mockResolvedValue('confirm')
2019-03-15 11:42:41 +08:00
const wrapper = mount(SkinLibItem, {
propsData: {
tid: 1, liked: true, anonymous: false,
},
})
2019-03-17 15:26:12 +08:00
wrapper.find('.like').trigger('click')
2019-03-15 11:42:41 +08:00
await flushPromises()
expect(wrapper.emitted('like-toggled')[0]).toEqual([false])
})
2019-03-17 10:21:18 +08:00
2018-08-14 23:27:36 +08:00
test('add to closet', async () => {
2019-03-15 11:42:41 +08:00
Vue.prototype.$http.post
2019-04-23 11:47:45 +08:00
.mockResolvedValueOnce({ code: 1, message: '1' })
.mockResolvedValue({ code: 0 })
2019-03-25 22:01:57 +08:00
Vue.prototype.$prompt
.mockImplementationOnce(() => Promise.reject())
.mockImplementation((_, { inputValidator }) => {
2019-03-15 11:42:41 +08:00
if (inputValidator) {
2019-03-18 09:55:24 +08:00
inputValidator('')
2019-03-15 11:42:41 +08:00
inputValidator('name')
}
2019-03-25 22:01:57 +08:00
return Promise.resolve({ value: 'name' } as MessageBoxData)
2019-03-15 11:42:41 +08:00
})
const wrapper = mount(SkinLibItem, {
propsData: {
tid: 1, liked: false, anonymous: false,
},
})
const button = wrapper.find('.like')
button.trigger('click')
expect(Vue.prototype.$http.post).not.toBeCalled()
button.trigger('click')
await flushPromises()
expect(Vue.prototype.$http.post).toBeCalledWith(
'/user/closet/add',
{ tid: 1, name: 'name' }
)
2019-03-25 22:01:57 +08:00
expect(Vue.prototype.$message.warning).toBeCalledWith('1')
2019-03-15 11:42:41 +08:00
button.trigger('click')
await flushPromises()
expect(wrapper.emitted('like-toggled')[0]).toEqual([true])
})