mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[ACA-4337]Move APW tests: claim/release standalone task, json widget
* Move APW tests: claim/release standalone task, json widget * Modify the form id * Fix lint * Fix lint * Change test rail id * no message
This commit is contained in:
107
e2e/process-services-cloud/form-field/json-widget.e2e.ts
Normal file
107
e2e/process-services-cloud/form-field/json-widget.e2e.ts
Normal file
@@ -0,0 +1,107 @@
|
|||||||
|
/*!
|
||||||
|
* @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 {
|
||||||
|
ApiService,
|
||||||
|
AppListCloudPage,
|
||||||
|
GroupIdentityService,
|
||||||
|
IdentityService,
|
||||||
|
EditJsonDialog,
|
||||||
|
FormCloudService,
|
||||||
|
LoginPage,
|
||||||
|
ProcessCloudWidgetPage,
|
||||||
|
StringUtil,
|
||||||
|
TaskFormCloudComponent,
|
||||||
|
TaskHeaderCloudPage,
|
||||||
|
TasksService
|
||||||
|
} from '@alfresco/adf-testing';
|
||||||
|
import { browser } from 'protractor';
|
||||||
|
import { TasksCloudDemoPage } from '.././pages/tasks-cloud-demo.page';
|
||||||
|
import { NavigationBarPage } from '../../core/pages/navigation-bar.page';
|
||||||
|
|
||||||
|
describe('Form Field Component - JSON Widget', () => {
|
||||||
|
|
||||||
|
const loginSSOPage = new LoginPage();
|
||||||
|
const navigationBarPage = new NavigationBarPage();
|
||||||
|
const appListCloudComponent = new AppListCloudPage();
|
||||||
|
|
||||||
|
const tasksCloudDemoPage = new TasksCloudDemoPage();
|
||||||
|
const taskList = tasksCloudDemoPage.taskListCloudComponent();
|
||||||
|
|
||||||
|
const taskFormCloudComponent = new TaskFormCloudComponent();
|
||||||
|
const taskHeaderCloudPage = new TaskHeaderCloudPage();
|
||||||
|
const editJsonDialog = new EditJsonDialog();
|
||||||
|
const widget = new ProcessCloudWidgetPage();
|
||||||
|
|
||||||
|
const apiService = new ApiService();
|
||||||
|
const identityService = new IdentityService(apiService);
|
||||||
|
const groupIdentityService = new GroupIdentityService(apiService);
|
||||||
|
const tasksService = new TasksService(apiService);
|
||||||
|
const formCloudService = new FormCloudService(apiService);
|
||||||
|
|
||||||
|
const jsonWidget = widget.json();
|
||||||
|
|
||||||
|
let testUser;
|
||||||
|
let groupInfo;
|
||||||
|
const simpleApp = browser.params.resources.ACTIVITI_CLOUD_APPS.SIMPLE_APP.name;
|
||||||
|
const taskName = StringUtil.generateRandomString();
|
||||||
|
const formWithJson = browser.params.resources.ACTIVITI_CLOUD_APPS.SIMPLE_APP.forms.formWithJsonWidget;
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
await apiService.loginWithProfile('identityAdmin');
|
||||||
|
|
||||||
|
testUser = await identityService.createIdentityUserWithRole( [identityService.ROLES.ACTIVITI_USER]);
|
||||||
|
|
||||||
|
groupInfo = await groupIdentityService.getGroupInfoByGroupName('hr');
|
||||||
|
await identityService.addUserToGroup(testUser.idIdentityService, groupInfo.id);
|
||||||
|
await apiService.login(testUser.username, testUser.password);
|
||||||
|
|
||||||
|
const formId = await formCloudService.getIdByFormName(simpleApp, formWithJson.name);
|
||||||
|
|
||||||
|
await tasksService.createStandaloneTaskWithForm(taskName, simpleApp, formId, { 'assignee': testUser.username });
|
||||||
|
|
||||||
|
await loginSSOPage.login(testUser.username, testUser.password);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
await apiService.loginWithProfile('identityAdmin');
|
||||||
|
await identityService.deleteIdentityUser(testUser.idIdentityService);
|
||||||
|
});
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
await navigationBarPage.navigateToProcessServicesCloudPage();
|
||||||
|
await appListCloudComponent.checkApsContainer();
|
||||||
|
await appListCloudComponent.goToApp(simpleApp);
|
||||||
|
await taskList.getDataTable().waitForTableBody();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C593999] View json field in standalone task ', async () => {
|
||||||
|
await taskList.checkContentIsDisplayedByName(taskName);
|
||||||
|
await taskList.selectRow(taskName);
|
||||||
|
|
||||||
|
await taskHeaderCloudPage.checkTaskPropertyListIsDisplayed();
|
||||||
|
await taskFormCloudComponent.formFields().checkFormIsDisplayed();
|
||||||
|
|
||||||
|
await jsonWidget.checkWidgetIsVisible(formWithJson.widgets.displayJsonWidgetId);
|
||||||
|
await jsonWidget.clickJsonButton(formWithJson.widgets.displayJsonWidgetId);
|
||||||
|
|
||||||
|
await editJsonDialog.checkDialogIsDisplayed();
|
||||||
|
await expect(await editJsonDialog.getDialogContent()).toBe('{}');
|
||||||
|
await editJsonDialog.clickCloseButton();
|
||||||
|
await editJsonDialog.checkDialogIsNotDisplayed();
|
||||||
|
});
|
||||||
|
});
|
@@ -24,9 +24,12 @@ import {
|
|||||||
LocalStorageUtil,
|
LocalStorageUtil,
|
||||||
LoginPage,
|
LoginPage,
|
||||||
ProcessDefinitionsService,
|
ProcessDefinitionsService,
|
||||||
ProcessInstancesService, StatusType,
|
ProcessInstancesService,
|
||||||
|
StatusType,
|
||||||
|
StringUtil,
|
||||||
TaskFormCloudComponent,
|
TaskFormCloudComponent,
|
||||||
TaskHeaderCloudPage
|
TaskHeaderCloudPage,
|
||||||
|
TasksService
|
||||||
} from '@alfresco/adf-testing';
|
} from '@alfresco/adf-testing';
|
||||||
import { NavigationBarPage } from '../../core/pages/navigation-bar.page';
|
import { NavigationBarPage } from '../../core/pages/navigation-bar.page';
|
||||||
import { TasksCloudDemoPage } from './../pages/tasks-cloud-demo.page';
|
import { TasksCloudDemoPage } from './../pages/tasks-cloud-demo.page';
|
||||||
@@ -36,6 +39,7 @@ import { taskFilterConfiguration } from './../config/task-filter.config';
|
|||||||
describe('Task claim/release', () => {
|
describe('Task claim/release', () => {
|
||||||
|
|
||||||
const candidateApp = browser.params.resources.ACTIVITI_CLOUD_APPS.CANDIDATE_BASE_APP;
|
const candidateApp = browser.params.resources.ACTIVITI_CLOUD_APPS.CANDIDATE_BASE_APP;
|
||||||
|
const simpleApp = browser.params.resources.ACTIVITI_CLOUD_APPS.SIMPLE_APP.name;
|
||||||
|
|
||||||
const loginSSOPage = new LoginPage();
|
const loginSSOPage = new LoginPage();
|
||||||
const navigationBarPage = new NavigationBarPage();
|
const navigationBarPage = new NavigationBarPage();
|
||||||
@@ -51,6 +55,9 @@ describe('Task claim/release', () => {
|
|||||||
const apiService = new ApiService();
|
const apiService = new ApiService();
|
||||||
const processDefinitionService = new ProcessDefinitionsService(apiService);
|
const processDefinitionService = new ProcessDefinitionsService(apiService);
|
||||||
const processInstancesService = new ProcessInstancesService(apiService);
|
const processInstancesService = new ProcessInstancesService(apiService);
|
||||||
|
const identityService = new IdentityService(apiService);
|
||||||
|
const groupIdentityService = new GroupIdentityService(apiService);
|
||||||
|
const tasksService = new TasksService(apiService);
|
||||||
|
|
||||||
let processInstance: ProcessInstanceCloud;
|
let processInstance: ProcessInstanceCloud;
|
||||||
|
|
||||||
@@ -71,7 +78,7 @@ describe('Task claim/release', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('[C306874] Should be able to Claim/Release a process task which has a candidate user', async () => {
|
it('[C306874] Should be able to Claim/Release a process task which has a candidate user', async () => {
|
||||||
await setTaskFilter('Created', processInstance.id);
|
await setStatusTaskFilter('Created', processInstance.id);
|
||||||
|
|
||||||
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.candidateUserTask);
|
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.candidateUserTask);
|
||||||
await taskList.selectRow(candidateApp.tasks.candidateUserTask);
|
await taskList.selectRow(candidateApp.tasks.candidateUserTask);
|
||||||
@@ -102,14 +109,10 @@ describe('Task claim/release', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('candidate group', () => {
|
describe('candidate group', () => {
|
||||||
let identityService: IdentityService;
|
|
||||||
let groupIdentityService: GroupIdentityService;
|
|
||||||
let candidate;
|
let candidate;
|
||||||
|
|
||||||
beforeAll(async () => {
|
beforeAll(async () => {
|
||||||
await apiService.loginWithProfile('identityAdmin');
|
await apiService.loginWithProfile('identityAdmin');
|
||||||
identityService = new IdentityService(apiService);
|
|
||||||
groupIdentityService = new GroupIdentityService(apiService);
|
|
||||||
candidate = await identityService.createIdentityUserWithRole([identityService.ROLES.ACTIVITI_USER]);
|
candidate = await identityService.createIdentityUserWithRole([identityService.ROLES.ACTIVITI_USER]);
|
||||||
const groupInfo = await groupIdentityService.getGroupInfoByGroupName('hr');
|
const groupInfo = await groupIdentityService.getGroupInfoByGroupName('hr');
|
||||||
await identityService.addUserToGroup(candidate.idIdentityService, groupInfo.id);
|
await identityService.addUserToGroup(candidate.idIdentityService, groupInfo.id);
|
||||||
@@ -130,7 +133,7 @@ describe('Task claim/release', () => {
|
|||||||
|
|
||||||
it('[C306875] should be able to Claim/Release a process task which has a candidate group', async () => {
|
it('[C306875] should be able to Claim/Release a process task which has a candidate group', async () => {
|
||||||
await navigateToApp(browser.params.testConfig.users.hrUser);
|
await navigateToApp(browser.params.testConfig.users.hrUser);
|
||||||
await setTaskFilter('Created', processInstance.id);
|
await setStatusTaskFilter('Created', processInstance.id);
|
||||||
|
|
||||||
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.uploadFileTask);
|
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.uploadFileTask);
|
||||||
await taskList.selectRow(candidateApp.tasks.uploadFileTask);
|
await taskList.selectRow(candidateApp.tasks.uploadFileTask);
|
||||||
@@ -158,7 +161,7 @@ describe('Task claim/release', () => {
|
|||||||
|
|
||||||
await navigationBarPage.clickLogoutButton();
|
await navigationBarPage.clickLogoutButton();
|
||||||
await navigateToApp(candidate);
|
await navigateToApp(candidate);
|
||||||
await setTaskFilter('Created', processInstance.id);
|
await setStatusTaskFilter('Created', processInstance.id);
|
||||||
|
|
||||||
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.uploadFileTask);
|
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.uploadFileTask);
|
||||||
await taskList.selectRow(candidateApp.tasks.uploadFileTask);
|
await taskList.selectRow(candidateApp.tasks.uploadFileTask);
|
||||||
@@ -187,6 +190,65 @@ describe('Task claim/release', () => {
|
|||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('standalone task', () => {
|
||||||
|
let testUser, groupInfo;
|
||||||
|
const taskName = StringUtil.generateRandomString();
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
await apiService.loginWithProfile('identityAdmin');
|
||||||
|
|
||||||
|
testUser = await identityService.createIdentityUserWithRole([identityService.ROLES.ACTIVITI_USER]);
|
||||||
|
groupInfo = await groupIdentityService.getGroupInfoByGroupName('hr');
|
||||||
|
await identityService.addUserToGroup(testUser.idIdentityService, groupInfo.id);
|
||||||
|
|
||||||
|
await apiService.login(testUser.username, testUser.password);
|
||||||
|
await tasksService.createStandaloneTask(taskName, simpleApp, { 'candidateGroups': ['hr'] });
|
||||||
|
|
||||||
|
await loginSSOPage.login(testUser.username, testUser.password);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
await apiService.loginWithProfile('identityAdmin');
|
||||||
|
await identityService.deleteIdentityUser(testUser.idIdentityService);
|
||||||
|
await navigationBarPage.clickLogoutButton();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C593997] Should be able to release/claim a standalone task ', async () => {
|
||||||
|
await navigationBarPage.navigateToProcessServicesCloudPage();
|
||||||
|
await appListCloudComponent.checkApsContainer();
|
||||||
|
await appListCloudComponent.goToApp(simpleApp);
|
||||||
|
|
||||||
|
await taskList.getDataTable().waitForTableBody();
|
||||||
|
|
||||||
|
await setStatusStandaloneTaskFilter('Created');
|
||||||
|
|
||||||
|
await taskList.checkContentIsDisplayedByName(taskName);
|
||||||
|
await taskList.selectRow(taskName);
|
||||||
|
|
||||||
|
await taskHeaderCloudPage.checkTaskPropertyListIsDisplayed();
|
||||||
|
|
||||||
|
await expect(await taskHeaderCloudPage.getAssignee()).toEqual('No assignee');
|
||||||
|
await taskFormCloudComponent.checkClaimButtonIsDisplayed();
|
||||||
|
|
||||||
|
await taskFormCloudComponent.clickClaimButton();
|
||||||
|
await browser.refresh();
|
||||||
|
await taskHeaderCloudPage.checkTaskPropertyListIsDisplayed();
|
||||||
|
|
||||||
|
await taskFormCloudComponent.checkReleaseButtonIsDisplayed();
|
||||||
|
await expect(await taskHeaderCloudPage.getStatus()).toEqual('ASSIGNED');
|
||||||
|
await expect(await taskHeaderCloudPage.getAssignee()).toEqual(testUser.username);
|
||||||
|
|
||||||
|
await taskFormCloudComponent.clickReleaseButton();
|
||||||
|
await browser.refresh();
|
||||||
|
await taskHeaderCloudPage.checkTaskPropertyListIsDisplayed();
|
||||||
|
|
||||||
|
await taskFormCloudComponent.checkClaimButtonIsDisplayed();
|
||||||
|
await expect(await taskHeaderCloudPage.getStatus()).toEqual('CREATED');
|
||||||
|
await expect(await taskHeaderCloudPage.getAssignee()).toEqual('No assignee');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
async function navigateToApp(user: { username: string; password: string }) {
|
async function navigateToApp(user: { username: string; password: string }) {
|
||||||
await loginSSOPage.login(user.username, user.password);
|
await loginSSOPage.login(user.username, user.password);
|
||||||
await LocalStorageUtil.setConfigField('adf-edit-task-filter', JSON.stringify(taskFilterConfiguration));
|
await LocalStorageUtil.setConfigField('adf-edit-task-filter', JSON.stringify(taskFilterConfiguration));
|
||||||
@@ -198,7 +260,7 @@ describe('Task claim/release', () => {
|
|||||||
await taskList.getDataTable().waitForTableBody();
|
await taskList.getDataTable().waitForTableBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
async function setTaskFilter(status: StatusType, processInstanceId: string) {
|
async function setStatusTaskFilter(status: StatusType, processInstanceId: string) {
|
||||||
await editTaskFilter.openFilter();
|
await editTaskFilter.openFilter();
|
||||||
await editTaskFilter.clearAssignee();
|
await editTaskFilter.clearAssignee();
|
||||||
await editTaskFilter.setStatusFilterDropDown(status);
|
await editTaskFilter.setStatusFilterDropDown(status);
|
||||||
@@ -206,4 +268,11 @@ describe('Task claim/release', () => {
|
|||||||
await editTaskFilter.setProcessInstanceId(processInstanceId);
|
await editTaskFilter.setProcessInstanceId(processInstanceId);
|
||||||
await editTaskFilter.openFilter();
|
await editTaskFilter.openFilter();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function setStatusStandaloneTaskFilter(status: StatusType) {
|
||||||
|
await editTaskFilter.openFilter();
|
||||||
|
await editTaskFilter.clearAssignee();
|
||||||
|
await editTaskFilter.setStatusFilterDropDown(status);
|
||||||
|
await editTaskFilter.openFilter();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
@@ -0,0 +1,36 @@
|
|||||||
|
/*!
|
||||||
|
* @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 { FormFields } from '../form-fields';
|
||||||
|
import { BrowserActions } from '../../../utils/public-api';
|
||||||
|
import { Locator, by } from 'protractor';
|
||||||
|
|
||||||
|
export class JsonWidgetPage {
|
||||||
|
|
||||||
|
formFields = new FormFields();
|
||||||
|
jsonButtonLocator: Locator = by.css('button');
|
||||||
|
|
||||||
|
async clickJsonButton(fieldId): Promise<void> {
|
||||||
|
const widget = await this.formFields.getWidget(fieldId);
|
||||||
|
const uploadButton = await widget.element(this.jsonButtonLocator);
|
||||||
|
await BrowserActions.click(uploadButton);
|
||||||
|
}
|
||||||
|
|
||||||
|
async checkWidgetIsVisible(fieldId: string): Promise<void> {
|
||||||
|
await this.formFields.checkWidgetIsVisible(fieldId);
|
||||||
|
}
|
||||||
|
}
|
@@ -37,6 +37,7 @@ import { DocumentWidgetPage } from './document-widget.page';
|
|||||||
import { GroupWidgetPage } from './group-widget.page';
|
import { GroupWidgetPage } from './group-widget.page';
|
||||||
import { TypeaheadWidgetPage } from './typeahead-widget.page';
|
import { TypeaheadWidgetPage } from './typeahead-widget.page';
|
||||||
import { AttachFolderWidgetPage } from './attach-folder-widget.page';
|
import { AttachFolderWidgetPage } from './attach-folder-widget.page';
|
||||||
|
import { JsonWidgetPage } from './json-widget.page';
|
||||||
|
|
||||||
export class Widget {
|
export class Widget {
|
||||||
|
|
||||||
@@ -127,4 +128,8 @@ export class Widget {
|
|||||||
tab(): TabPage {
|
tab(): TabPage {
|
||||||
return new TabPage();
|
return new TabPage();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
json(): JsonWidgetPage {
|
||||||
|
return new JsonWidgetPage();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user