/*! * @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, ApplicationsUtil, DatePickerCalendarPage, DateUtil, LoginPage, UsersActions, Widget } from '@alfresco/adf-testing'; import { ProcessFiltersPage } from './../pages/process-filters.page'; import { ProcessServiceTabBarPage } from './../pages/process-service-tab-bar.page'; import { NavigationBarPage } from '../../core/pages/navigation-bar.page'; import { browser } from 'protractor'; describe('Dynamic Table', () => { const loginPage = new LoginPage(); const processFiltersPage = new ProcessFiltersPage(); const processServiceTabBarPage = new ProcessServiceTabBarPage(); const datePicker = new DatePickerCalendarPage(); const navigationBarPage = new NavigationBarPage(); const widget = new Widget(); const apiService = new ApiService(); const usersActions = new UsersActions(apiService); let user, tenantId, appId; beforeAll(async () => { await apiService.loginWithProfile('admin'); user = await usersActions.createUser(); tenantId = user.tenantId; }); afterAll(async () => { await apiService.loginWithProfile('admin'); await apiService.getInstance().activiti.adminTenantsApi.deleteTenant(tenantId); }); describe('Date Picker', () => { const app = browser.params.resources.Files.DYNAMIC_TABLE_APP; const randomText = { date: '12/12/2012', wrongDate: 'HELLO WORLD', wrongDateTime: 'Test', dateTime: '15/07/2019 23:55', error: `Invalid 'columnDate' format.`, requiredError: `Field 'columnDate' is required.` }; const currentDate = DateUtil.formatDate('DD-MM-YYYY'); const rowPosition = 0; beforeAll(async () => { await apiService.login(user.username, user.password); const applicationsService = new ApplicationsUtil(apiService); const importedApp = await applicationsService.importPublishDeployApp(app.file_path); appId = importedApp.id; await loginPage.login(user.username, user.password); }); afterAll(async () => { await apiService.login(user.username, user.password); await apiService.getInstance().activiti.modelsApi.deleteModel(appId); await navigationBarPage.clickLogoutButton(); }); beforeEach(async () => { await (await (await navigationBarPage.navigateToProcessServicesPage()).goToTaskApp()).clickProcessButton(); await processServiceTabBarPage.clickProcessButton(); await processFiltersPage.clickCreateProcessButton(); await processFiltersPage.clickNewProcessDropdown(); }); it('[C286277] Should have a datepicker and a mask for DateTime field', async () => { await widget.dynamicTable().clickAddRow(); await widget.dynamicTable().clickColumnDateTime(); await expect(await widget.dynamicTable().addRandomStringOnDateTime(randomText.wrongDateTime)).toBe(''); }); it('[C286279] Should be able to save row with Date field', async () => { await widget.dynamicTable().clickAddRow(); await widget.dynamicTable().addRandomStringOnDate(randomText.wrongDate); await widget.dynamicTable().clickSaveButton(); await expect(await widget.dynamicTable().checkErrorMessage()).toBe(randomText.error); await widget.dynamicTable().clickDateWidget(); await datePicker.selectTodayDate(); await datePicker.checkDatePickerIsNotDisplayed(); await widget.dynamicTable().clickSaveButton(); await widget.dynamicTable().getTableRow(rowPosition); await expect(await widget.dynamicTable().getTableCellText(rowPosition, 1)).toBe(currentDate); }); it('[C311456] Should be able to delete date that is not mandatory and save the Dynamic Table', async () => { await widget.dynamicTable().clickAddRow(); await widget.dynamicTable().clickSaveButton(); await expect(await widget.dynamicTable().checkErrorMessage()).toBe(randomText.requiredError); await widget.dynamicTable().clickDateWidget(); await datePicker.selectTodayDate(); await datePicker.checkDatePickerIsNotDisplayed(); await widget.dynamicTable().clickSaveButton(); await widget.dynamicTable().getTableRow(rowPosition); await expect(await widget.dynamicTable().getTableCellText(rowPosition, 1)).toBe(currentDate); await expect(await widget.dynamicTable().getTableCellText(rowPosition, 2)).toBe(''); }); }); describe('Required Dropdown', () => { const app = browser.params.resources.Files.APP_DYNAMIC_TABLE_DROPDOWN; const dropdown = widget.dropdown(); beforeAll(async () => { await apiService.login(user.username, user.password); const applicationsService = new ApplicationsUtil(apiService); const importedApp = await applicationsService.importPublishDeployApp(app.file_path); appId = importedApp.id; await loginPage.login(user.username, user.password); }); afterAll(async () => { await apiService.login(user.username, user.password); await apiService.getInstance().activiti.modelsApi.deleteModel(appId); }); beforeEach(async () => { await (await (await navigationBarPage.navigateToProcessServicesPage()).goToApp(app.title)).clickProcessButton(); await processServiceTabBarPage.clickProcessButton(); await processFiltersPage.clickCreateProcessButton(); await processFiltersPage.clickNewProcessDropdown(); }); it('[C286519] Should be able to save row with required dropdown column', async () => { const dropdownOption = 'Option 1'; await widget.dynamicTable().clickAddRow(); await dropdown.selectOption(dropdownOption); await widget.dynamicTable().clickSaveButton(); await widget.dynamicTable().checkItemIsPresent(dropdownOption); }); }); });