mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* [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
169 lines
5.3 KiB
TypeScript
169 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 Util = require('../../../util/util');
|
|
import StartTaskDialog = require('./dialog/startTaskDialog');
|
|
import FormFields = require('./formFields');
|
|
import { TaskDetailsPage } from './taskDetailsPage';
|
|
|
|
import FiltersPage = require('./filtersPage');
|
|
import ChecklistDialog = require('./dialog/createChecklistDialog');
|
|
import TasksListPage = require('./tasksListPage');
|
|
import { element, by } from 'protractor';
|
|
|
|
export class TasksPage {
|
|
|
|
createButton = element(by.css('button[data-automation-id="create-button"'));
|
|
newTaskButton = element(by.css('button[data-automation-id="btn-start-task"]'));
|
|
addChecklistButton = element(by.css('button[class*="adf-add-to-checklist-button"]'));
|
|
rowByRowName = by.xpath('ancestor::mat-chip');
|
|
checklistContainer = by.css('div[class*="checklist-menu"]');
|
|
taskTitle = 'h2[class="activiti-task-details__header"] span';
|
|
rows = by.css('div[class*="adf-datatable-body"] div[class*="adf-datatable-row"] div[class*="adf-data-table-cell"]');
|
|
completeButtonNoForm = element(by.id('adf-no-form-complete-button'));
|
|
checklistDialog = element(by.id('checklist-dialog'));
|
|
checklistNoMessage = element(by.id('checklist-none-message'));
|
|
numberOfChecklists = element(by.css('[data-automation-id="checklist-label"] mat-chip'));
|
|
|
|
createNewTask() {
|
|
this.createButtonIsDisplayed();
|
|
this.clickOnCreateButton();
|
|
this.newTaskButtonIsDisplayed();
|
|
this.newTaskButton.click();
|
|
return new StartTaskDialog();
|
|
}
|
|
|
|
createButtonIsDisplayed() {
|
|
Util.waitUntilElementIsVisible(this.createButton);
|
|
return this;
|
|
}
|
|
|
|
newTaskButtonIsDisplayed() {
|
|
Util.waitUntilElementIsVisible(this.newTaskButton);
|
|
return this;
|
|
}
|
|
|
|
clickOnCreateButton() {
|
|
Util.waitUntilElementIsClickable(this.createButton);
|
|
this.createButton.click();
|
|
return this;
|
|
}
|
|
|
|
formFields() {
|
|
return new FormFields();
|
|
}
|
|
|
|
taskDetails() {
|
|
return new TaskDetailsPage();
|
|
}
|
|
|
|
filtersPage() {
|
|
return new FiltersPage();
|
|
}
|
|
|
|
tasksListPage() {
|
|
return new TasksListPage();
|
|
}
|
|
|
|
usingCheckListDialog() {
|
|
return new ChecklistDialog();
|
|
}
|
|
|
|
clickOnAddChecklistButton() {
|
|
Util.waitUntilElementIsClickable(this.addChecklistButton);
|
|
this.addChecklistButton.click();
|
|
return new ChecklistDialog();
|
|
}
|
|
|
|
getRowsName(name) {
|
|
let row = element(this.checklistContainer).element(by.cssContainingText('span', name));
|
|
Util.waitUntilElementIsVisible(row);
|
|
return row;
|
|
}
|
|
|
|
getChecklistByName(checklist) {
|
|
let row = this.getRowsName(checklist).element(this.rowByRowName);
|
|
Util.waitUntilElementIsVisible(row);
|
|
return row;
|
|
}
|
|
|
|
checkChecklistIsDisplayed(checklist) {
|
|
Util.waitUntilElementIsVisible(this.getChecklistByName(checklist));
|
|
return this;
|
|
}
|
|
|
|
checkChecklistIsNotDisplayed(checklist) {
|
|
Util.waitUntilElementIsNotOnPage(element(this.checklistContainer).element(by.cssContainingText('span', checklist)));
|
|
return this;
|
|
}
|
|
|
|
checkTaskTitle(taskName) {
|
|
Util.waitUntilElementIsVisible(element(by.css(this.taskTitle)));
|
|
let title = element(by.cssContainingText(this.taskTitle, taskName));
|
|
Util.waitUntilElementIsVisible(title);
|
|
return this;
|
|
}
|
|
|
|
getAllDisplayedRows() {
|
|
return element.all(this.rows).count();
|
|
}
|
|
|
|
completeTaskNoForm() {
|
|
Util.waitUntilElementIsClickable(this.completeButtonNoForm);
|
|
this.completeButtonNoForm.click();
|
|
}
|
|
|
|
completeTaskNoFormNotDisplayed() {
|
|
Util.waitUntilElementIsNotOnPage(this.completeButtonNoForm);
|
|
return this;
|
|
}
|
|
|
|
checkChecklistDialogIsDisplayed() {
|
|
Util.waitUntilElementIsVisible(this.checklistDialog);
|
|
return this;
|
|
}
|
|
|
|
checkChecklistDialogIsNotDisplayed() {
|
|
Util.waitUntilElementIsNotOnPage(this.checklistDialog);
|
|
return this;
|
|
}
|
|
|
|
checkNoChecklistIsDisplayed() {
|
|
Util.waitUntilElementIsVisible(this.checklistNoMessage);
|
|
return this;
|
|
}
|
|
|
|
getNumberOfChecklists() {
|
|
Util.waitUntilElementIsVisible(this.numberOfChecklists);
|
|
return this.numberOfChecklists.getText();
|
|
}
|
|
|
|
removeChecklists(checklist) {
|
|
let row = this.getRowsName(checklist).element(this.rowByRowName);
|
|
Util.waitUntilElementIsVisible(row.element(by.css('mat-icon')));
|
|
row.element(by.css('mat-icon')).click();
|
|
return this;
|
|
}
|
|
|
|
checkChecklistsRemoveButtonIsNotDisplayed(checklist) {
|
|
let row = this.getRowsName(checklist).element(this.rowByRowName);
|
|
Util.waitUntilElementIsNotOnPage(row.element(by.css('mat-icon')));
|
|
return this;
|
|
}
|
|
|
|
}
|