lazhen
2025-01-08 adb6335399c5a1658d8d8172a91042585f3e30b1
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
Quintiq file version 2.0
#parent: #root
Method VerifyKPINumberOfShelfLifeViolation (
  MacroPlan macroplan,
  Number expectedValue,
  Real timeoutInSeconds,
  Real elapsedInSeconds
)
{
  Description: 'Verify KPI Number of Shelf Life Violation matches the expected value within timeout (in seconds).'
  TextBody:
  [*
    actual := macroplan.GetKPINumberOfShelfLifeViolation();
    kpiMatch := actual = expectedValue;
    
    if( not kpiMatch )
    {
      if( elapsedInSeconds < timeoutInSeconds )
      {
        waitFor := 0.5;
        wait := stream[Void]::Wait( Duration::Seconds( waitFor ) );
        this->After( wait )->VerifyKPINumberOfShelfLifeViolation( macroplan, expectedValue, timeoutInSeconds, elapsedInSeconds + waitFor );
      }
      else
      {
        this.Run().RegisterFailure( 'Expected KPI value for Number of Shelf Life Violation is ' + [String]expectedValue + ' but actual value is ' + [String]actual );
      }
    }
  *]
  InterfaceProperties { Accessibility: 'Module' }
}