-
Notifications
You must be signed in to change notification settings - Fork 329
/
Copy pathsignUpPageObject.ts
79 lines (67 loc) · 2.33 KB
/
signUpPageObject.ts
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
import { common } from './commonPageObject';
import type { TestArgs } from './signInPageObject';
type SignUpFormInputs = {
email?: string;
password?: string;
firstName?: string;
lastName?: string;
username?: string;
phoneNumber?: string;
legalAccepted?: boolean;
};
export const createSignUpComponentPageObject = (testArgs: TestArgs) => {
const { page } = testArgs;
const self = {
...common(testArgs),
goTo: async (opts?: { searchParams?: URLSearchParams; headlessSelector?: string }) => {
await page.goToRelative('/sign-up', { searchParams: opts?.searchParams });
if (typeof opts?.headlessSelector !== 'undefined') {
return self.waitForMounted(opts.headlessSelector);
}
return self.waitForMounted();
},
waitForMounted: (selector = '.cl-signUp-root') => {
return page.waitForSelector(selector, { state: 'attached' });
},
waitForModal: (state?: 'open' | 'closed') => {
return page.waitForSelector('.cl-modalContent:has(.cl-signUp-root)', {
state: state === 'closed' ? 'detached' : 'attached',
});
},
signUpWithOauth: (provider: string) => {
return page.getByRole('button', { name: new RegExp(`continue with ${provider}`, 'gi') });
},
signUp: async (opts: SignUpFormInputs) => {
if (opts.firstName) {
await self.getFirstNameInput().fill(opts.lastName);
}
if (opts.lastName) {
await self.getLastNameInput().fill(opts.firstName);
}
if (opts.email) {
await self.getEmailAddressInput().fill(opts.email);
}
if (opts.username) {
await self.getUsernameInput().fill(opts.username);
}
if (opts.phoneNumber) {
await self.getPhoneNumberInput().fill(opts.phoneNumber);
}
if (opts.password) {
await self.getPasswordInput().fill(opts.password);
}
if (opts.legalAccepted) {
await self.getLegalAccepted().check();
}
await self.continue();
},
signUpWithEmailAndPassword: async (opts: Pick<SignUpFormInputs, 'email' | 'password'>) => {
await self.signUp({ email: opts.email, password: opts.password });
},
waitForEmailVerificationScreen: async () => {
await page.waitForURL(/verify/);
await page.getByRole('heading', { name: /Verify your email/i }).waitFor();
},
};
return self;
};