mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-26 17:24:56 +00:00
[C310199][C310142]- empty form , required data and invalid form data validations (#4900)
* C310199, C310142, empty form validations, Form validations with required field and invalid data.Added a new form to candidatebaseapp, 'FormToTestValidations' * using BrowserActions
This commit is contained in:
parent
939277366f
commit
cae73e3c02
@ -17,8 +17,18 @@
|
|||||||
|
|
||||||
import { browser } from 'protractor';
|
import { browser } from 'protractor';
|
||||||
import {
|
import {
|
||||||
AppListCloudPage, StringUtil, ApiService, LoginSSOPage, TasksService, QueryService,
|
AppListCloudPage,
|
||||||
ProcessDefinitionsService, ProcessInstancesService, SettingsPage, TaskHeaderCloudPage, TaskFormCloudComponent
|
StringUtil,
|
||||||
|
ApiService,
|
||||||
|
LoginSSOPage,
|
||||||
|
TasksService,
|
||||||
|
QueryService,
|
||||||
|
ProcessDefinitionsService,
|
||||||
|
ProcessInstancesService,
|
||||||
|
SettingsPage,
|
||||||
|
TaskHeaderCloudPage,
|
||||||
|
TaskFormCloudComponent,
|
||||||
|
Widget
|
||||||
} from '@alfresco/adf-testing';
|
} from '@alfresco/adf-testing';
|
||||||
import { NavigationBarPage } from '../pages/adf/navigationBarPage';
|
import { NavigationBarPage } from '../pages/adf/navigationBarPage';
|
||||||
import { TasksCloudDemoPage } from '../pages/adf/demo-shell/process-services/tasksCloudDemoPage';
|
import { TasksCloudDemoPage } from '../pages/adf/demo-shell/process-services/tasksCloudDemoPage';
|
||||||
@ -34,13 +44,15 @@ describe('Task form cloud component', () => {
|
|||||||
const taskHeaderCloudPage = new TaskHeaderCloudPage();
|
const taskHeaderCloudPage = new TaskHeaderCloudPage();
|
||||||
const taskFormCloudComponent = new TaskFormCloudComponent();
|
const taskFormCloudComponent = new TaskFormCloudComponent();
|
||||||
const settingsPage = new SettingsPage();
|
const settingsPage = new SettingsPage();
|
||||||
|
const widget = new Widget();
|
||||||
|
const formToTestValidationsKey = 'form-49904910-603c-48e9-8c8c-1d442c0fa524';
|
||||||
|
|
||||||
let tasksService: TasksService;
|
let tasksService: TasksService;
|
||||||
let processDefinitionService: ProcessDefinitionsService;
|
let processDefinitionService: ProcessDefinitionsService;
|
||||||
let processInstancesService: ProcessInstancesService;
|
let processInstancesService: ProcessInstancesService;
|
||||||
let queryService: QueryService;
|
let queryService: QueryService;
|
||||||
|
|
||||||
let completedTask, createdTask, assigneeTask, toBeCompletedTask, completedProcess, claimedTask;
|
let completedTask, createdTask, assigneeTask, toBeCompletedTask, completedProcess, claimedTask, formValidationsTask;
|
||||||
const candidateBaseApp = resources.ACTIVITI7_APPS.CANDIDATE_BASE_APP.name;
|
const candidateBaseApp = resources.ACTIVITI7_APPS.CANDIDATE_BASE_APP.name;
|
||||||
const completedTaskName = StringUtil.generateRandomString(), assignedTaskName = StringUtil.generateRandomString();
|
const completedTaskName = StringUtil.generateRandomString(), assignedTaskName = StringUtil.generateRandomString();
|
||||||
|
|
||||||
@ -55,6 +67,9 @@ describe('Task form cloud component', () => {
|
|||||||
assigneeTask = await tasksService.createStandaloneTask(StringUtil.generateRandomString(), candidateBaseApp);
|
assigneeTask = await tasksService.createStandaloneTask(StringUtil.generateRandomString(), candidateBaseApp);
|
||||||
await tasksService.claimTask(assigneeTask.entry.id, candidateBaseApp);
|
await tasksService.claimTask(assigneeTask.entry.id, candidateBaseApp);
|
||||||
|
|
||||||
|
formValidationsTask = await tasksService.createStandaloneTaskWithForm(StringUtil.generateRandomString(), candidateBaseApp, formToTestValidationsKey);
|
||||||
|
await tasksService.claimTask(formValidationsTask.entry.id, candidateBaseApp);
|
||||||
|
|
||||||
toBeCompletedTask = await tasksService.createStandaloneTask(StringUtil.generateRandomString(), candidateBaseApp);
|
toBeCompletedTask = await tasksService.createStandaloneTask(StringUtil.generateRandomString(), candidateBaseApp);
|
||||||
await tasksService.claimTask(toBeCompletedTask.entry.id, candidateBaseApp);
|
await tasksService.claimTask(toBeCompletedTask.entry.id, candidateBaseApp);
|
||||||
|
|
||||||
@ -89,6 +104,60 @@ describe('Task form cloud component', () => {
|
|||||||
expect(taskFormCloudComponent.getReleaseButtonText()).toBe('RELEASE');
|
expect(taskFormCloudComponent.getReleaseButtonText()).toBe('RELEASE');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('[C310142] Empty content is displayed when having a task without form', async () => {
|
||||||
|
navigationBarPage.navigateToProcessServicesCloudPage();
|
||||||
|
appListCloudComponent.checkApsContainer();
|
||||||
|
appListCloudComponent.goToApp(candidateBaseApp);
|
||||||
|
tasksCloudDemoPage.myTasksFilter().clickTaskFilter();
|
||||||
|
tasksCloudDemoPage.taskListCloudComponent().checkContentIsDisplayedByName(assigneeTask.entry.name);
|
||||||
|
tasksCloudDemoPage.taskListCloudComponent().selectRow(assigneeTask.entry.name);
|
||||||
|
taskFormCloudComponent.checkFormIsNotDisplayed();
|
||||||
|
expect(taskFormCloudComponent.getFormTitle()).toBe(assigneeTask.entry.name);
|
||||||
|
taskFormCloudComponent.checkFormContentIsEmpty();
|
||||||
|
expect(taskFormCloudComponent.getEmptyFormContentTitle()).toBe(`No form available`);
|
||||||
|
expect(taskFormCloudComponent.getEmptyFormContentSubtitle()).toBe(`Attach a form that can be viewed later`);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C310199] Should not be able to complete a task when required field is empty or invalid data is added to a field', async () => {
|
||||||
|
navigationBarPage.navigateToProcessServicesCloudPage();
|
||||||
|
appListCloudComponent.checkApsContainer();
|
||||||
|
appListCloudComponent.goToApp(candidateBaseApp);
|
||||||
|
tasksCloudDemoPage.myTasksFilter().clickTaskFilter();
|
||||||
|
tasksCloudDemoPage.taskListCloudComponent().checkContentIsDisplayedByName(formValidationsTask.entry.name);
|
||||||
|
tasksCloudDemoPage.taskListCloudComponent().selectRow(formValidationsTask.entry.name);
|
||||||
|
taskFormCloudComponent.checkFormIsDisplayed();
|
||||||
|
taskFormCloudComponent.formFields().checkFormIsDisplayed();
|
||||||
|
taskFormCloudComponent.formFields().checkWidgetIsVisible('Text0tma8h');
|
||||||
|
taskFormCloudComponent.formFields().checkWidgetIsVisible('Date0m1moq');
|
||||||
|
taskFormCloudComponent.formFields().checkWidgetIsVisible('Number0klykr');
|
||||||
|
taskFormCloudComponent.formFields().checkWidgetIsVisible('Amount0mtp1h');
|
||||||
|
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(false);
|
||||||
|
widget.textWidget().setValue('Text0tma8h', 'Some random text');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(true);
|
||||||
|
|
||||||
|
widget.dateWidget().setDateInput('Date0m1moq', 'invalid date');
|
||||||
|
widget.dateWidget().clickOutsideWidget('Date0m1moq');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(false);
|
||||||
|
|
||||||
|
widget.dateWidget().setDateInput('Date0m1moq', '20-10-2018');
|
||||||
|
widget.dateWidget().clickOutsideWidget('Date0m1moq');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(true);
|
||||||
|
|
||||||
|
widget.numberWidget().setFieldValue('Number0klykr', 'invalid number');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(false);
|
||||||
|
|
||||||
|
widget.numberWidget().setFieldValue('Number0klykr', '26');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(true);
|
||||||
|
|
||||||
|
widget.amountWidget().setFieldValue('Amount0mtp1h', 'invalid amount');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(false);
|
||||||
|
|
||||||
|
widget.amountWidget().setFieldValue('Amount0mtp1h', '660');
|
||||||
|
expect(taskFormCloudComponent.getCompleteButton().isEnabled()).toBe(true);
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
describe('Complete task - cloud directive', () => {
|
describe('Complete task - cloud directive', () => {
|
||||||
|
|
||||||
beforeEach((done) => {
|
beforeEach((done) => {
|
||||||
|
Binary file not shown.
@ -43,6 +43,25 @@ export class TasksService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async createStandaloneTaskWithForm(taskName, appName, formKey, options?) {
|
||||||
|
try {
|
||||||
|
const path = '/' + appName + '/rb/v1/tasks';
|
||||||
|
const method = 'POST';
|
||||||
|
|
||||||
|
const queryParams = {}, postBody = {
|
||||||
|
'name': taskName,
|
||||||
|
'payloadType': 'CreateTaskPayload',
|
||||||
|
'formKey': formKey,
|
||||||
|
...options
|
||||||
|
};
|
||||||
|
|
||||||
|
return await this.api.performBpmOperation(path, method, queryParams, postBody);
|
||||||
|
} catch (error) {
|
||||||
|
// tslint:disable-next-line:no-console
|
||||||
|
console.log('Create FormTask - Service error, Response: ', JSON.parse(JSON.stringify(error)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async completeTask(taskId, appName) {
|
async completeTask(taskId, appName) {
|
||||||
try {
|
try {
|
||||||
const path = '/' + appName + '/rb/v1/tasks/' + taskId + '/complete';
|
const path = '/' + appName + '/rb/v1/tasks/' + taskId + '/complete';
|
||||||
|
@ -28,6 +28,10 @@ export class TaskFormCloudComponent {
|
|||||||
saveButton = element(by.css('button[id="adf-form-save"]'));
|
saveButton = element(by.css('button[id="adf-form-save"]'));
|
||||||
claimButton = element(by.css('button[adf-cloud-claim-task]'));
|
claimButton = element(by.css('button[adf-cloud-claim-task]'));
|
||||||
form = element(by.css('adf-cloud-form'));
|
form = element(by.css('adf-cloud-form'));
|
||||||
|
formTitle = element(by.css(`span.adf-form-title`));
|
||||||
|
emptyContentIcon = element(by.css(`div.adf-empty-content mat-icon.adf-empty-content__icon`));
|
||||||
|
emptyContentTitle = element(by.css(`div.adf-empty-content div.adf-empty-content__title`));
|
||||||
|
emptyContentSubtitle = element(by.css(`div.adf-empty-content div.adf-empty-content__subtitle`));
|
||||||
|
|
||||||
checkCompleteButtonIsDisplayed() {
|
checkCompleteButtonIsDisplayed() {
|
||||||
BrowserVisibility.waitUntilElementIsVisible(this.completeButton);
|
BrowserVisibility.waitUntilElementIsVisible(this.completeButton);
|
||||||
@ -68,6 +72,16 @@ export class TaskFormCloudComponent {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getFormTitle() {
|
||||||
|
BrowserVisibility.waitUntilElementIsVisible(this.formTitle);
|
||||||
|
return this.formTitle.getText();
|
||||||
|
}
|
||||||
|
|
||||||
|
checkFormIsNotDisplayed() {
|
||||||
|
BrowserVisibility.waitUntilElementIsNotVisible(this.form);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
getReleaseButtonText() {
|
getReleaseButtonText() {
|
||||||
return BrowserActions.getText(this.releaseButton);
|
return BrowserActions.getText(this.releaseButton);
|
||||||
}
|
}
|
||||||
@ -82,4 +96,23 @@ export class TaskFormCloudComponent {
|
|||||||
this.saveButton.click();
|
this.saveButton.click();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkFormContentIsEmpty() {
|
||||||
|
BrowserVisibility.waitUntilElementIsVisible(this.emptyContentIcon);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
getEmptyFormContentTitle() {
|
||||||
|
return BrowserActions.getText(this.emptyContentTitle);
|
||||||
|
}
|
||||||
|
|
||||||
|
getEmptyFormContentSubtitle() {
|
||||||
|
return BrowserActions.getText(this.emptyContentSubtitle);
|
||||||
|
}
|
||||||
|
|
||||||
|
getCompleteButton() {
|
||||||
|
BrowserVisibility.waitUntilElementIsVisible(this.completeButton);
|
||||||
|
return this.completeButton;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user