mirror of
https://github.com/overleaf/overleaf.git
synced 2024-10-24 21:12:38 -04:00
5498d59c6b
Migrating admin panel register new user to react GitOrigin-RevId: 520fea91cd9e560e4381504de45e5bedf11a7844
139 lines
4.7 KiB
JavaScript
139 lines
4.7 KiB
JavaScript
import { expect } from 'chai'
|
|
import { render, screen, fireEvent } from '@testing-library/react'
|
|
import fetchMock from 'fetch-mock'
|
|
import UserActivateRegister from '../../../../frontend/js/components/user-activate-register'
|
|
|
|
describe('UserActivateRegister', function () {
|
|
beforeEach(function () {
|
|
fetchMock.reset()
|
|
})
|
|
afterEach(function () {
|
|
fetchMock.reset()
|
|
})
|
|
it('should display the error message', async function () {
|
|
const email = 'abc@gmail.com'
|
|
render(<UserActivateRegister />)
|
|
const endPointResponse = {
|
|
status: 500,
|
|
}
|
|
const registerMock = fetchMock.post('/admin/register', endPointResponse)
|
|
const registerInput = screen.getByLabelText('emails to register')
|
|
const registerButton = screen.getByRole('button', { name: /register/i })
|
|
|
|
fireEvent.change(registerInput, { target: { value: email } })
|
|
fireEvent.click(registerButton)
|
|
|
|
expect(registerMock.called()).to.be.true
|
|
await screen.findByText('Sorry, an error occured', { exact: false })
|
|
})
|
|
|
|
it('should display the success message', async function () {
|
|
const email = 'abc@gmail.com'
|
|
render(<UserActivateRegister />)
|
|
const endPointResponse = {
|
|
status: 200,
|
|
body: {
|
|
email,
|
|
setNewPasswordUrl: 'SetNewPasswordURL',
|
|
},
|
|
}
|
|
const registerMock = fetchMock.post('/admin/register', endPointResponse)
|
|
const registerInput = screen.getByLabelText('emails to register')
|
|
const registerButton = screen.getByRole('button', { name: /register/i })
|
|
|
|
fireEvent.change(registerInput, { target: { value: email } })
|
|
fireEvent.click(registerButton)
|
|
|
|
expect(registerMock.called()).to.be.true
|
|
await screen.findByText(
|
|
"We've sent out welcome emails to the registered users."
|
|
)
|
|
})
|
|
|
|
it('should display the registered emails', async function () {
|
|
const email = 'abc@gmail.com, def@gmail.com'
|
|
render(<UserActivateRegister />)
|
|
const endPointResponse1 = {
|
|
status: 200,
|
|
body: {
|
|
email: 'abc@gmail.com',
|
|
setNewPasswordUrl: 'SetNewPasswordURL',
|
|
},
|
|
}
|
|
const endPointResponse2 = {
|
|
status: 200,
|
|
body: {
|
|
email: 'def@gmail.com',
|
|
setNewPasswordUrl: 'SetNewPasswordURL',
|
|
},
|
|
}
|
|
const registerMock = fetchMock.post('/admin/register', (path, req) => {
|
|
const body = JSON.parse(req.body)
|
|
if (body.email === 'abc@gmail.com') return endPointResponse1
|
|
else if (body.email === 'def@gmail.com') return endPointResponse2
|
|
})
|
|
const registerInput = screen.getByLabelText('emails to register')
|
|
const registerButton = screen.getByRole('button', { name: /register/i })
|
|
|
|
fireEvent.change(registerInput, { target: { value: email } })
|
|
fireEvent.click(registerButton)
|
|
|
|
expect(registerMock.called()).to.be.true
|
|
await screen.findByText('abc@gmail.com')
|
|
await screen.findByText('def@gmail.com')
|
|
})
|
|
|
|
it('should display the failed emails', async function () {
|
|
const email = 'abc@, def@'
|
|
render(<UserActivateRegister />)
|
|
const endPointResponse1 = {
|
|
status: 500,
|
|
}
|
|
const endPointResponse2 = {
|
|
status: 500,
|
|
}
|
|
const registerMock = fetchMock.post('/admin/register', (path, req) => {
|
|
const body = JSON.parse(req.body)
|
|
if (body.email === 'abc@') return endPointResponse1
|
|
else if (body.email === 'def@') return endPointResponse2
|
|
})
|
|
const registerInput = screen.getByLabelText('emails to register')
|
|
const registerButton = screen.getByRole('button', { name: /register/i })
|
|
|
|
fireEvent.change(registerInput, { target: { value: email } })
|
|
fireEvent.click(registerButton)
|
|
|
|
expect(registerMock.called()).to.be.true
|
|
await screen.findByText('abc@')
|
|
await screen.findByText('def@')
|
|
})
|
|
|
|
it('should display the registered and failed emails together', async function () {
|
|
const email = 'abc@gmail.com, def@'
|
|
render(<UserActivateRegister />)
|
|
const endPointResponse1 = {
|
|
status: 200,
|
|
body: {
|
|
email: 'abc@gmail.com',
|
|
setNewPasswordUrl: 'SetNewPasswordURL',
|
|
},
|
|
}
|
|
const endPointResponse2 = {
|
|
status: 500,
|
|
}
|
|
const registerMock = fetchMock.post('/admin/register', (path, req) => {
|
|
const body = JSON.parse(req.body)
|
|
if (body.email === 'abc@gmail.com') return endPointResponse1
|
|
else if (body.email === 'def@gmail.com') return endPointResponse2
|
|
})
|
|
const registerInput = screen.getByLabelText('emails to register')
|
|
const registerButton = screen.getByRole('button', { name: /register/i })
|
|
|
|
fireEvent.change(registerInput, { target: { value: email } })
|
|
fireEvent.click(registerButton)
|
|
|
|
expect(registerMock.called()).to.be.true
|
|
await screen.findByText('abc@gmail.com')
|
|
await screen.findByText('def@')
|
|
})
|
|
})
|