mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-26 17:24:56 +00:00
* update project script possible different JS-API * first commit no controll flow * second commit no controll flow * third commit no controll flow * 4 commit no controll flow * 5 commit no controll flow * 6 commit no controll flow * 7 commit no controll flow * 8 commit no controll flow * 9 commit no controll flow * 10 commit no controll flow * 11 commit no controll flow * 12 commit no controll flow * 13 commit no controll flow * 14 commit no controll flow * 15 commit no controll flow * 16 commit no controll flow * 17 commit no controll flow * 18 commit no controll flow * 19 commit no controll flow * 20 commit no controll flow * remove wdpromise, protractor promise and deferred promises * - fixed some incorrect “expect” calls - fixed some matchers - removed “return this;” when not needed - added a few more await-s * forgot a file * fix some failing tests * replaced driver calls with browser calls and enabled back waitForAngular * fix rightClick methods and hopefully some tests * fix settings-component * some more fixes for core and content tests * try to fix some more issues * linting * revert some changes, allowing download on headless chrome won’t work with multiple browser instances * fixes for Search tests * try to remove some wait calls * fix build * increase allScriptsTimeout and try another protractor and web driver version * improve navigation methods * some fixes for notification history and login sso * forgot a space * fix packages and enable some screenshots * navigation bar fixes * fix some test * some fixes for notification history and navigation bar use correct visibility method in attachFileWidget test * fix searching and another fix for navigation * try solve sso login * some more fixes * refactor async forEach into for..of * try fix for search tests * resolve rebabse problems * remove install * fix lint * fix core e2e * fix core e2e * fix core e2e * fix ps tests * fix some tests * fix core e2e * fix core e2e * fix core * fix some issues PS * fix core * fix core * fix some ps test * fix rebase issues * remove save * fix url regressed after rebase * fix url regressed after rebase * fix ps and core * fix lint * more parallel e2e ps * fix some ps cloud test * some cloud fix * fix lint * fix some test * remove files to be ignored * out-tsc * improve one cs test * fix candidate base app * fix ps test * remove click function * clean methods alrady present in browser action * try ugly wait * move wait * remove duplicate call * remove underscore * fix after review * fix imports * minor cosmetic fixes * fix comments test
190 lines
11 KiB
TypeScript
190 lines
11 KiB
TypeScript
/*!
|
|
* @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 CONSTANTS = require('../util/constants');
|
|
import { ApiService, StringUtil, SettingsPage, IdentityService, GroupIdentityService, LocalStorageUtil } from '@alfresco/adf-testing';
|
|
import moment = require('moment');
|
|
import { browser } from 'protractor';
|
|
|
|
import { NavigationBarPage } from '../pages/adf/navigationBarPage';
|
|
import { LoginSSOPage, AppListCloudPage, TaskHeaderCloudPage, TasksService } from '@alfresco/adf-testing';
|
|
import { TasksCloudDemoPage } from '../pages/adf/demo-shell/process-services/tasksCloudDemoPage';
|
|
import resources = require('../util/resources');
|
|
|
|
describe('Task Header cloud component', () => {
|
|
const basicCreatedTaskName = StringUtil.generateRandomString();
|
|
const completedTaskName = StringUtil.generateRandomString();
|
|
let basicCreatedTask;
|
|
let basicCreatedDate;
|
|
let completedTask;
|
|
let completedCreatedDate;
|
|
let subTask;
|
|
let subTaskCreatedDate;
|
|
let completedEndDate;
|
|
let defaultDate;
|
|
let groupInfo, testUser;
|
|
const simpleApp = resources.ACTIVITI7_APPS.SIMPLE_APP.name;
|
|
const priority = 30;
|
|
const description = 'descriptionTask';
|
|
const formatDate = 'MMM D, YYYY';
|
|
const defaultFormat = 'M/D/YY';
|
|
|
|
const taskHeaderCloudPage = new TaskHeaderCloudPage();
|
|
|
|
const loginSSOPage = new LoginSSOPage();
|
|
const navigationBarPage = new NavigationBarPage();
|
|
const appListCloudComponent = new AppListCloudPage();
|
|
const tasksCloudDemoPage = new TasksCloudDemoPage();
|
|
const settingsPage = new SettingsPage();
|
|
const apiService = new ApiService(browser.params.config.oauth2.clientId, browser.params.config.bpmHost, browser.params.config.oauth2.host, browser.params.config.providers);
|
|
let tasksService: TasksService;
|
|
let identityService: IdentityService;
|
|
let groupIdentityService: GroupIdentityService;
|
|
|
|
beforeAll(async () => {
|
|
await apiService.login(browser.params.identityAdmin.email, browser.params.identityAdmin.password);
|
|
identityService = new IdentityService(apiService);
|
|
groupIdentityService = new GroupIdentityService(apiService);
|
|
testUser = await identityService.createIdentityUserWithRole(apiService, [identityService.ROLES.APS_USER]);
|
|
|
|
groupInfo = await groupIdentityService.getGroupInfoByGroupName('hr');
|
|
await identityService.addUserToGroup(testUser.idIdentityService, groupInfo.id);
|
|
await apiService.login(testUser.email, testUser.password);
|
|
|
|
tasksService = new TasksService(apiService);
|
|
|
|
const createdTaskId = await tasksService.createStandaloneTask(basicCreatedTaskName, simpleApp);
|
|
await tasksService.claimTask(createdTaskId.entry.id, simpleApp);
|
|
basicCreatedTask = await tasksService.getTask(createdTaskId.entry.id, simpleApp);
|
|
basicCreatedDate = moment(basicCreatedTask.entry.createdDate).format(formatDate);
|
|
|
|
const completedTaskId = await tasksService.createStandaloneTask(completedTaskName,
|
|
simpleApp, {priority: priority, description: description, dueDate: basicCreatedTask.entry.createdDate});
|
|
await tasksService.claimTask(completedTaskId.entry.id, simpleApp);
|
|
await tasksService.completeTask(completedTaskId.entry.id, simpleApp);
|
|
completedTask = await tasksService.getTask(completedTaskId.entry.id, simpleApp);
|
|
completedCreatedDate = moment(completedTask.entry.createdDate).format(formatDate);
|
|
completedEndDate = moment(completedTask.entry.endDate).format(formatDate);
|
|
defaultDate = moment(completedTask.entry.createdDate).format(defaultFormat);
|
|
|
|
const subTaskId = await tasksService.createStandaloneSubtask(createdTaskId.entry.id, simpleApp, StringUtil.generateRandomString());
|
|
await tasksService.claimTask(subTaskId.entry.id, simpleApp);
|
|
subTask = await tasksService.getTask(subTaskId.entry.id, simpleApp);
|
|
subTaskCreatedDate = moment(subTask.entry.createdDate).format(formatDate);
|
|
|
|
await settingsPage.setProviderBpmSso(
|
|
browser.params.config.bpmHost,
|
|
browser.params.config.oauth2.host,
|
|
browser.params.config.identityHost);
|
|
await loginSSOPage.loginSSOIdentityService(testUser.email, testUser.password);
|
|
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await apiService.login(browser.params.identityAdmin.email, browser.params.identityAdmin.password);
|
|
await identityService.deleteIdentityUser(testUser.idIdentityService);
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
await navigationBarPage.navigateToProcessServicesCloudPage();
|
|
await appListCloudComponent.checkApsContainer();
|
|
await appListCloudComponent.goToApp(simpleApp);
|
|
});
|
|
|
|
it('[C291943] Should display task details for assigned task', async () => {
|
|
await tasksCloudDemoPage.myTasksFilter().clickTaskFilter();
|
|
await tasksCloudDemoPage.taskListCloudComponent().checkContentIsDisplayedByName(basicCreatedTaskName);
|
|
await tasksCloudDemoPage.taskListCloudComponent().selectRow(basicCreatedTaskName);
|
|
await expect(await taskHeaderCloudPage.getId()).toEqual(basicCreatedTask.entry.id);
|
|
await expect(await taskHeaderCloudPage.getDescription())
|
|
.toEqual(basicCreatedTask.entry.description === null ? CONSTANTS.TASK_DETAILS.NO_DESCRIPTION : basicCreatedTask.entry.description);
|
|
await expect(await taskHeaderCloudPage.getStatus()).toEqual(basicCreatedTask.entry.status);
|
|
await expect(await taskHeaderCloudPage.getPriority()).toEqual(basicCreatedTask.entry.priority === 0 ? '' : basicCreatedTask.entry.priority.toString());
|
|
await expect(await taskHeaderCloudPage.getCategory()).toEqual(!basicCreatedTask.entry.category ?
|
|
CONSTANTS.TASK_DETAILS.NO_CATEGORY : basicCreatedTask.entry.category);
|
|
await expect(await taskHeaderCloudPage.getDueDate()).toEqual(basicCreatedTask.entry.dueDate === null ?
|
|
CONSTANTS.TASK_DETAILS.NO_DATE : basicCreatedDate);
|
|
await expect(await taskHeaderCloudPage.getEndDate()).toEqual('');
|
|
await expect(await taskHeaderCloudPage.getCreated()).toEqual(basicCreatedDate);
|
|
await expect(await taskHeaderCloudPage.getAssignee()).toEqual(basicCreatedTask.entry.assignee === null ? '' : basicCreatedTask.entry.assignee);
|
|
await expect(await taskHeaderCloudPage.getParentName()).toEqual(CONSTANTS.TASK_DETAILS.NO_PARENT);
|
|
});
|
|
|
|
it('[C291944] Should display task details for completed task', async () => {
|
|
await tasksCloudDemoPage.myTasksFilter().clickTaskFilter();
|
|
await tasksCloudDemoPage.completedTasksFilter().clickTaskFilter();
|
|
await tasksCloudDemoPage.taskListCloudComponent().checkContentIsDisplayedByName(completedTaskName);
|
|
await tasksCloudDemoPage.taskListCloudComponent().selectRow(completedTaskName);
|
|
await expect(await taskHeaderCloudPage.getId()).toEqual(completedTask.entry.id);
|
|
await expect(await taskHeaderCloudPage.getDescription())
|
|
.toEqual(completedTask.entry.description === null ? CONSTANTS.TASK_DETAILS.NO_DESCRIPTION : completedTask.entry.description);
|
|
await expect(await taskHeaderCloudPage.getStatus()).toEqual(completedTask.entry.status);
|
|
await expect(await taskHeaderCloudPage.getPriority()).toEqual(completedTask.entry.priority === '0' ? '' : completedTask.entry.priority.toString());
|
|
await expect(await taskHeaderCloudPage.getCategory()).toEqual(!completedTask.entry.category ?
|
|
CONSTANTS.TASK_DETAILS.NO_CATEGORY : completedTask.entry.category);
|
|
await expect(await taskHeaderCloudPage.getDueDate()).toEqual(completedTask.entry.dueDate === null ?
|
|
CONSTANTS.TASK_DETAILS.NO_DATE : completedCreatedDate);
|
|
await expect(await taskHeaderCloudPage.getEndDate()).toEqual(completedEndDate);
|
|
await expect(await taskHeaderCloudPage.getCreated()).toEqual(completedCreatedDate);
|
|
await expect(await taskHeaderCloudPage.getAssignee()).toEqual(completedTask.entry.assignee === null ? '' : completedTask.entry.assignee);
|
|
await expect(await taskHeaderCloudPage.getParentName()).toEqual(CONSTANTS.TASK_DETAILS.NO_PARENT);
|
|
});
|
|
|
|
it('[C291945] Should Parent Name and Parent Id not be empty in task details for sub task', async () => {
|
|
await tasksCloudDemoPage.myTasksFilter().clickTaskFilter();
|
|
await tasksCloudDemoPage.taskListCloudComponent().checkContentIsDisplayedByName(subTask.entry.name);
|
|
await tasksCloudDemoPage.taskListCloudComponent().selectRow(subTask.entry.name);
|
|
await expect(await taskHeaderCloudPage.getId()).toEqual(subTask.entry.id);
|
|
await expect(await taskHeaderCloudPage.getDescription())
|
|
.toEqual(subTask.entry.description === null ? CONSTANTS.TASK_DETAILS.NO_DESCRIPTION : subTask.entry.description);
|
|
await expect(await taskHeaderCloudPage.getStatus()).toEqual(subTask.entry.status);
|
|
await expect(await taskHeaderCloudPage.getPriority()).toEqual(subTask.entry.priority === 0 ? '' : subTask.entry.priority.toString());
|
|
await expect(await taskHeaderCloudPage.getCategory()).toEqual(!subTask.entry.category ?
|
|
CONSTANTS.TASK_DETAILS.NO_CATEGORY : subTask.entry.category);
|
|
await expect(await taskHeaderCloudPage.getDueDate()).toEqual(subTask.entry.dueDate === null ?
|
|
CONSTANTS.TASK_DETAILS.NO_DATE : subTaskCreatedDate);
|
|
await expect(await taskHeaderCloudPage.getEndDate()).toEqual('');
|
|
await expect(await taskHeaderCloudPage.getCreated()).toEqual(subTaskCreatedDate);
|
|
await expect(await taskHeaderCloudPage.getAssignee()).toEqual(subTask.entry.assignee === null ? '' : subTask.entry.assignee);
|
|
await expect(await taskHeaderCloudPage.getParentName()).toEqual(basicCreatedTask.entry.name);
|
|
await expect(await taskHeaderCloudPage.getParentTaskId())
|
|
.toEqual(subTask.entry.parentTaskId === null ? '' : subTask.entry.parentTaskId);
|
|
});
|
|
|
|
describe('Default Date format', () => {
|
|
beforeEach(async () => {
|
|
await LocalStorageUtil.setConfigField('dateValues', '{' +
|
|
'"defaultDateFormat": "shortDate",' +
|
|
'"defaultDateTimeFormat": "M/d/yy, h:mm a",' +
|
|
'"defaultLocale": "uk"' +
|
|
'}');
|
|
await navigationBarPage.navigateToProcessServicesCloudPage();
|
|
await appListCloudComponent.checkApsContainer();
|
|
await appListCloudComponent.goToApp(simpleApp);
|
|
});
|
|
|
|
it('[C311280] Should pick up the default date format from the app configuration', async () => {
|
|
await tasksCloudDemoPage.myTasksFilter().clickTaskFilter();
|
|
await tasksCloudDemoPage.completedTasksFilter().clickTaskFilter();
|
|
await tasksCloudDemoPage.taskListCloudComponent().checkContentIsDisplayedByName(completedTaskName);
|
|
await tasksCloudDemoPage.taskListCloudComponent().selectRow(completedTaskName);
|
|
await taskHeaderCloudPage.checkTaskPropertyListIsDisplayed();
|
|
await expect(await taskHeaderCloudPage.getCreated()).toEqual(defaultDate);
|
|
});
|
|
});
|
|
});
|