import { mount } from '@vue/test-utils';
import { flushPromises } from '../../utils';
import Profile from '@/components/user/Profile';
import axios from 'axios';
import toastr from 'toastr';
import { swal } from '@/js/notify';
jest.mock('axios');
jest.mock('@/js/notify');
test('computed values', () => {
window.__bs_data__ = { admin: true };
const wrapper = mount(Profile);
expect(wrapper.vm.siteName).toBe('Blessing Skin');
expect(wrapper.vm.isAdmin).toBeTrue();
window.__bs_data__ = { admin: false };
expect(mount(Profile).vm.isAdmin).toBeFalse();
});
test('convert linebreak', () => {
const wrapper = mount(Profile);
expect(wrapper.vm.nl2br('a\nb\nc')).toBe('a
b
c');
});
test('change password', async () => {
jest.spyOn(toastr, 'info');
axios.post
.mockResolvedValueOnce({ data: { errno: 1, msg: 'w' } })
.mockResolvedValueOnce({ data: { errno: 0, msg: 'o' } });
swal.mockResolvedValue();
const wrapper = mount(Profile);
const button = wrapper.find('[data-test=changePassword]');
button.trigger('click');
expect(toastr.info).toBeCalledWith('user.emptyPassword');
expect(axios.post).not.toBeCalled();
wrapper.setData({ oldPassword: '1' });
button.trigger('click');
expect(toastr.info).toBeCalledWith('user.emptyNewPassword');
expect(axios.post).not.toBeCalled();
wrapper.setData({ newPassword: '1' });
button.trigger('click');
expect(toastr.info).toBeCalledWith('auth.emptyConfirmPwd');
expect(axios.post).not.toBeCalled();
wrapper.setData({ confirmPassword: '2' });
button.trigger('click');
expect(toastr.info).toBeCalledWith('auth.invalidConfirmPwd');
expect(axios.post).not.toBeCalled();
wrapper.setData({ confirmPassword: '1' });
button.trigger('click');
await wrapper.vm.$nextTick();
expect(axios.post).toBeCalledWith(
'/user/profile?action=password',
{ current_password: '1', new_password: '1' }
);
expect(swal).toBeCalledWith({ type: 'warning', text: 'w' });
button.trigger('click');
await wrapper.vm.$nextTick();
expect(swal).toBeCalledWith({ type: 'success', text: 'o' });
});
test('change nickname', async () => {
axios.post
.mockResolvedValueOnce({ data: { errno: 1, msg: 'w' } })
.mockResolvedValue({ data: { errno: 0, msg: 'o' } });
swal.mockResolvedValueOnce({})
.mockResolvedValueOnce({ dismiss: 1 })
.mockResolvedValue({});
window.$ = jest.fn(() => ({
each(fn) {
fn();
},
html() {}
}));
const wrapper = mount(Profile);
const button = wrapper.find('[data-test=changeNickName]');
button.trigger('click');
expect(axios.post).not.toBeCalled();
expect(swal).toBeCalledWith({ type: 'error', html: 'user.emptyNewNickName' });
wrapper.setData({ nickname: 'nickname' });
button.trigger('click');
expect(axios.post).not.toBeCalled();
expect(swal).toBeCalledWith({
text: 'user.changeNickName',
type: 'question',
showCancelButton: true
});
button.trigger('click');
await wrapper.vm.$nextTick();
expect(axios.post).toBeCalledWith(
'/user/profile?action=nickname',
{ new_nickname: 'nickname' }
);
await wrapper.vm.$nextTick();
expect(swal).toBeCalledWith({ type: 'warning', html: 'w' });
button.trigger('click');
await flushPromises();
expect(swal).toBeCalledWith({ type: 'success', html: 'o' });
});
test('change email', async () => {
axios.post
.mockResolvedValueOnce({ data: { errno: 1, msg: 'w' } })
.mockResolvedValue({ data: { errno: 0, msg: 'o' } });
swal.mockResolvedValueOnce({})
.mockResolvedValueOnce({})
.mockResolvedValueOnce({ dismiss: 1 })
.mockResolvedValue({});
const wrapper = mount(Profile);
const button = wrapper.find('[data-test=changeEmail]');
button.trigger('click');
expect(swal).toBeCalledWith({ type: 'error', html: 'user.emptyNewEmail' });
expect(axios.post).not.toBeCalled();
wrapper.setData({ email: 'e' });
button.trigger('click');
expect(swal).toBeCalledWith({ type: 'warning', html: 'auth.invalidEmail' });
expect(axios.post).not.toBeCalled();
wrapper.setData({ email: 'a@b.c', currentPassword: 'abc' });
button.trigger('click');
expect(swal).toBeCalledWith({
text: 'user.changeEmail',
type: 'question',
showCancelButton: true
});
expect(axios.post).not.toBeCalled();
button.trigger('click');
await wrapper.vm.$nextTick();
expect(axios.post).toBeCalledWith(
'/user/profile?action=email',
{ new_email: 'a@b.c', password: 'abc' }
);
await wrapper.vm.$nextTick();
expect(swal).toBeCalledWith({ type: 'warning', text: 'w' });
button.trigger('click');
await flushPromises();
expect(swal).toBeCalledWith({ type: 'success', text: 'o' });
});
test('delete account', async () => {
window.__bs_data__ = { admin: true };
swal.mockResolvedValue();
axios.post
.mockResolvedValueOnce({ data: { errno: 1, msg: 'w' } })
.mockResolvedValue({ data: { errno: 0, msg: 'o' } });
const wrapper = mount(Profile);
const button = wrapper.find('[data-test=deleteAccount]');
button.trigger('click');
expect(swal).toBeCalledWith({ type: 'warning', html: 'user.emptyDeletePassword' });
expect(axios.post).not.toBeCalled();
wrapper.setData({ deleteConfirm: 'abc' });
button.trigger('click');
expect(axios.post).toBeCalledWith(
'/user/profile?action=delete',
{ password: 'abc' }
);
await wrapper.vm.$nextTick();
expect(swal).toBeCalledWith({ type: 'warning', html: 'w' });
button.trigger('click');
await wrapper.vm.$nextTick();
expect(swal).toBeCalledWith({ type: 'success', html: 'o' });
});