Files
piratepoet/mailpoet/tests/performance/utils/helpers.js
2024-06-27 15:31:44 +03:00

160 lines
5.0 KiB
JavaScript

/**
* Internal dependencies
*/
import {
baseURL,
adminUsername,
adminPassword,
fromName,
adminEmail,
fullPageSet,
screenshotPath,
} from '../config.js';
/* global Promise */
// WordPress login authorization
export async function login(page) {
// Go to WP Admin login page
await Promise.all([
page.goto(`${baseURL}/wp-login.php`, { waitUntil: 'networkidle' }),
page.waitForSelector('#user_login'),
]);
// Enter login credentials and login
await page.waitForLoadState('networkidle');
await page.locator('input[name="log"]').type(`${adminUsername}`);
await page.locator('input[name="pwd"]').type(`${adminPassword}`);
// Wait for asynchronous operations to complete
await Promise.all([
page.waitForNavigation(),
page.locator('input[name="wp-submit"]').click(),
]);
}
// Select a segment or a list from a select2 search field
export async function selectInSelect2(page, listName) {
// Type a list name from a dropdown and hit Enter
await page.locator('.select2-selection').type(listName);
await page.keyboard.press('Enter');
}
// Select a segment or a list from a react search field
export async function selectInReact(page, reactSelector, reactValue) {
// Type a list name from a dropdown and hit Enter
await page.locator(reactSelector).type(reactValue);
await page.keyboard.press('Enter');
}
// Focus and click the element
export async function focusAndClick(page, element) {
await page.locator(element).waitFor({ trial: true });
await page.locator(element).focus();
await page.locator(element).click();
}
// Wait and click the element
export async function waitAndClick(page, element) {
await page.waitForSelector(element);
await page.locator(element).click();
}
// Wait and type on the element
export async function waitAndType(page, element, text) {
await page.locator(element).waitFor({ state: 'visible' });
await page.locator(element).type(text, { delay: 25 });
}
// Wait for selector to be visible
export async function waitForSelectorToBeVisible(page, element) {
await page.locator(element).waitFor({ state: 'visible' });
}
// Wait for selector to be available
export async function waitForSelectorToBeClickable(page, element) {
await page.locator(element).waitFor({ trial: true });
}
// Add an item to the automation workflow
export async function addActionTriggerItemToWorkflow(page, actionName) {
await page.locator('.components-input-control__input').type(actionName);
await page.keyboard.press('Tab');
await page.keyboard.press('Tab');
await page.keyboard.press('Enter');
}
// Add value to an action in automations workflow
export async function addValueToActionInWorkflow(page, actionValue) {
await page.locator('.components-form-token-field__input').type(actionValue);
await page.keyboard.press('Enter');
}
// Activate the automation workflow while in the workflow
export async function activateWorkflow(page) {
await Promise.all([
page.locator('.editor-post-publish-button').click(),
page
.locator('.mailpoet-automation-activate-panel__header-activate-button')
.click(),
page.waitForLoadState('networkidle'),
]);
}
// Click to design email in the workflow and save it
export async function designEmailInWorkflow(page) {
// Fill the sender email and name
await page.locator('input[type="text"]').waitFor({ state: 'visible' });
await page.locator('input[type="text"]').fill(fromName);
await page.locator('input[type="text"]').type(' '); // to avoid flakiness
await page.locator('input[type="email"]').fill(adminEmail);
await page.screenshot({
path: screenshotPath + `Design_Email_In_Workflow_${Date.now()}.png`,
fullPage: fullPageSet,
});
// Click Design automation email button
await Promise.all([
page.waitForNavigation(),
page.locator('.mailpoet-automation-button-sidebar-primary').click(),
]);
await page.waitForLoadState('networkidle');
await page.screenshot({
path: screenshotPath + `Design_Email_In_Workflow_${Date.now()}.png`,
fullPage: fullPageSet,
});
// Switch to a Standard templates tab and select the 2nd template
await page
.locator('[data-automation-id="templates-standard"]')
.waitFor({ state: 'visible' });
await page.locator('[data-automation-id="templates-standard"]').click();
await Promise.all([
page.waitForNavigation(),
page.locator('[data-automation-id="select_template_1"]').click(),
]);
await page.waitForLoadState('networkidle');
await page.screenshot({
path: screenshotPath + `Design_Email_In_Workflow_${Date.now()}.png`,
fullPage: fullPageSet,
});
// Click to save and get back to the workflow
await page
.locator('input[value="Save and continue"')
.waitFor({ state: 'visible' });
try {
await page.locator('#mailpoet_modal_close').click({ timeout: 3000 });
} catch (error) {
console.log("Newsletter tutorial video wasn't present.");
}
await Promise.all([
page.waitForNavigation(),
page.locator('input[value="Save and continue"').click(),
]);
await page.waitForLoadState('networkidle');
}