2018-08-06 13:16:10 +08:00
|
|
|
import Vue from 'vue';
|
2018-07-27 16:17:22 +08:00
|
|
|
import { mount } from '@vue/test-utils';
|
2018-08-06 09:30:54 +08:00
|
|
|
import { flushPromises } from '../../utils';
|
2018-07-31 10:42:14 +08:00
|
|
|
import ClosetItem from '@/components/user/ClosetItem';
|
|
|
|
import { swal } from '@/js/notify';
|
2018-07-27 16:17:22 +08:00
|
|
|
|
2018-07-31 10:42:14 +08:00
|
|
|
jest.mock('@/js/notify');
|
2018-07-27 16:17:22 +08:00
|
|
|
|
|
|
|
function factory(opt = {}) {
|
|
|
|
return {
|
|
|
|
tid: 1,
|
|
|
|
name: 'texture',
|
|
|
|
type: 'steve',
|
|
|
|
...opt
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
test('computed values', () => {
|
|
|
|
const wrapper = mount(ClosetItem, { propsData: factory() });
|
2018-09-08 13:25:14 +08:00
|
|
|
expect(wrapper.find('img').attributes('src')).toBe('/preview/1.png');
|
|
|
|
expect(wrapper.find('a.more').attributes('href')).toBe('/skinlib/show/1');
|
2018-07-27 16:17:22 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('selected item', () => {
|
|
|
|
const wrapper = mount(ClosetItem, { propsData: factory({ selected: true }) });
|
2018-09-08 13:25:14 +08:00
|
|
|
expect(wrapper.find('.item').classes('item-selected')).toBeTrue();
|
2018-07-27 16:17:22 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('click item body', () => {
|
|
|
|
const wrapper = mount(ClosetItem, { propsData: factory() });
|
|
|
|
|
|
|
|
wrapper.find('.item').trigger('click');
|
|
|
|
expect(wrapper.emitted().select).toBeUndefined();
|
|
|
|
|
|
|
|
wrapper.find('.item-body').trigger('click');
|
|
|
|
expect(wrapper.emitted().select).toBeTruthy();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('rename texture', async () => {
|
2018-08-06 13:16:10 +08:00
|
|
|
Vue.prototype.$http.post
|
|
|
|
.mockResolvedValueOnce({ errno: 0 })
|
|
|
|
.mockResolvedValueOnce({ errno: 1 });
|
2018-08-05 14:36:44 +08:00
|
|
|
swal.mockImplementationOnce(() => ({ dismiss: 'cancel' }))
|
|
|
|
.mockImplementation(options => {
|
2018-07-31 10:19:51 +08:00
|
|
|
options.inputValidator('name');
|
2018-08-05 14:36:44 +08:00
|
|
|
options.inputValidator();
|
2018-07-31 10:19:51 +08:00
|
|
|
return { value: 'new-name' };
|
|
|
|
});
|
2018-07-27 16:17:22 +08:00
|
|
|
|
|
|
|
const wrapper = mount(ClosetItem, { propsData: factory() });
|
|
|
|
const button = wrapper.findAll('.dropdown-menu > li').at(0).find('a');
|
|
|
|
|
2018-07-29 08:50:25 +08:00
|
|
|
button.trigger('click');
|
|
|
|
await wrapper.vm.$nextTick();
|
2018-08-06 13:16:10 +08:00
|
|
|
expect(Vue.prototype.$http.post).not.toBeCalled();
|
2018-07-29 08:50:25 +08:00
|
|
|
|
2018-07-27 16:17:22 +08:00
|
|
|
button.trigger('click');
|
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
|
|
|
|
button.trigger('click');
|
2018-08-06 13:16:10 +08:00
|
|
|
await flushPromises();
|
2018-07-27 16:17:22 +08:00
|
|
|
expect(wrapper.find('.texture-name > span').text()).toBe('new-name (steve)');
|
2018-08-06 13:16:10 +08:00
|
|
|
expect(Vue.prototype.$http.post).toBeCalledWith(
|
2018-07-27 16:17:22 +08:00
|
|
|
'/user/closet/rename',
|
|
|
|
{ tid: 1, new_name: 'new-name' }
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('remove texture', async () => {
|
2018-08-06 13:16:10 +08:00
|
|
|
Vue.prototype.$http.post
|
|
|
|
.mockResolvedValueOnce({ errno: 0 })
|
|
|
|
.mockResolvedValueOnce({ errno: 1 });
|
2018-07-31 10:19:51 +08:00
|
|
|
swal
|
|
|
|
.mockResolvedValueOnce({ dismiss: 'cancel' })
|
|
|
|
.mockResolvedValue({});
|
2018-07-27 16:17:22 +08:00
|
|
|
|
|
|
|
const wrapper = mount(ClosetItem, { propsData: factory() });
|
|
|
|
const button = wrapper.findAll('.dropdown-menu > li').at(1).find('a');
|
|
|
|
|
2018-07-29 08:50:25 +08:00
|
|
|
button.trigger('click');
|
|
|
|
await wrapper.vm.$nextTick();
|
2018-08-06 13:16:10 +08:00
|
|
|
expect(Vue.prototype.$http.post).not.toBeCalled();
|
2018-07-29 08:50:25 +08:00
|
|
|
|
2018-07-27 16:17:22 +08:00
|
|
|
button.trigger('click');
|
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
|
|
|
|
button.trigger('click');
|
2018-08-06 09:30:54 +08:00
|
|
|
await flushPromises();
|
2018-08-20 22:19:05 +08:00
|
|
|
expect(wrapper.emitted()['item-removed']).toBeTruthy();
|
2018-08-06 13:16:10 +08:00
|
|
|
expect(Vue.prototype.$http.post).toBeCalledWith('/user/closet/remove', { tid: 1 });
|
2018-07-27 16:17:22 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('set as avatar', async () => {
|
2018-08-06 13:16:10 +08:00
|
|
|
Vue.prototype.$http.post
|
|
|
|
.mockResolvedValueOnce({ errno: 0 })
|
|
|
|
.mockResolvedValueOnce({ errno: 1 });
|
2018-07-31 10:19:51 +08:00
|
|
|
swal
|
|
|
|
.mockResolvedValueOnce({ dismiss: 'cancel' })
|
|
|
|
.mockResolvedValue({});
|
2018-07-27 16:17:22 +08:00
|
|
|
window.$ = jest.fn(() => ({
|
|
|
|
each(fn) { fn(); },
|
|
|
|
prop() {},
|
|
|
|
attr() { return ''; }
|
|
|
|
}));
|
|
|
|
|
|
|
|
const wrapper = mount(ClosetItem, { propsData: factory() });
|
|
|
|
const button = wrapper.findAll('.dropdown-menu > li').at(2).find('a');
|
|
|
|
|
2018-07-29 08:50:25 +08:00
|
|
|
button.trigger('click');
|
|
|
|
await wrapper.vm.$nextTick();
|
2018-08-06 13:16:10 +08:00
|
|
|
expect(Vue.prototype.$http.post).not.toBeCalled();
|
2018-07-29 08:50:25 +08:00
|
|
|
|
2018-07-27 16:17:22 +08:00
|
|
|
button.trigger('click');
|
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
|
|
|
|
button.trigger('click');
|
2018-08-06 09:30:54 +08:00
|
|
|
await flushPromises();
|
2018-08-06 13:16:10 +08:00
|
|
|
await wrapper.vm.$nextTick();
|
|
|
|
expect(Vue.prototype.$http.post).toBeCalledWith('/user/profile/avatar', { tid: 1 });
|
2018-07-27 16:17:22 +08:00
|
|
|
expect(window.$).toBeCalledWith('[alt="User Image"]');
|
|
|
|
});
|