forked from oppia/oppia
-
Notifications
You must be signed in to change notification settings - Fork 0
/
puppeteer-login-script.js
149 lines (139 loc) · 5.34 KB
/
puppeteer-login-script.js
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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
// Copyright 2014 The Oppia Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the 'License');
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an 'AS-IS' BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/**
* @fileoverview Login script to access pages behind authentication for
* lighthouse checks
* @param {puppeteer.Browser} browser
* @param {{url: string, options: LHCI.CollectCommand.Options}} context
*/
const LOGIN_URL = 'http://localhost:8181/login';
const CREATOR_DASHBOARD_URL = 'http://localhost:8181/creator-dashboard';
const networkIdle = 'networkidle0';
var emailInput = '.e2e-test-sign-in-email-input';
var signInButton = '.e2e-test-sign-in-button';
var usernameInput = '.e2e-test-username-input';
var agreeToTermsCheckBox = '.e2e-test-agree-to-terms-checkbox';
var registerUser = '.e2e-test-register-user:not([disabled])';
var navbarToggle = '.oppia-navbar-dropdown-toggle';
var usernameInputFieldForRolesEditing = (
'.e2e-test-username-for-role-editor');
var editUserRoleButton = '.e2e-test-role-edit-button';
var roleEditorContainer = '.e2e-test-roles-editor-card-container';
var addNewRoleButton = '.e2e-test-add-new-role-button';
var roleSelect = '.e2e-test-new-role-selector';
module.exports = async(browser, context) => {
const page = await browser.newPage();
await page.setDefaultNavigationTimeout(0);
// Sign into Oppia.
await login(context, page);
if (context.url.includes('moderator')) {
await setRole(page, 'MODERATOR');
} else if (context.url.includes('emaildashboard')) {
await setRole(page, 'ADMIN');
} else if (context.url.includes('collection/0')) {
await createCollections(context, page);
} else if (context.url.includes('explore/0')) {
await createExplorations(context, page);
} else if (context.url.includes('blog-dashboard')) {
await setRole(page, 'BLOG_ADMIN');
}
await page.close();
};
// Needed to relogin after lighthouse_setup.js.
const login = async function(context, page) {
try {
// eslint-disable-next-line dot-notation
await page.goto(LOGIN_URL, {waitUntil: networkIdle});
// The user is already logged in.
if (!page.url().includes('login')) {
return;
}
await page.waitForSelector(emailInput, {visible: true});
await page.type(emailInput, '[email protected]');
await page.click(signInButton);
// Checks if the user's account was already made.
try {
await page.waitForSelector(usernameInput, {visible: true});
await page.type(usernameInput, 'username1');
await page.click(agreeToTermsCheckBox);
await page.waitForSelector(registerUser);
await page.click(registerUser);
await page.waitForSelector(navbarToggle);
} catch (error) {
// Already Signed in.
}
} catch (e) {
// eslint-disable-next-line no-console
console.log(e);
}
};
const setRole = async function(page, role) {
try {
// eslint-disable-next-line dot-notation
await page.goto(
'http://localhost:8181/admin#/roles', { waitUntil: networkIdle });
await page.waitForSelector(usernameInputFieldForRolesEditing);
await page.type(usernameInputFieldForRolesEditing, 'username1');
await page.waitForSelector(editUserRoleButton);
await page.click(editUserRoleButton);
await page.waitForSelector(roleEditorContainer);
await page.waitForSelector(addNewRoleButton);
await page.click(addNewRoleButton);
await page.click(roleSelect);
var selector = `mat-option[ng-reflect-value="${role}"]`;
await page.click(selector);
await page.waitForTimeout(2000);
// eslint-disable-next-line dot-notation
await page.goto(CREATOR_DASHBOARD_URL, { waitUntil: networkIdle});
} catch (e) {
// eslint-disable-next-line no-console
console.log(e);
}
};
const createCollections = async function(context, page) {
try {
// eslint-disable-next-line no-console
console.log('Creating Collections...');
await setRole(page, 'COLLECTION_EDITOR');
// Load in Collection
// eslint-disable-next-line dot-notation
await page.goto('http://localhost:8181/admin');
await page.waitForTimeout(2000);
await page.evaluate('window.confirm = () => true');
await page.click('#reload-collection-button-id');
// eslint-disable-next-line no-console
console.log('Collections Created');
} catch (e) {
// eslint-disable-next-line no-console
console.log(e);
}
};
const createExplorations = async function(context, page) {
try {
// eslint-disable-next-line no-console
console.log('Creating Exploration...');
// Load in Exploration
// eslint-disable-next-line dot-notation
await page.goto('http://localhost:8181/admin', { waitUntil: 'networkidle0' });
await page.waitForTimeout(2000);
await page.evaluate('window.confirm = () => true');
await page.click(
'.e2e-test-reload-exploration-button');
// eslint-disable-next-line no-console
console.log('Exploration Created');
} catch (e) {
// eslint-disable-next-line no-console
console.log(e);
}
};