Ocelot-Social/webapp/pages/password-reset/change-password.spec.js

106 lines
2.7 KiB
JavaScript

import { mount } from '@vue/test-utils'
import changePassword from './change-password'
const localVue = global.localVue
const stubs = {
'sweetalert-icon': true,
'nuxt-link': true,
}
describe('change-password', () => {
let wrapper
let Wrapper
let mocks
beforeEach(() => {
mocks = {
$toast: {
success: jest.fn(),
error: jest.fn(),
},
$t: jest.fn((key) => key),
$route: {
query: { email: 'mail@example.org', nonce: '12345' },
},
$router: {
push: jest.fn(),
},
$apollo: {
loading: false,
mutate: jest.fn().mockResolvedValue({ data: { resetPassword: true } }),
},
}
})
describe('mount', () => {
beforeEach(() => {
jest.useFakeTimers()
})
Wrapper = () => {
return mount(changePassword, {
mocks,
localVue,
stubs,
})
}
it('renders', () => {
wrapper = Wrapper()
expect(wrapper.findAll('form')).toHaveLength(1)
})
describe('submitting new password', () => {
beforeEach(() => {
wrapper = Wrapper()
wrapper.find('input#password').setValue('supersecret')
wrapper.find('input#passwordConfirmation').setValue('supersecret')
wrapper.find('form').trigger('submit')
})
it('calls resetPassword graphql mutation', () => {
expect(mocks.$apollo.mutate).toHaveBeenCalled()
})
it('delivers new password to backend', () => {
const expected = expect.objectContaining({
variables: { nonce: '12345', email: 'mail@example.org', password: 'supersecret' },
})
expect(mocks.$apollo.mutate).toHaveBeenCalledWith(expected)
})
describe('password reset successful', () => {
it('displays success message', () => {
const expected = 'components.password-reset.change-password.success'
expect(mocks.$t).toHaveBeenCalledWith(expected)
})
describe('after animation', () => {
beforeEach(jest.runAllTimers)
it('redirects to login', () => {
expect(mocks.$router.push).toHaveBeenCalledWith('/login')
})
})
})
describe('password reset not successful', () => {
beforeEach(() => {
mocks.$apollo.mutate = jest.fn().mockRejectedValue({
message: 'Ouch!',
})
wrapper = Wrapper()
wrapper.find('input#password').setValue('supersecret')
wrapper.find('input#passwordConfirmation').setValue('supersecret')
wrapper.find('form').trigger('submit')
})
it('display a toast error', () => {
expect(mocks.$toast.error).toHaveBeenCalled()
})
})
})
})
})