davidcanonieto ee7af9d797 [ADF-3671] Add automation tests for Form Widgets (#3911)
* [ADF-3617] Fix bugs in Task Details Page controller

* [ADF-3617] Fix bugs in Task Page controller

* [ADF-3617] Separate in different describes automation tests

* [ADF-3671] start working on e2e form tests

* [ADF-3671] improved checks for form widgets

* [ADF-3671] start adding multiline text widget tsts

* [ADF-3671] added test for multiline and some improvements

* [ADF-3671] Add e2e tests for Dropdown, Date, Checkbox widgets

* [ADF-3671] Add e2e test for radio, number, hyperlink widgets

* [ADF-3671] Add automation tests for Form Widgets

* [ADF-3671] Update usage of Dropdown Widget

* [ADF-3671] Fix fileModel file and rename widget controles

* [ADF-3671] Rename Widget Controllers

* [ADF-3671] Remove unused imports and fix dynamic table e2e test

* [ADF-3671] Fix spell errors

* [ADF-3671] Fix people, date time, attach widget

* [ADF-3671] Fix Form People widget tests

* [ADF-3671] Rebase and remove unused variables
2018-10-26 14:03:13 +01:00

155 lines
5.3 KiB
TypeScript

/*!
* @license
* Copyright 2016 Alfresco Software, Ltd.
*
* 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.
*/
import FormFields = require('../formFields');
import Util = require('../../../../util/util');
import { by, element, browser, protractor } from 'protractor';
export class DynamicTableWidget {
formFields = new FormFields();
labelLocator = by.css('dynamic-table-widget div div');
columnNameLocator = by.css('table[id*="dynamic-table"] th');
addButton = element(by.id('label-add-row'));
cancelButton = element(by.cssContainingText('button span', 'Cancel'));
editButton = element(by.cssContainingText('button span', 'edit'));
addRow = element(by.id('dynamictable-add-row'));
columnDateTime = element(by.id('columnDateTime'));
columnDate = element(by.id('columnDate'));
calendarHeader = element(by.css('div[class="mat-datetimepicker-calendar-header-date-time"]'));
calendarContent = element(by.css('div[class="mat-datetimepicker-calendar-content"]'));
saveButton = element(by.cssContainingText('button span', 'Save'));
errorMessage = element(by.css('div[class="adf-error-text"]'));
dateWidget = element.all(by.css('button[aria-label="Open calendar"]')).first();
calendarNumber = element.all(by.css('td div'));
tableRow = element.all(by.css('tbody tr'));
dataTableInput = element(by.id('id'));
getFieldLabel(fieldId) {
return this.formFields.getFieldLabel(fieldId, this.labelLocator);
}
getColumnName(fieldId) {
return this.formFields.getFieldText(fieldId, this.columnNameLocator);
}
clickAddButton() {
Util.waitUntilElementIsVisible(this.addButton);
return this.addButton.click();
}
clickAddRow() {
Util.waitUntilElementIsVisible(this.addRow);
return this.addRow.click();
}
clickTableRow(rowNumber) {
let tableRowByIndex = element(by.id('dynamictable-row-' + rowNumber));
Util.waitUntilElementIsVisible(tableRowByIndex);
return tableRowByIndex.click();
}
clickEditButton() {
Util.waitUntilElementIsVisible(this.editButton);
return this.editButton.click();
}
clickCancelButton() {
Util.waitUntilElementIsVisible(this.cancelButton);
return this.cancelButton.click();
}
setDatatableInput(text) {
Util.waitUntilElementIsVisible(this.dataTableInput);
this.dataTableInput.clear();
return this.dataTableInput.sendKeys(text);
}
getTableRowText(rowNumber) {
let tableRowByIndex = element(by.id('dynamictable-row-' + rowNumber));
Util.waitUntilElementIsVisible(tableRowByIndex);
return tableRowByIndex.getText();
}
checkTableRowIsVisible(rowNumber) {
let tableRowByIndex = element(by.id('dynamictable-row-' + rowNumber));
return Util.waitUntilElementIsVisible(tableRowByIndex);
}
checkTableRowIsNotVisible(rowNumber) {
let tableRowByIndex = element(by.id('dynamictable-row-' + rowNumber));
return Util.waitUntilElementIsNotVisible(tableRowByIndex);
}
clickColumnDateTime() {
Util.waitUntilElementIsVisible(this.columnDateTime);
this.columnDateTime.click();
Util.waitUntilElementIsVisible(this.calendarHeader);
Util.waitUntilElementIsVisible(this.calendarContent);
browser.actions().sendKeys(protractor.Key.ESCAPE).perform();
}
addRandomStringOnDateTime(randomText) {
Util.waitUntilElementIsVisible(this.columnDateTime);
this.columnDateTime.click();
browser.actions().sendKeys(protractor.Key.ESCAPE).perform();
this.columnDateTime.sendKeys(randomText);
this.columnDateTime.sendKeys(protractor.Key.ENTER);
return this.columnDateTime.getAttribute('value');
}
addRandomStringOnDate(randomText) {
Util.waitUntilElementIsVisible(this.columnDate);
this.columnDate.click();
return this.columnDate.sendKeys(randomText);
}
clickSaveButton() {
Util.waitUntilElementIsVisible(this.saveButton);
return this.saveButton.click();
}
checkErrorMessage() {
Util.waitUntilElementIsVisible(this.errorMessage);
return this.errorMessage.getText();
}
clickDateWidget() {
Util.waitUntilElementIsVisible(this.dateWidget);
return this.dateWidget.click();
}
getDateCalendarNumber(date) {
return this.calendarNumber.get(date).click();
}
getTableRow(rowNumber) {
return Util.waitUntilElementIsVisible(this.tableRow.get(rowNumber));
}
waitForCalendarToDisappear() {
Util.waitUntilElementIsNotVisible(this.calendarNumber);
}
checkItemIsPresent(item) {
let row = element(by.cssContainingText('table tbody tr td span', item));
let present = Util.waitUntilElementIsVisible(row);
expect(present).toBe(true);
}
}