/**
|
* @file ADSO-10182
|
* @description Edit single stocking cost via context menu - update Start and Cost
|
* @testcategory Web - Financials - Stocking points
|
* @author Gay Er Xuan (erxuan.gay@3ds.com)
|
* @copyright Dassault Systèmes
|
*/
|
import { qCustomMatcher } from '../../../e2elib/lib/src/main/qmatchers.const';
|
import { ColumnIDValueMap } from '../../../libappbase/listbase';
|
import { LogMessage } from '../../../libappbase/logmessage';
|
import { AppMP, Demo, Scenario } from '../../../libmp/appmp';
|
import { DataFoodBaseEntityName } from '../../../libmp/data/data.navigation';
|
import { DataFoodBaseAccountCost, DataFoodBaseAccountCostDriver, DataFoodBaseAccountLengthOfTime, DataFoodBaseAccountName, DataFoodBaseAccountTimeUnit } from '../../../libmp/data/data.account';
|
import { DialogStockingCost } from '../../../libmp/dialogs/dialog.stockingcost';
|
import { ListStockingCostColumn } from '../../../libmp/forms/form.stockingcost';
|
import { ActionTriggerType } from '../../../libappbase/utils';
|
import { startOfPlanningYear } from '../../../libmp/data/data.period';
|
|
describe('ADSO-10182 - Edit single stocking cost via context menu - update Start and Cost', () => {
|
// Component used in this script
|
const appMP = AppMP.getInstance();
|
const listStockingCost = appMP.viewStockingCost.frmStockingCost.lstStockingCost;
|
|
// Variable used across multiple steps
|
let sopYear: string;
|
let oldStartDate: Date;
|
let newStartDate: Date;
|
let dialog: DialogStockingCost;
|
|
// Test data
|
const oldStartDateStr = `1-Jan-${startOfPlanningYear - 1}`;
|
let newStartDateStr = '1-Feb'; // Year to be added after getting SOP year
|
|
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} to get the start of planning (SOP) year`, async () => {
|
await appMP.viewPeriod.switchTo();
|
const formPeriod = appMP.viewPeriod.frmPeriod;
|
({ sopYear } = await formPeriod.getStartAndEndOfPlanning());
|
newStartDateStr = `${newStartDateStr}-${sopYear}`;
|
newStartDate = new Date(newStartDateStr);
|
oldStartDate = new Date(oldStartDateStr);
|
});
|
|
it(`Step 1 - Open view ${appMP.viewStockingCost.viewPath}, select ${DataFoodBaseAccountName.GeneralFixedCosts} for ${DataFoodBaseEntityName.DCAustria} \
|
in stocking cost list, then verify the values in dialog`, async () => {
|
await appMP.viewStockingCost.switchTo();
|
const searchCriteria: ColumnIDValueMap[] = [
|
{ columnID: ListStockingCostColumn.Account, value: DataFoodBaseAccountName.GeneralFixedCosts },
|
{ columnID: ListStockingCostColumn.StockingPoint, value: DataFoodBaseEntityName.DCAustria },
|
];
|
const row = await listStockingCost.getRowByValue(searchCriteria);
|
dialog = await listStockingCost.openStockingCostDialog(ActionTriggerType.ContextMenu, row);
|
const feedback = await dialog.verifyDialogValue(DataFoodBaseAccountName.GeneralFixedCosts, DataFoodBaseAccountCostDriver.Fixed, DataFoodBaseEntityName.DCAustria, oldStartDate, DataFoodBaseAccountTimeUnit.Month, DataFoodBaseAccountLengthOfTime._1, DataFoodBaseAccountCost._1000);
|
expect(feedback.length).toBe(0, feedback.join('. \n'));
|
});
|
|
it('Step 2 - Modify the dialog value with "Start = 1-Feb (SOP Year)", "Cost = 2000"', async () => {
|
await dialog.updateDialog(undefined, undefined, undefined, newStartDate, DataFoodBaseAccountCost._2000);
|
const [isClickable, tooltip] = await dialog.btnOk.verifyIsButtonClickable();
|
expect(isClickable).toBe(true, LogMessage.btn_notClickable('OK', tooltip));
|
await dialog.btnOk.click();
|
await listStockingCost.waitForScreenUpdate();
|
});
|
|
it('Step 3 - Verify that a new stocking cost created with value in step 2', async () => {
|
const searchCriteria: ColumnIDValueMap[] = [
|
{ columnID: ListStockingCostColumn.Account, value: DataFoodBaseAccountName.GeneralFixedCosts },
|
{ columnID: ListStockingCostColumn.StockingPoint, value: DataFoodBaseEntityName.DCAustria },
|
{ columnID: ListStockingCostColumn.Start, value: newStartDateStr },
|
{ columnID: ListStockingCostColumn.Cost, value: DataFoodBaseAccountCost._2000.toLocaleString('en') },
|
];
|
|
const rowFound = await listStockingCost.getRowByValue(searchCriteria);
|
expect(rowFound).toBeDefined(`Expect ${DataFoodBaseAccountName.GeneralFixedCosts} of ${DataFoodBaseEntityName.DCAustria} with startd date = ${newStartDateStr}, cost = ${DataFoodBaseAccountCost._2000} to be found in "Stocking Cost" list`);
|
});
|
});
|