che-server/tests/e2e/pageobjects/dashboard/GetStarted.ts

86 lines
3.6 KiB
TypeScript

/*********************************************************************
* Copyright (c) 2019 Red Hat, Inc.
*
* This program and the accompanying materials are made
* available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
**********************************************************************/
import { injectable, inject } from 'inversify';
import { CLASSES } from '../../inversify.types';
import { DriverHelper } from '../../utils/DriverHelper';
import { By } from 'selenium-webdriver';
import { Logger } from '../../utils/Logger';
import { TimeoutConstants } from '../../TimeoutConstants';
@injectable()
export class GetStarted {
constructor(@inject(CLASSES.DriverHelper) private readonly driverHelper: DriverHelper) { }
async waitTitleContains(expectedText: string, timeout: number = TimeoutConstants.TS_COMMON_DASHBOARD_WAIT_TIMEOUT) {
Logger.debug(`GetStarted.waitTitleContains text: "${expectedText}"`);
const pageTitleLocator: By = By.xpath(`//div[contains(@title, '${expectedText}')]`);
await this.driverHelper.waitVisibility(pageTitleLocator, timeout);
}
async waitPage(timeout: number = TimeoutConstants.TS_SELENIUM_LOAD_PAGE_TIMEOUT) {
Logger.debug('GetStarted.waitPage');
await this.waitTitleContains('Getting Started', timeout);
}
async waitSample(sampleName: string, timeout: number = TimeoutConstants.TS_COMMON_DASHBOARD_WAIT_TIMEOUT) {
Logger.debug(`GetStarted.waitSample sampleName: "${sampleName}"`);
const sampleLocator: By = this.getSampleLocator(sampleName);
await this.driverHelper.waitVisibility(sampleLocator, timeout);
}
async clickOnSample(sampleName: string, timeout: number = TimeoutConstants.TS_CLICK_DASHBOARD_ITEM_TIMEOUT) {
Logger.debug(`GetStarted.clickOnSample sampleName: "${sampleName}"`);
const sampleLocator: By = this.getSampleLocator(sampleName);
await this.driverHelper.waitAndClick(sampleLocator, timeout);
}
async waitSampleSelected(sampleName: string, timeout: number = TimeoutConstants.TS_COMMON_DASHBOARD_WAIT_TIMEOUT) {
Logger.debug(`GetStarted.waitSampleSelected sampleName: "${sampleName}"`);
const selectedSampleLocator: By =
By.xpath(`//div[contains(@class, 'get-started-template') and contains(@class, 'selected')]//span[text()='${sampleName}']`);
await this.driverHelper.waitVisibility(selectedSampleLocator, timeout);
}
async waitSampleUnselected(sampleName: string, timeout: number = TimeoutConstants.TS_COMMON_DASHBOARD_WAIT_TIMEOUT) {
Logger.debug(`GetStarted.waitSampleUnselected sampleName: "${sampleName}"`);
const unselectedSampleLocator: By =
By.xpath(`//div[contains(@class, 'get-started-template') and not(contains(@class, 'selected'))]//span[text()='${sampleName}']`);
await this.driverHelper.waitVisibility(unselectedSampleLocator, timeout);
}
async clickCreateAndOpenButton(timeout: number = TimeoutConstants.TS_CLICK_DASHBOARD_ITEM_TIMEOUT) {
Logger.debug('GetStarted.clickCreateAndOpenButton');
const createAndOpenButtonLocator: By =
By.xpath('(//che-button-save-flat[@che-button-title=\'Create & Open\'][@aria-disabled=\'false\']/button)[1]');
await this.driverHelper.waitAndClick(createAndOpenButtonLocator, timeout);
}
private getSampleLocator(sampleName: string): By {
Logger.trace(`GetStarted.getSampleLocator sampleName: ${sampleName}`);
return By.xpath(`//div[contains(@devfile, 'devfile')]/div/b[contains(text(), '${sampleName}')]`);
}
}