| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  | import { test, expect } from '@playwright/test'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('password login', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "changeme@example.com" | 
					
						
							|  |  |  |     const password = "MyPassword" | 
					
						
							|  |  |  |     const name = "Change Me" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							|  |  |  |     await page.getByLabel('Email or Username', { exact: true }).fill(username); | 
					
						
							|  |  |  |     await page.getByLabel('Password', { exact: true }).fill(password); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login', exact: true }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-11 08:28:54 -05:00
										 |  |  |     // skip admin setup page
 | 
					
						
							|  |  |  |     await page.getByRole('link', { name: "I'm already set up, just bring me to the homepage" }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('ldap login', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "bender" | 
					
						
							|  |  |  |     const password = "bender" | 
					
						
							|  |  |  |     const name = "Bender Bending Rodríguez" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							|  |  |  |     await page.getByLabel('Email or Username', { exact: true }).fill(username); | 
					
						
							|  |  |  |     await page.getByLabel('Password', { exact: true }).fill(password); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login', exact: true }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/g\/home/); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  |     await expect(page.getByRole('link', { name: 'Settings' })).not.toBeVisible(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('ldap admin login', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "professor" | 
					
						
							|  |  |  |     const password = "professor" | 
					
						
							|  |  |  |     const name = "Hubert J. Farnsworth" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							|  |  |  |     await page.getByLabel('Email or Username', { exact: true }).fill(username); | 
					
						
							|  |  |  |     await page.getByLabel('Password', { exact: true }).fill(password); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login', exact: true }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-11 08:28:54 -05:00
										 |  |  |     // skip admin setup page
 | 
					
						
							|  |  |  |     await page.getByRole('link', { name: "I'm already set up, just bring me to the homepage" }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  |     await expect(page.getByRole('link', { name: 'Settings' })).toBeVisible(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('oidc initial login', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "testUser" | 
					
						
							|  |  |  |     const name = "Test User" | 
					
						
							|  |  |  |     const claims = { | 
					
						
							|  |  |  |         "sub": username, | 
					
						
							|  |  |  |         "email": `${username}@example.com`, | 
					
						
							|  |  |  |         "preferred_username": username, | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  |         "name": name, | 
					
						
							|  |  |  |         "groups": ["user"] | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login with OAuth' }).click(); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Enter any user/subject').fill(username); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Optional claims JSON value,').fill(JSON.stringify(claims)); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Sign-in' }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/g\/home/); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  |     await expect(page.getByRole('link', { name: 'Settings' })).not.toBeVisible(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  | test('oidc login with user not in propery group', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "testUserNoGroup" | 
					
						
							|  |  |  |     const name = "Test User No Group" | 
					
						
							|  |  |  |     const claims = { | 
					
						
							|  |  |  |         "sub": username, | 
					
						
							|  |  |  |         "email": `${username}@example.com`, | 
					
						
							|  |  |  |         "preferred_username": username, | 
					
						
							|  |  |  |         "name": name, | 
					
						
							|  |  |  |         "groups": [] | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login with OAuth' }).click(); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Enter any user/subject').fill(username); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Optional claims JSON value,').fill(JSON.stringify(claims)); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Sign-in' }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/login\?direct=1/); | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  |     await expect(page.getByRole('button', { name: 'Login with OAuth' })).toBeVisible() | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  | test('oidc sequential login', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "testUser2" | 
					
						
							|  |  |  |     const name = "Test User 2" | 
					
						
							|  |  |  |     const claims = { | 
					
						
							|  |  |  |         "sub": username, | 
					
						
							|  |  |  |         "email": `${username}@example.com`, | 
					
						
							|  |  |  |         "preferred_username": username, | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  |         "name": name, | 
					
						
							|  |  |  |         "groups": ["user"] | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login with OAuth' }).click(); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Enter any user/subject').fill(username); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Optional claims JSON value,').fill(JSON.stringify(claims)); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Sign-in' }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/g\/home/, { timeout: 15000 }); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Logout' }).click(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/login\?direct=1/); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login with OAuth' }).click(); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Enter any user/subject').fill(username); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Optional claims JSON value,').fill(JSON.stringify(claims)); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Sign-in' }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name, { timeout: 15000 }); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('settings page verify oidc', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "oidcUser" | 
					
						
							|  |  |  |     const name = "OIDC User" | 
					
						
							|  |  |  |     const claims = { | 
					
						
							|  |  |  |         "sub": username, | 
					
						
							|  |  |  |         "email": `${username}@example.com`, | 
					
						
							|  |  |  |         "preferred_username": username, | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  |         "name": name, | 
					
						
							|  |  |  |         "groups": ["user"] | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login with OAuth' }).click(); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Enter any user/subject').fill(username); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Optional claims JSON value,').fill(JSON.stringify(claims)); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Sign-in' }).click(); | 
					
						
							|  |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Logout' }).click(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/login\?direct=1/); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByLabel('Email or Username').click(); | 
					
						
							|  |  |  |     await page.getByLabel('Email or Username').fill('changeme@example.com'); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.getByLabel('Password', { exact: true }).click(); | 
					
						
							|  |  |  |     await page.getByLabel('Password', { exact: true }).fill('MyPassword'); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login', exact: true }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-11 08:28:54 -05:00
										 |  |  |     // skip admin setup page
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/admin\/setup/, { timeout: 15000 }); | 
					
						
							| 
									
										
										
										
											2024-03-11 08:28:54 -05:00
										 |  |  |     await page.getByRole('link', { name: "I'm already set up, just bring me to the homepage" }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/g\/home/); | 
					
						
							|  |  |  |     // validate user settings
 | 
					
						
							|  |  |  |     await page.goto('/admin/manage/users'); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('cell', { name: username, exact: true }).click(); | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page.getByText('Administrator')).toBeVisible(); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('oidc admin user', async ({ page }) => { | 
					
						
							|  |  |  |     const username = "oidcAdmin" | 
					
						
							|  |  |  |     const name = "OIDC Admin" | 
					
						
							|  |  |  |     const claims = { | 
					
						
							|  |  |  |         "sub": username, | 
					
						
							|  |  |  |         "email": `${username}@example.com`, | 
					
						
							|  |  |  |         "preferred_username": username, | 
					
						
							|  |  |  |         "name": name, | 
					
						
							| 
									
										
										
										
											2024-04-18 19:17:45 -05:00
										 |  |  |         "groups": ["user", "admin"] | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await page.goto('/login'); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await page.getByRole('button', { name: 'Login with OAuth' }).click(); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Enter any user/subject').fill(username); | 
					
						
							|  |  |  |     await page.getByPlaceholder('Optional claims JSON value,').fill(JSON.stringify(claims)); | 
					
						
							|  |  |  |     await page.getByRole('button', { name: 'Sign-in' }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-11 08:28:54 -05:00
										 |  |  |     // skip admin setup page
 | 
					
						
							| 
									
										
										
										
											2025-06-20 00:09:12 +07:00
										 |  |  |     await expect(page).toHaveURL(/\/admin\/setup/, { timeout: 15000 }); | 
					
						
							| 
									
										
										
										
											2024-03-11 08:28:54 -05:00
										 |  |  |     await page.getByRole('link', { name: "I'm already set up, just bring me to the homepage" }).click(); | 
					
						
							| 
									
										
										
										
											2024-03-10 13:51:36 -05:00
										 |  |  |     await expect(page.getByRole('navigation')).toContainText(name); | 
					
						
							|  |  |  |     await expect(page.getByRole('link', { name: 'Settings' })).toBeVisible(); | 
					
						
							|  |  |  | }); |