|
6 | 6 | */ |
7 | 7 | import { expect, test } from '@playwright/test'; |
8 | 8 | import { asyncEvents } from './utils/async-events.js'; |
9 | | -// |
10 | | -test('Test happy paths on test page', async ({ page }) => { |
| 9 | +import { password } from './utils/demo-user.js'; |
| 10 | + |
| 11 | +test('Using ACR Values, lets render an OTP form and submit the request', async ({ page }) => { |
11 | 12 | const { navigate } = asyncEvents(page); |
12 | 13 | await navigate( |
13 | | - '/?clientId=20dd0ed0-bb9b-4c8f-9a60-9ebeb4b348e0&acr_value=93928296ac55765e57e30b99da8ddabe', |
| 14 | + '/?clientId=20dd0ed0-bb9b-4c8f-9a60-9ebeb4b348e0&acr_value=22eb75b5d31d371afe089d6e4a824f5c', |
14 | 15 | ); |
15 | 16 |
|
16 | | - expect(page.url()).toBe('http://localhost:5829/?clientId=20dd0ed0-bb9b-4c8f-9a60-9ebeb4b348e0'); |
17 | | - |
18 | | - await expect(page.getByText('Create Your Profile')).toBeVisible(); |
19 | | - |
20 | | - await page.getByLabel('Email Address').fill('test@test.com'); |
21 | | - await page.getByLabel('Password').fill('apassword'); |
22 | | - await page.getByLabel('Placeholder').fill('12345678901'); |
23 | | - |
24 | | - const requestPromise = page.waitForRequest((request) => |
25 | | - request |
26 | | - .url() |
27 | | - .includes( |
28 | | - 'https://auth.pingone.ca/02fb4743-189a-4bc7-9d6c-a919edfe6447/davinci/connections/8209285e0d2f3fc76bfd23fd10d45e6f/capabilities/customForm?next=true', |
29 | | - ), |
| 17 | + expect(page.url()).toBe( |
| 18 | + 'http://localhost:5829/?clientId=20dd0ed0-bb9b-4c8f-9a60-9ebeb4b348e0&acr_value=22eb75b5d31d371afe089d6e4a824f5c', |
30 | 19 | ); |
31 | 20 |
|
| 21 | + await page.getByLabel('Email Address').fill('mfauser+' + Date.now() + '@user.com'); |
| 22 | + await page.getByLabel('Password').fill(password); |
| 23 | + await page.getByLabel('Placeholder').fill('12345678901'); |
32 | 24 | await page.getByRole('button', { name: 'Submit' }).click(); |
33 | 25 |
|
34 | | - const request = await requestPromise; |
35 | | - const postedData = JSON.parse(request.postData()); |
36 | | - const data = postedData.parameters.data; |
37 | | - expect(data).toEqual({ |
38 | | - actionKey: 'submit', |
39 | | - formData: { |
40 | | - 'user.email': 'test@test.com', |
41 | | - 'user.password': 'apassword', |
42 | | - 'phone-field': { phoneNumber: '12345678901', countryCode: 'CA' }, |
43 | | - }, |
44 | | - }); |
45 | | -}); |
46 | | -test('should validate that phone number is sent correctly in the outgoing response', async ({ |
47 | | - page, |
48 | | -}) => { |
49 | | - const { navigate } = asyncEvents(page); |
50 | | - await navigate('/?clientId=20dd0ed0-bb9b-4c8f-9a60-9ebeb4b348e0'); |
| 26 | + await page.getByRole('button', { name: 'Text Message' }).click(); |
51 | 27 |
|
52 | | - expect(page.url()).toBe('http://localhost:5829/?clientId=20dd0ed0-bb9b-4c8f-9a60-9ebeb4b348e0'); |
| 28 | + await page.waitForEvent('requestfinished'); |
53 | 29 |
|
54 | | - await expect(page.getByText('Create Your Profile')).toBeVisible(); |
| 30 | + await page.getByText('MFA - Enter Phone Number'); |
55 | 31 |
|
56 | | - await page.getByLabel('Email Address').fill('test@test.com'); |
57 | | - await page.getByLabel('Password').fill('apassword'); |
58 | | - await page.getByLabel('Placeholder').fill('12345678901'); |
| 32 | + await page.getByLabel('Country Code').selectOption('United States (1)'); |
| 33 | + await page.getByLabel('Enter Phone Number').fill('12345678901'); |
59 | 34 |
|
60 | | - const requestPromise = page.waitForRequest((request) => |
61 | | - request |
62 | | - .url() |
63 | | - .includes( |
64 | | - 'https://auth.pingone.ca/02fb4743-189a-4bc7-9d6c-a919edfe6447/davinci/connections/8209285e0d2f3fc76bfd23fd10d45e6f/capabilities/customForm?next=true', |
65 | | - ), |
| 35 | + const request = page.waitForRequest((request) => |
| 36 | + request.url().endsWith('/capabilities/customForm?next=true'), |
66 | 37 | ); |
67 | | - |
68 | 38 | await page.getByRole('button', { name: 'Submit' }).click(); |
69 | | - |
70 | | - const request = await requestPromise; |
71 | | - const postedData = JSON.parse(request.postData()); |
| 39 | + const posted = await request; |
| 40 | + const postedData = JSON.parse(posted.postData()); |
72 | 41 | const data = postedData.parameters.data; |
73 | 42 | expect(data).toEqual({ |
74 | 43 | actionKey: 'submit', |
75 | 44 | formData: { |
76 | | - 'user.email': 'test@test.com', |
77 | | - 'user.password': 'apassword', |
78 | | - 'phone-field': { phoneNumber: '12345678901', countryCode: 'CA' }, |
| 45 | + countryCode: '1', |
| 46 | + phoneNumber: '12345678901', |
79 | 47 | }, |
80 | 48 | }); |
81 | 49 | }); |
0 commit comments