[ACA-2989]Add doubleClickRow method (#5728)

* Add doubleClickRow method

* Renamed the method to be in sync with the actions made

* Modified the columns parameter from 'any' to 'Column[]'

* no message

* Make Column abstract again

* Add locators snackbar action

* Unblock Travis

* no message
This commit is contained in:
Cristina Jalba
2020-06-05 19:41:08 +03:00
committed by GitHub
parent a78f24ada1
commit 492fba5f4e
6 changed files with 26 additions and 8 deletions

View File

@@ -18,10 +18,10 @@
export abstract class Column {
columnName: string;
columnType: string;
locator: string;
constructor(columnName: string) {
constructor(columnName: string, columnType: string ) {
this.columnName = columnName;
this.columnType = columnType;
}
createLocator(columnValue: string): string {

View File

@@ -23,7 +23,7 @@ import { ElementFinder } from 'protractor';
export class DataTableBuilder {
createDataTable(columns: Array<Column>, rootElement?: ElementFinder): DataTableItem {
createDataTable(columns: Column[], rootElement?: ElementFinder): DataTableItem {
const datatable: DataTableItem = new DataTableItem(rootElement);
for (const column of columns) {
switch (column.columnType) {

View File

@@ -16,7 +16,7 @@
*/
import { Column } from './column';
import { by, element, ElementFinder, Locator } from 'protractor';
import { by, element, ElementFinder, Locator, protractor, browser } from 'protractor';
import { BrowserActions } from '../../utils/browser-actions';
import { BrowserVisibility } from '../../utils/browser-visibility';
@@ -59,4 +59,10 @@ export class DataTableItem {
async waitForFirstRow(): Promise<void> {
await BrowserVisibility.waitUntilElementIsVisible(this.rootElement.all(this.rows).first());
}
async clickAndEnterOnRow(columnName: string, columnValue: string): Promise<void> {
const row = this.getRow(columnName, columnValue);
await BrowserActions.click(row);
await browser.actions().sendKeys(protractor.Key.ENTER).perform();
}
}

View File

@@ -18,10 +18,10 @@
import { Column } from './column';
export class DateColumn extends Column {
columnType: string = 'date';
columnType: string;
columnName: string;
constructor(columnName: string) {
super(columnName);
super(columnName, 'date');
}
}

View File

@@ -18,10 +18,10 @@
import { Column } from './column';
export class TextColumn extends Column {
columnType: string = 'text';
columnType: string;
columnName: string;
constructor(columnName: string) {
super(columnName);
super(columnName, 'text');
}
}

View File

@@ -17,10 +17,12 @@
import { element, by, ElementFinder } from 'protractor';
import { BrowserVisibility } from '../utils/browser-visibility';
import { BrowserActions } from '../utils/browser-actions';
export class SnackbarPage {
notificationSnackBar: ElementFinder = element.all(by.css('simple-snack-bar span')).first();
snackBarAction: ElementFinder = element(by.css('simple-snack-bar button span'));
snackBarContainerCss = by.css('.mat-snack-bar-container');
async waitForSnackBarToAppear() {
@@ -38,6 +40,16 @@ export class SnackbarPage {
return this.notificationSnackBar.getText();
}
async getSnackBarActionMessage(): Promise<string> {
await this.waitForSnackBarToAppear();
return this.snackBarAction.getText();
}
async clickSnackBarAction(): Promise<void> {
await this.waitForSnackBarToAppear();
await BrowserActions.click(this.snackBarAction);
}
async isNotificationSnackBarDisplayed(): Promise<boolean> {
try {
await BrowserVisibility.waitUntilElementIsVisible(this.notificationSnackBar, 2000);