[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:
Cristina Jalba
2021-03-25 10:27:19 +02:00
committed by GitHub
parent 6ec9833b36
commit 09834a1a70
4 changed files with 227 additions and 10 deletions

View 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();
});
});

View File

@@ -24,9 +24,12 @@ import {
LocalStorageUtil,
LoginPage,
ProcessDefinitionsService,
ProcessInstancesService, StatusType,
ProcessInstancesService,
StatusType,
StringUtil,
TaskFormCloudComponent,
TaskHeaderCloudPage
TaskHeaderCloudPage,
TasksService
} from '@alfresco/adf-testing';
import { NavigationBarPage } from '../../core/pages/navigation-bar.page';
import { TasksCloudDemoPage } from './../pages/tasks-cloud-demo.page';
@@ -36,6 +39,7 @@ import { taskFilterConfiguration } from './../config/task-filter.config';
describe('Task claim/release', () => {
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 navigationBarPage = new NavigationBarPage();
@@ -51,6 +55,9 @@ describe('Task claim/release', () => {
const apiService = new ApiService();
const processDefinitionService = new ProcessDefinitionsService(apiService);
const processInstancesService = new ProcessInstancesService(apiService);
const identityService = new IdentityService(apiService);
const groupIdentityService = new GroupIdentityService(apiService);
const tasksService = new TasksService(apiService);
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 () => {
await setTaskFilter('Created', processInstance.id);
await setStatusTaskFilter('Created', processInstance.id);
await taskList.checkContentIsDisplayedByName(candidateApp.tasks.candidateUserTask);
await taskList.selectRow(candidateApp.tasks.candidateUserTask);
@@ -102,14 +109,10 @@ describe('Task claim/release', () => {
});
describe('candidate group', () => {
let identityService: IdentityService;
let groupIdentityService: GroupIdentityService;
let candidate;
beforeAll(async () => {
await apiService.loginWithProfile('identityAdmin');
identityService = new IdentityService(apiService);
groupIdentityService = new GroupIdentityService(apiService);
candidate = await identityService.createIdentityUserWithRole([identityService.ROLES.ACTIVITI_USER]);
const groupInfo = await groupIdentityService.getGroupInfoByGroupName('hr');
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 () => {
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.selectRow(candidateApp.tasks.uploadFileTask);
@@ -158,7 +161,7 @@ describe('Task claim/release', () => {
await navigationBarPage.clickLogoutButton();
await navigateToApp(candidate);
await setTaskFilter('Created', processInstance.id);
await setStatusTaskFilter('Created', processInstance.id);
await taskList.checkContentIsDisplayedByName(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 }) {
await loginSSOPage.login(user.username, user.password);
await LocalStorageUtil.setConfigField('adf-edit-task-filter', JSON.stringify(taskFilterConfiguration));
@@ -198,7 +260,7 @@ describe('Task claim/release', () => {
await taskList.getDataTable().waitForTableBody();
}
async function setTaskFilter(status: StatusType, processInstanceId: string) {
async function setStatusTaskFilter(status: StatusType, processInstanceId: string) {
await editTaskFilter.openFilter();
await editTaskFilter.clearAssignee();
await editTaskFilter.setStatusFilterDropDown(status);
@@ -206,4 +268,11 @@ describe('Task claim/release', () => {
await editTaskFilter.setProcessInstanceId(processInstanceId);
await editTaskFilter.openFilter();
}
async function setStatusStandaloneTaskFilter(status: StatusType) {
await editTaskFilter.openFilter();
await editTaskFilter.clearAssignee();
await editTaskFilter.setStatusFilterDropDown(status);
await editTaskFilter.openFilter();
}
});

View File

@@ -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);
}
}

View File

@@ -37,6 +37,7 @@ import { DocumentWidgetPage } from './document-widget.page';
import { GroupWidgetPage } from './group-widget.page';
import { TypeaheadWidgetPage } from './typeahead-widget.page';
import { AttachFolderWidgetPage } from './attach-folder-widget.page';
import { JsonWidgetPage } from './json-widget.page';
export class Widget {
@@ -127,4 +128,8 @@ export class Widget {
tab(): TabPage {
return new TabPage();
}
json(): JsonWidgetPage {
return new JsonWidgetPage();
}
}