2023-06-25 22:12:46 -05:00
|
|
|
import {expect, test} from '@playwright/test';
|
2023-08-03 03:29:14 -05:00
|
|
|
import {globalDataRequests, mockApi, responseFixtures} from '../../../utils/e2e';
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
test.describe('User actions', async () => {
|
|
|
|
test('Supports suspending a user', async ({page}) => {
|
2023-08-03 03:29:14 -05:00
|
|
|
const userToEdit = responseFixtures.users.users.find(user => user.email === 'author@test.com')!;
|
|
|
|
|
|
|
|
const {lastApiRequests} = await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
browseUsers: {method: 'GET', path: '/users/?limit=all&include=roles', response: responseFixtures.users},
|
2023-08-10 07:04:23 -05:00
|
|
|
editUser: {method: 'PUT', path: `/users/${userToEdit.id}/?include=roles`, response: {
|
2023-08-03 03:29:14 -05:00
|
|
|
users: [{
|
|
|
|
...userToEdit,
|
|
|
|
status: 'inactive'
|
|
|
|
}]
|
|
|
|
}}
|
2023-06-25 22:12:46 -05:00
|
|
|
}});
|
|
|
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
|
|
|
const section = page.getByTestId('users');
|
|
|
|
const activeTab = section.locator('[role=tabpanel]:not(.hidden)');
|
|
|
|
|
|
|
|
await section.getByRole('tab', {name: 'Authors'}).click();
|
|
|
|
|
|
|
|
const listItem = activeTab.getByTestId('user-list-item').last();
|
|
|
|
await listItem.hover();
|
|
|
|
await listItem.getByRole('button', {name: 'Edit'}).click();
|
|
|
|
|
|
|
|
const modal = page.getByTestId('user-detail-modal');
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Actions'}).click();
|
2023-08-14 07:11:53 -05:00
|
|
|
await page.getByTestId('popover-content').getByRole('button', {name: 'Suspend user'}).click();
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
const confirmation = page.getByTestId('confirmation-modal');
|
|
|
|
await confirmation.getByRole('button', {name: 'Suspend'}).click();
|
|
|
|
|
|
|
|
await expect(modal).toHaveText(/Suspended/);
|
|
|
|
|
2023-08-03 03:29:14 -05:00
|
|
|
expect(lastApiRequests.editUser?.body).toMatchObject({
|
2023-06-25 22:12:46 -05:00
|
|
|
users: [{
|
|
|
|
email: 'author@test.com',
|
|
|
|
status: 'inactive'
|
|
|
|
}]
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Supports un-suspending a user', async ({page}) => {
|
2023-08-03 03:29:14 -05:00
|
|
|
const userToEdit = responseFixtures.users.users.find(user => user.email === 'author@test.com')!;
|
|
|
|
|
|
|
|
const {lastApiRequests} = await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
browseUsers: {method: 'GET', path: '/users/?limit=all&include=roles', response: {
|
|
|
|
users: [
|
|
|
|
...responseFixtures.users.users.filter(user => user.email !== 'author@test.com'),
|
|
|
|
{
|
|
|
|
...userToEdit,
|
|
|
|
status: 'inactive'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}},
|
2023-08-10 07:04:23 -05:00
|
|
|
editUser: {method: 'PUT', path: `/users/${userToEdit.id}/?include=roles`, response: {
|
2023-08-03 03:29:14 -05:00
|
|
|
users: [{
|
|
|
|
...userToEdit,
|
|
|
|
status: 'active'
|
|
|
|
}]
|
|
|
|
}}
|
2023-06-25 22:12:46 -05:00
|
|
|
}});
|
|
|
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
|
|
|
const section = page.getByTestId('users');
|
|
|
|
const activeTab = section.locator('[role=tabpanel]:not(.hidden)');
|
|
|
|
|
|
|
|
await section.getByRole('tab', {name: 'Authors'}).click();
|
|
|
|
|
|
|
|
const listItem = activeTab.getByTestId('user-list-item').last();
|
|
|
|
await listItem.hover();
|
|
|
|
await listItem.getByRole('button', {name: 'Edit'}).click();
|
|
|
|
|
|
|
|
const modal = page.getByTestId('user-detail-modal');
|
|
|
|
|
|
|
|
await expect(modal).toHaveText(/Suspended/);
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Actions'}).click();
|
2023-08-14 07:11:53 -05:00
|
|
|
await page.getByTestId('popover-content').getByRole('button', {name: 'Un-suspend user'}).click();
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
const confirmation = page.getByTestId('confirmation-modal');
|
|
|
|
await confirmation.getByRole('button', {name: 'Un-suspend'}).click();
|
|
|
|
|
|
|
|
await expect(modal).not.toHaveText(/Suspended/);
|
|
|
|
|
2023-08-03 03:29:14 -05:00
|
|
|
expect(lastApiRequests.editUser?.body).toMatchObject({
|
2023-06-25 22:12:46 -05:00
|
|
|
users: [{
|
|
|
|
email: 'author@test.com',
|
|
|
|
status: 'active'
|
|
|
|
}]
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Supports deleting a user', async ({page}) => {
|
|
|
|
const authorUser = responseFixtures.users.users.find(user => user.email === 'author@test.com')!;
|
|
|
|
|
2023-08-03 03:29:14 -05:00
|
|
|
const {lastApiRequests} = await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
browseUsers: {method: 'GET', path: '/users/?limit=all&include=roles', response: responseFixtures.users},
|
|
|
|
deleteUser: {method: 'DELETE', path: `/users/${authorUser.id}/`, response: {}}
|
|
|
|
}});
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
|
|
|
const section = page.getByTestId('users');
|
|
|
|
const activeTab = section.locator('[role=tabpanel]:not(.hidden)');
|
|
|
|
|
|
|
|
await section.getByRole('tab', {name: 'Authors'}).click();
|
|
|
|
|
|
|
|
const listItem = activeTab.getByTestId('user-list-item').last();
|
|
|
|
await listItem.hover();
|
|
|
|
await listItem.getByRole('button', {name: 'Edit'}).click();
|
|
|
|
|
|
|
|
const modal = page.getByTestId('user-detail-modal');
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Actions'}).click();
|
2023-08-14 07:11:53 -05:00
|
|
|
await page.getByTestId('popover-content').getByRole('button', {name: 'Delete user'}).click();
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
const confirmation = page.getByTestId('confirmation-modal');
|
|
|
|
await confirmation.getByRole('button', {name: 'Delete user'}).click();
|
|
|
|
|
|
|
|
await expect(page.getByTestId('toast')).toHaveText(/User deleted/);
|
|
|
|
await expect(activeTab.getByTestId('user-list-item')).toHaveCount(0);
|
|
|
|
|
2023-08-03 03:29:14 -05:00
|
|
|
expect(lastApiRequests.deleteUser?.url).toMatch(new RegExp(`/users/${authorUser.id}`));
|
2023-06-25 22:12:46 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
test('Supports transferring ownership to an administrator', async ({page}) => {
|
|
|
|
const administrator = responseFixtures.users.users.find(user => user.email === 'administrator@test.com')!;
|
|
|
|
|
2023-08-03 03:29:14 -05:00
|
|
|
const makeOwnerResponse = {
|
|
|
|
users: [
|
|
|
|
...responseFixtures.users.users.filter(user => user.email !== 'administrator@test.com' && user.email !== 'owner@test.com'),
|
|
|
|
{
|
|
|
|
...administrator,
|
|
|
|
roles: [responseFixtures.roles.roles.find(role => role.name === 'Owner')!]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
...responseFixtures.users.users.find(user => user.email === 'owner@test.com')!,
|
|
|
|
roles: [responseFixtures.roles.roles.find(role => role.name === 'Administrator')!]
|
2023-06-25 22:12:46 -05:00
|
|
|
}
|
2023-08-03 03:29:14 -05:00
|
|
|
]
|
|
|
|
};
|
|
|
|
|
|
|
|
const {lastApiRequests} = await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
browseUsers: {method: 'GET', path: '/users/?limit=all&include=roles', response: responseFixtures.users},
|
2023-08-10 07:04:23 -05:00
|
|
|
editUser: {method: 'PUT', path: /^\/users\/\w{24}\/\?include=roles$/, response: responseFixtures.users},
|
2023-08-03 03:29:14 -05:00
|
|
|
makeOwner: {method: 'PUT', path: '/users/owner/', response: makeOwnerResponse}
|
2023-06-25 22:12:46 -05:00
|
|
|
}});
|
|
|
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
|
|
|
const section = page.getByTestId('users');
|
|
|
|
const activeTab = section.locator('[role=tabpanel]:not(.hidden)');
|
|
|
|
const listItem = activeTab.getByTestId('user-list-item').last();
|
|
|
|
const modal = page.getByTestId('user-detail-modal');
|
|
|
|
|
|
|
|
// Can't transfer to a role other than administrator
|
|
|
|
|
|
|
|
await section.getByRole('tab', {name: 'Editors'}).click();
|
|
|
|
|
|
|
|
await listItem.hover();
|
|
|
|
await listItem.getByRole('button', {name: 'Edit'}).click();
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Actions'}).click();
|
2023-08-14 07:11:53 -05:00
|
|
|
await expect(page.getByTestId('popover-content').getByRole('button', {name: 'Make owner'})).toHaveCount(0);
|
|
|
|
await page.getByTestId('popover-overlay').click();
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Close'}).click();
|
|
|
|
|
|
|
|
// Can transfer to an administrator
|
|
|
|
|
|
|
|
await section.getByRole('tab', {name: 'Administrators'}).click();
|
|
|
|
|
|
|
|
await listItem.hover();
|
|
|
|
await listItem.getByRole('button', {name: 'Edit'}).click();
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Actions'}).click();
|
2023-08-14 07:11:53 -05:00
|
|
|
await page.getByTestId('popover-content').getByRole('button', {name: 'Make owner'}).click();
|
2023-06-25 22:12:46 -05:00
|
|
|
|
|
|
|
const confirmation = page.getByTestId('confirmation-modal');
|
|
|
|
await confirmation.getByRole('button', {name: 'Yep — I\'m sure'}).click();
|
|
|
|
|
|
|
|
await expect(page.getByTestId('toast')).toHaveText(/Ownership transferred/);
|
|
|
|
|
|
|
|
await expect(section.getByTestId('owner-user')).toHaveText(/administrator@test\.com/);
|
|
|
|
|
2023-08-03 03:29:14 -05:00
|
|
|
expect(lastApiRequests.makeOwner?.body).toMatchObject({
|
2023-06-25 22:12:46 -05:00
|
|
|
owner: [{
|
|
|
|
id: administrator.id
|
|
|
|
}]
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|