Saturday, 28 November 2015

SAP CBTA Advanced - How to make use of Conditions, Loops

PREREQUISITES
The looping capability are planned to be shipped with SAP Solution Manager 7.1 SP13
Alternatively you can implement following notes in advance:

USE-CASE FOR LOOP FUNCTIONALITY:
A test script may need to perform actions against an unknown number of entries in a table. The script may therefore need to:
•    Start at first row and check if there is an entry
•    If entry exists perform one or more actions on the current row
•    Continue with next row

REQUIRED DEFAULT COMPONENTS: DO, EXIT_DO, LOOP

Keyword: DO
It can be used to iterate over several steps. It defines where the loop starts.
•    It must be used together with the LOOP keyword which defines where the loop ends.
•    The EXIT_DO keyword must be used as well to determine when to stop the loop.

The CounterName parameter provides the name of the iteration counter. This counter is incremented automatically at runtime while iterating over the included steps. The actual value of the counter can be retrieve using the regular token syntax.
For instance, when CounterName is set to "COUNTER" its value can be reused in the subsequent steps using %COUNTER% (or $COUNTER$ for specific situations where the percent character is ambiguous).

If you plan to use nested loops please make sure to declare a different counter names.

Component Parameters

CounterName: Specifies the the name of the iteration counter.

Keyword: EXIT DO
It must be used within a loop that has been defined using the DO and the LOOP keywords. The EXIT_DO keyword interrupts the loop as soon as the condition is met.
A typical use case is to check the value of iteration counter that has been declared via the CounterName parameter of the DO keyword.
For instance, when CounterName is set to "COUNTER" its value can be checked using the %COUNTER% token.

Component Parameters
LeftOperand
•    Specifies the value of the left operand that is to be checked.
Operator
•    Specifies the boolean operator to use.
The operators supported are the ones below:
o    = for "Equal to"
o    < for "Less than"
o    > for "Greater than"
o    <= for "Less than or equal to"
o    >= for "Greater than or equal to"
o    <> for "Not equal to"
o    {contains} for "Contains"
o    {startsWith} for "Starts with"
o    {endsWith} for "Ends with"
An additional operator is supported when testing WEB applications (i.e.: applications running in the browser):
o    {matches} for checking whether the value matches a regular expression. The regular expressions are expressed using the .NET syntax.
RightOperand
•    Specifies the value of the right operand that is to be compared with the left operand.

Options
The options parameter lets you perform some adaptations or conversions of both the left and right operand before comparing them.
The supported options are:
•    /u (for uppercase) - Both values are converted to upper-case before being compared
•    /t (for trimmed) - Both values are trimmed before being compared
•    /i (integer) - Both values are converted to an integer before being compared
•    /f (float) - Both values are converted to a float (or double) before being compared
•    /b (bool) - Both values are converted to a Boolean before being compared

Keyword: LOOP
It defines the end of the loop and must be used together with the DO keyword which defines where the loop starts.


EXAMPLE – PROCESS LINE ITEMS IN SALES ORDER
The following scripts was created for transaction VA02 (Change Sales Order) to add shipping information for each line item of an existing sales order.

No comments:

Post a Comment