-
Notifications
You must be signed in to change notification settings - Fork 23
Expand file tree
/
Copy pathproject-access.e2e.ts
More file actions
118 lines (102 loc) · 3.98 KB
/
project-access.e2e.ts
File metadata and controls
118 lines (102 loc) · 3.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
*
* Copyright Oxide Computer Company
*/
import { user3, user4 } from '@oxide/api-mocks'
import { expect, expectNotVisible, expectRowVisible, expectVisible, test } from './utils'
test('Click through project access page', async ({ page }) => {
await page.goto('/projects/mock-project')
await page.click('role=link[name*="Access"]')
// we see groups and users 1, 3, 6 but not users 2, 4, 5
await expectVisible(page, ['role=heading[name*="Access"]'])
const table = page.locator('table')
await expectRowVisible(table, {
Name: 'Hannah Arendt',
Type: 'User',
Role: 'silo.admin',
})
await expectRowVisible(table, {
Name: 'Jacob Klein',
Type: 'User',
Role: 'project.collaborator',
})
await expectRowVisible(table, {
Name: 'Herbert Marcuse',
Type: 'User',
Role: 'project.limited_collaborator',
})
await expectRowVisible(table, {
Name: 'real-estate-devs',
Type: 'Group',
Role: 'silo.collaborator',
})
await expectRowVisible(table, {
Name: 'kernel-devs',
Type: 'Group',
Role: 'project.viewer',
})
await expectNotVisible(page, [
`role=cell[name="Hans Jonas"]`,
`role=cell[name="Simone de Beauvoir"]`,
])
// Add user 4 as collab
await page.click('role=button[name="Add user or group"]')
await expectVisible(page, ['role=heading[name*="Add user or group"]'])
await page.click('role=button[name*="User or group"]')
// only users not already on the project should be visible
await expectNotVisible(page, [
'role=option[name="Jacob Klein"]',
'role=option[name="Herbert Marcuse"]',
])
await expectVisible(page, [
'role=option[name="Hannah Arendt"]',
'role=option[name="Hans Jonas"]',
'role=option[name="Simone de Beauvoir"]',
])
await page.click('role=option[name="Simone de Beauvoir"]')
await page.getByRole('radio', { name: /^Collaborator / }).click()
await page.click('role=button[name="Assign role"]')
// User 4 shows up in the table
await expectRowVisible(table, {
Name: 'Simone de Beauvoir',
Type: 'User',
Role: 'project.collaborator',
})
// now change user 4 role from collab to viewer
await page
.locator('role=row', { hasText: user4.display_name })
.locator('role=button[name="Row actions"]')
.click()
await page.click('role=menuitem[name="Change role"]')
await expectVisible(page, ['role=heading[name*="Edit role"]'])
// Verify Collaborator is currently selected
await expect(page.getByRole('radio', { name: /^Collaborator / })).toBeChecked()
// Select Viewer role
await page.getByRole('radio', { name: /^Viewer / }).click()
await page.click('role=button[name="Update role"]')
await expectRowVisible(table, { Name: user4.display_name, Role: 'project.viewer' })
// now delete user 3. has to be 3 or 4 because they're the only ones that come
// from the project policy
const user3Row = page.getByRole('row', { name: user3.display_name, exact: false })
await expect(user3Row).toBeVisible()
await user3Row.getByRole('button', { name: 'Row actions' }).click()
await page.getByRole('menuitem', { name: 'Delete' }).click()
await page.getByRole('button', { name: 'Confirm' }).click()
await expect(user3Row).toBeHidden()
// now add a project role to user 1, who currently only has silo role
await page.click('role=button[name="Add user or group"]')
await page.click('role=button[name*="User or group"]')
await page.click('role=option[name="Hannah Arendt"]')
// Select Viewer role
await page.getByRole('radio', { name: /^Viewer / }).click()
await page.click('role=button[name="Assign role"]')
// because we only show the "effective" role, we should still see the silo admin role, but should now have an additional count value
await expectRowVisible(table, {
Name: 'Hannah Arendt',
Type: 'User',
Role: 'silo.admin+1',
})
})