mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
add start-process-cloud-component.page.ts page in @adf-testing
This commit is contained in:
@@ -26,5 +26,6 @@ export * from './process-filters-cloud-component.page';
|
||||
export * from './process-list-cloud-component.page';
|
||||
export * from './task-filters-cloud-component.page';
|
||||
export * from './task-list-cloud-component.page';
|
||||
export * from './start-process-cloud-component.page';
|
||||
|
||||
export * from './dialog/public-api';
|
||||
|
@@ -0,0 +1,120 @@
|
||||
/*!
|
||||
* @license
|
||||
* Copyright 2019 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 { by, element, Key, protractor, browser } from 'protractor';
|
||||
import { BrowserVisibility } from '../../core/browser-visibility';
|
||||
|
||||
export class StartProcessCloudPage {
|
||||
|
||||
defaultProcessName = element(by.css('input[id="processName"]'));
|
||||
processNameInput = element(by.id('processName'));
|
||||
selectProcessDropdownArrow = element(by.css('button[id="adf-select-process-dropdown"]'));
|
||||
cancelProcessButton = element(by.id('cancel_process'));
|
||||
formStartProcessButton = element(by.css('button[data-automation-id="adf-form-start process"]'));
|
||||
startProcessButton = element(by.css('button[data-automation-id="btn-start"]'));
|
||||
noProcess = element(by.id('no-process-message'));
|
||||
processDefinition = element(by.css('input[id="processDefinitionName"]'));
|
||||
processDefinitionOptionsPanel = element(by.css('div[class*="processDefinitionOptions"]'));
|
||||
|
||||
checkNoProcessMessage() {
|
||||
BrowserVisibility.waitUntilElementIsVisible(this.noProcess);
|
||||
}
|
||||
|
||||
pressDownArrowAndEnter() {
|
||||
this.processDefinition.sendKeys(protractor.Key.ARROW_DOWN);
|
||||
return browser.actions().sendKeys(protractor.Key.ENTER).perform();
|
||||
}
|
||||
|
||||
checkNoProcessDefinitionOptionIsDisplayed() {
|
||||
BrowserVisibility.waitUntilElementIsNotOnPage(this.processDefinitionOptionsPanel);
|
||||
}
|
||||
|
||||
enterProcessName(name) {
|
||||
BrowserVisibility.waitUntilElementIsVisible(this.processNameInput);
|
||||
this.clearProcessName();
|
||||
this.processNameInput.sendKeys(name);
|
||||
}
|
||||
|
||||
clearProcessName() {
|
||||
BrowserVisibility.waitUntilElementIsVisible(this.processNameInput);
|
||||
this.processNameInput.clear();
|
||||
}
|
||||
|
||||
selectFromProcessDropdown(name) {
|
||||
this.clickProcessDropdownArrow();
|
||||
return this.selectOption(name);
|
||||
}
|
||||
|
||||
clickProcessDropdownArrow() {
|
||||
BrowserVisibility.waitUntilElementIsVisible(this.selectProcessDropdownArrow);
|
||||
BrowserVisibility.waitUntilElementIsClickable(this.selectProcessDropdownArrow);
|
||||
this.selectProcessDropdownArrow.click();
|
||||
}
|
||||
|
||||
checkOptionIsDisplayed(name) {
|
||||
const selectProcessDropdown = element(by.cssContainingText('.mat-option-text', name));
|
||||
BrowserVisibility.waitUntilElementIsVisible(selectProcessDropdown);
|
||||
BrowserVisibility.waitUntilElementIsClickable(selectProcessDropdown);
|
||||
return this;
|
||||
}
|
||||
|
||||
selectOption(name) {
|
||||
const selectProcessDropdown = element(by.cssContainingText('.mat-option-text', name));
|
||||
BrowserVisibility.waitUntilElementIsVisible(selectProcessDropdown);
|
||||
BrowserVisibility.waitUntilElementIsClickable(selectProcessDropdown);
|
||||
selectProcessDropdown.click();
|
||||
return this;
|
||||
}
|
||||
|
||||
clickCancelProcessButton() {
|
||||
BrowserVisibility.waitUntilElementIsVisible(this.cancelProcessButton);
|
||||
this.cancelProcessButton.click();
|
||||
}
|
||||
|
||||
checkStartProcessButtonIsEnabled() {
|
||||
expect(this.startProcessButton.isEnabled()).toBe(true);
|
||||
}
|
||||
|
||||
checkStartProcessButtonIsDisabled() {
|
||||
expect(this.startProcessButton.isEnabled()).toBe(false);
|
||||
}
|
||||
|
||||
clickStartProcessButton() {
|
||||
return this.startProcessButton.click();
|
||||
}
|
||||
|
||||
checkValidationErrorIsDisplayed(error, elementRef = 'mat-error') {
|
||||
const errorElement = element(by.cssContainingText(elementRef, error));
|
||||
BrowserVisibility.waitUntilElementIsVisible(errorElement);
|
||||
return this;
|
||||
}
|
||||
|
||||
blur(locator) {
|
||||
locator.click();
|
||||
locator.sendKeys(Key.TAB);
|
||||
return this;
|
||||
}
|
||||
|
||||
clearField(locator) {
|
||||
BrowserVisibility.waitUntilElementIsVisible(locator);
|
||||
locator.getAttribute('value').then((result) => {
|
||||
for (let i = result.length; i >= 0; i--) {
|
||||
locator.sendKeys(protractor.Key.BACK_SPACE);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user