mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-31 17:38:48 +00:00
[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
This commit is contained in:
committed by
Eugenio Romano
parent
9599b84a84
commit
ee7af9d797
154
e2e/pages/adf/process_services/widgets/dynamicTableWidget.ts
Normal file
154
e2e/pages/adf/process_services/widgets/dynamicTableWidget.ts
Normal file
@@ -0,0 +1,154 @@
|
||||
/*!
|
||||
* @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);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user