admin
2025-01-22 7e31442f0e9b07764e9c6a9680d3d4aeba5fe1de
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
Quintiq file version 2.0
#parent: #root
Method VerifyKPISales (
  MacroPlan macroplan,
  Real expectedValue,
  Real epsilon,
  Real timeoutInSeconds,
  Real elapsedInSeconds
) as stream[UTF_UnitTestMPBase]
{
  Description: 'Verify KPI sales with tolerance of x value.'
  TextBody:
  [*
    actual := macroplan.GetKPISales().Round( 0 );
    currency := macroplan.BaseCurrency().Name();
    
    // Tolerate margin of error between actual and expected
    kpiMatch := GlobalParameters_MP::GetIsBalanceWithinAbsoluteTolerance( actual, expectedValue, epsilon );
    ret := emit( this );
    
    if( not kpiMatch )
    {
      if( elapsedInSeconds < timeoutInSeconds )
      {
        waitFor := 0.5;
        wait := stream[Void]::Wait( Duration::Seconds( waitFor ) );
        ret := ret->After( wait )->VerifyKPISales(  macroplan, expectedValue, epsilon, timeoutInSeconds, elapsedInSeconds + waitFor );
      }
      else
      {
        this.Run().RegisterFailure( 'Expected KPI value for Sales is ' + [String]expectedValue + ' ' + currency + ' but actual value is ' + [String]actual  + ' ' + currency);
      }
    }
    
    return ret;
  *]
  InterfaceProperties { Accessibility: 'Module' }
}