| /** | 
|  * @file         ADSO-10116 | 
|  * @description  Copy single unit cost via list menu | 
|  * @testcategory Web - Financials - Units | 
|  * @author       Gay Er Xuan (erxuan.gay@3ds.com) | 
|  * @copyright    Dassault Systemes | 
|  */ | 
| import { qCustomMatcher } from '../../../e2elib/lib/src/main/qmatchers.const'; | 
| import { AppMP, Demo, Scenario } from '../../../libmp/appmp'; | 
| import { DataFoodBaseAccountUoM } from '../../../libmp/data/data.account'; | 
| import { startOfPlanningYear } from '../../../libmp/data/data.period'; | 
| import { ListUnitCost, ListUnitCostColumn } from '../../../libmp/forms/form.unitcost'; | 
|   | 
| describe('ADSO-10116 - Copy single unit cost via list menu', () => { | 
|   const appMP = AppMP.getInstance(); | 
|   let listUnitCost: ListUnitCost; | 
|   let startOfPlanningDate: Date; | 
|   let endOfPlanningDate: Date; | 
|   let startOfPlanningYearString: string; | 
|   const janSOPMinus1 = `1-Jan-${startOfPlanningYear - 1}`; | 
|   | 
|   const uom = DataFoodBaseAccountUoM.EuroPerMonth; | 
|   | 
|   beforeAll(async () => { | 
|     jasmine.addMatchers(qCustomMatcher); | 
|     await appMP.login(); | 
|   }); | 
|   | 
|   afterAll(async () => { | 
|     await appMP.cleanupAndLogout(); | 
|   }); | 
|   | 
|   afterEach(async () => { | 
|     await appMP.checkToastMessage(); | 
|   }); | 
|   | 
|   it(`Setup - ${AppMP.getDemoDataPath(Demo.Food, Scenario.Base)}`, async () => { | 
|     await appMP.createDemoDataset(Demo.Food, Scenario.Base, false); | 
|   }); | 
|   | 
|   it(`Setup - Open view ${appMP.viewPeriod.viewPath}. Get start and end of planning`, async () => { | 
|     // Open Periods view | 
|     await appMP.viewPeriod.switchTo(); | 
|     const formPeriod = appMP.viewPeriod.frmPeriod; | 
|     startOfPlanningDate = await formPeriod.getStartOfPlanningDate(); | 
|     endOfPlanningDate = await formPeriod.getEndOfPlanningDate(); | 
|     startOfPlanningYearString = startOfPlanningDate.getFullYear().toString(); | 
|   }); | 
|   | 
|   it(`Setup - Open view ${appMP.viewUnitCost.viewPath}. Verify DE Fermenter exist`, async () => { | 
|     // Open unit cost view | 
|     await appMP.viewUnitCost.switchTo(); | 
|     listUnitCost = appMP.viewUnitCost.frmUnitCost.listUnitCost; | 
|     // Filter by DE Fermenter | 
|     await appMP.formNavigation.filterByEntity('DE Fermenter', ['Europe', 'Plants', 'Denmark Plant']); | 
|     // Verify 1 DE Fermenter Unit Cost exist in the list | 
|     await listUnitCost.waitForScreenUpdate(); | 
|     expect(await listUnitCost.getRowCount()).toBe(1, 'Exactly one DE Fermenter Unit Cost should exist in the list'); | 
|     const unitCost = await listUnitCost.getRowByIndex(0); | 
|     expect(await (await unitCost.getCell(ListUnitCostColumn.Start)).getValue()).toBe(janSOPMinus1, `Start of the DE Fermenter unit cost should be ${janSOPMinus1}`); | 
|   }); | 
|   | 
|   it('Step 1 - Copy single unit cost via list menu', async () => { | 
|     // Open copy dialog | 
|     const unitCost = await listUnitCost.getRowByIndex(0); | 
|     let dlgUnitCost = await listUnitCost.openEditDialog(unitCost, true); | 
|     // Verify field value in dialog | 
|     const verifyBeforeDialogFeedback = await dlgUnitCost.verifyDialogValue('General fixed costs', 'Fixed', 'DE Fermenter', new Date(janSOPMinus1), 'Month', 1, 1000); | 
|     expect(verifyBeforeDialogFeedback.length).toBe(0, verifyBeforeDialogFeedback.join('. ')); | 
|     // Verify OK button is disabled with precondition | 
|     expect(await dlgUnitCost.btnOk.isClickable()).toBe(false, 'OK button should be disabled'); | 
|     expect(await dlgUnitCost.getOKButtonTooltip()).toBe('Identical cost definition exists. Unit cost must be unique by Account, Cost driver and Start date.', 'Feedback text should match'); | 
|     // Update start value | 
|     await dlgUnitCost.updateUnitCostValue(undefined, undefined, undefined, new Date(startOfPlanningDate.getFullYear(), 1, 1)); | 
|     expect(await dlgUnitCost.btnOk.isClickable()).toBe(true, 'OK button should be enabled'); | 
|     await dlgUnitCost.clickOK(); | 
|     // Verify row created with correct values in dialog | 
|     const previousUnitCost = await listUnitCost.getRowByCellValue(ListUnitCostColumn.Start, janSOPMinus1); | 
|     const newUnitCost = await listUnitCost.getRowByCellValue(ListUnitCostColumn.Start, `1-Feb-${startOfPlanningYearString}`); | 
|     dlgUnitCost = await listUnitCost.openEditDialog(newUnitCost); | 
|     const verifyAfterDialogFeedback = await dlgUnitCost.verifyDialogValue('General fixed costs', 'Fixed', 'DE Fermenter', new Date(startOfPlanningDate.getFullYear(), 1, 1), 'Month', 1, 1000); | 
|     expect(verifyAfterDialogFeedback.length).toBe(0, verifyAfterDialogFeedback.join('. ')); | 
|     await dlgUnitCost.clickCancel(); | 
|     // Verify UoM, Start, and End column value of the new row | 
|     expect(await listUnitCost.getCellValueFromRow(ListUnitCostColumn.UoM, newUnitCost)).toBe(uom, `UoM should be ${uom}`); | 
|     const newUnitCostStartString = `1-Feb-${startOfPlanningYearString}`; | 
|     const endOfPlanningString = `${endOfPlanningDate.getDate().toString()}-${endOfPlanningDate.toLocaleString(undefined, { month: 'short' })}-${endOfPlanningDate.getFullYear().toString()}`; | 
|     expect(await listUnitCost.getCellValueFromRow(ListUnitCostColumn.Start, newUnitCost)).toBe(newUnitCostStartString, `Start should be ${newUnitCostStartString}`); | 
|     expect(await listUnitCost.getCellValueFromRow(ListUnitCostColumn.End, newUnitCost)).toBe(endOfPlanningString, `End should be ${endOfPlanningString}`); | 
|     // Verify Start and End column value of the previous unit cost | 
|     expect(await listUnitCost.getCellValueFromRow(ListUnitCostColumn.Start, previousUnitCost)).toBe(janSOPMinus1, `Start should be ${janSOPMinus1}`); | 
|     expect(await listUnitCost.getCellValueFromRow(ListUnitCostColumn.End, previousUnitCost)).toBe(newUnitCostStartString, `End should be ${newUnitCostStartString}`); | 
|   }); | 
| }); |