The Test Case Command Sequencer allows you to create and specify the functions, parameters, and timers that indicate when the function should be triggered. With test case Command Sequencer window, you can define multiple commands, including a list of arguments. Select the Sequencer test activity on the configuration tab.
You may select pre-defined commands, loops counts, and delays to indicate the commands to be repeated. The pre-defined command sequence are executed on the Test Server.
Each test case has only one sequence of commands and the test server executes the commands one at a time in the order listed. The Sequencer executes the first command, when it completes, executes the next command and so on.
Each test case included has one thread of execution, that is, one set of onDemand Commands specified using the Sequencer Window. It includes Actions described in Manage Command Sequencer Steps, ODCs, Delays, Loops, and Start/Stop ALL Traffic, no ACTION_X or LOGs. They run in order, immediately following each other. Estimated Duration and Elapsed Time (in seconds) provide you with an estimate of how long an Action may take to execute and how long it actually took to execute. Additional details below.
Estimated Duration of an action (in seconds) is an estimate of how long the action will take to execute. It is an estimate and should only be relied upon for Delays and ODCs that have a “rate” argument. Do not rely on the Estimated Duration for things like Sync Points, Stop DMFs, Start DMFs, ODCs without a Rate. For On Demand Commands (ODCs) with Rates, the Estimated Duration is derived by:
The # of UEs / RATE UNITs math: Attach 100 UEs at 1 UE/S = 100s. UE / (UE/s) == s. Thus, for as long as the execution can keep upand the Test Server is not overloaded, we should expect it will take ~100s to get through this ODC. A Delay of 10s should take 10s (unless teh TS is overloaded and timers can’t keep up). Example of Command Sequencer tests listed below.
Some ODC commands such as SGW Nodal External Apps, detailed here Command Mode Test Activity , estimate duration time in different manner.
Elapsed Time in seconds is how long the action actually took to execute.
You may select the end of a subset of command (within the sequence of commands) to execute when a test case is stopped before the Sequencer completes on its own. This allows for graceful cleanup of SUTs when sequencer test cases are manually terminated prior to the end of a test. To set/indicate a the Graceful Stop sequence, select the first command of the end of the subset to be executed.
TIP: See Set Graceful Stop to set the graceful stop sequence. |
NOTES: The following applies to the Sequencer OnDemand Command (ODC) execution/operation:
|
TIP:
The Session Index arguments and the DMF Index arguments will be automatically updated by the Tcl API during validation, all you need to do is define arguments (placeholders) and set the STARTING index to 1 and ENDING index to last index (i.e. total number sessions). Example: { OnDemandCommand { ControlBearer { Handover 1000.0 1 1 4 } } } Where: The first two 1’s indicate the Session range, and these will be updated by the Tcl API to include the entire range of MNs, that is, 1 – total sessions. |
CommandSequence “\{ \{ ITEM \} \{ ITEM \} \{ ITEM \} …. \{ ITEM \}”
ITEM = DELAY_ITEM | ODC_ITEM | START_TRAFFIC | WAIT | STOP_TRAFFIC | LOOP_START | LOOP_END
DELAY_ITEM = { Delay NUMBER_OF_SECONDS }
##See specific ODC formats described in the Test Case On Demand Commands.
START_TRAFFIC = { StartAllTraffic RATE_UNUSED }
STOP_TRAFFIC = { StopAllTraffic RATE_UNUSED }
WAIT == { Wait }
ControlAttero { op=Connect hostip=HOST_IP ip=ATTERO_IP } ControlAttero { op=Start ip=ATTERO_IP profile=PROFILE } ControlAttero { op=Stop ip=ATTERO_IP profile=PROFILE } ControlAttero { op=Disconnect ip=ATTERO_IP }
LOOP_START = { LoopStart }
LOOP_END = { LoopEnd NUMBER_OF_LOOPS } |
You may open an existing command sequence template, save the listed command sequence as a template, add, remove, or re-order the steps by using the sequence control buttons on the Command Sequencer window and the Add menu.
You may select any row and use the tool bar or right-click on any step to access the Sequence menu. Select multiple contiguous sequence of Commands and move, remove or copy/insert where desired (Add, Before, After the current selection, or choose a location within the sequence of steps). This allows you to move entire blocks of steps up or down, or delete entire blocks. Inserts would occur either before or after the entire block or at a chosen step.
Open |
Open an existing/saved command sequence template. The Select Test Case Command Sequence window displays command sequence templates relevant to the Test Case type. Click the Test Case column to sort the displayed list.
|
||||||||||
Save | Allows you to save valid sequences as templates to a library. The Test Case column on the Save Dialog Command Sequence window identifies the test case to which the Command Sequences belong. When you save a TC Command Sequence Template the Save Dialog Command Sequence window displays all the templates in the library. | ||||||||||
Add |
Click Add to access the drop-down list or right-click to use the Sequence menu. Use to build a set of OnDemand Command Sequence and insert them at current position. |
||||||||||
Edit | To edit a step, select the step and click Edit or select Edit from the right-click menu. You may edit delay time, the OnDemand Command, and number of loops (in the End Loop step). | ||||||||||
Delete | To Delete a step, select the step and click Delete or select Remove from the right-click menu. | ||||||||||
Move Up | To move the sequence command one step higher in the list, select the step and click Move Up or select Move Up from the right-click menu. | ||||||||||
Move Down | To move the sequence command one step lower in the list, select the step and click Move Down or select Move Down from the right-click menu.
|
||||||||||
Set Graceful Stop |
Allows you to set the selected command as the first of the sequence to gracefully stop the test case.
Select the option from the Tool Bar or from the right-click menu option, Set Graceful Stop. Select a command to be the start of a graceful stop sequence, so that if you click Stop or force a test case to stop, the sequencer does not end abruptly, but instead executes the commands of the sequence to clean up resources.
Tcl Parameter: CommandSequenceStopIndex (You set it to index of the first command in the stop sequence) Range: 0 to Last Index, i.e., NumberOfCommands-1 The Set Graceful Stop command executes as follows when you stop the test case, depending on the test case state.
|
||||||||||
Disable Graceful Stop |
Clicking Disable Graceful Stop clears all the Set Graceful Stop sequence. Supports Graceful Stop within a loop. If first stop command is within a loop, when you stop the test case, the loop does not occur.
|
||||||||||
Auto-Stop | Select to automatically stop the test case when the sequence completes execution. | ||||||||||
Chart | You can chart Events per Second from the steps defined in the Command Sequencer window (also from Test Session window by clicking Mobility Events, which appears only if you have defined sequence of commands in the Command Sequencer window). | ||||||||||
Copy/Paste | Select one more rows in the sequence table, right-click and select Copy from the menu or press Control-C to copy the selected sequence items to the clipboard. Right-click and select Paste or Press Control-V to paste/insert within a sequence table of the same type of test case (for example, from one MME Nodal test case Sequence table to another MME Nodal test case Sequence table). | ||||||||||
Table Height | Select the height of the table displayed Max, Tall, Medium, Short. Depending on the height you select and the number of rows of commands you enter, a scroll bar appears to help scroll through the table rows. |
NOTE:
A command is complete/done when the Test Session has finished executing the action associated with the command, and NOT when the MNs are in the resultant state due to the action. A TS executing an On Demand Command (ODC) does not wait for each MN to reach the expected state before being done and ready to execute the next ODC. For example, an Attach ODC is done when all of the attach requests have been sent out, and not when all of the MNs are attached. You must include in (your) required Delay between commands to make sure they reach a certain State. In addition, if you require 15 second measurements to fully report, you need to make sure your commands are at least spaced 15 seconds apart. When you are in the On Demand Command (ODC) Tab, using the F2 key, will provide you with API Parameters and arguments for both Tcl and REST APIs. |
OnDemand (ODC) |
The Commands available in the OnDemand sequence has the same format as described in the Test Case On Demand Commands. See Sequencer and Execution of On Demand Commands section (above) for how the commands specified on the Sequencer Window works.
|
||
Delay |
Allows you to pause the command processing for the duration you specify. Double-click Delay and define the number seconds to wait/delay executing the next sequence of command. Click OK to commit the entry.
|
||
Wait |
Allows you to pause the step processing until you decide to click the Continue button to execute the next step. See the Wait section below. |
||
SyncPoint |
Use a SyncPoint to keep multiple test cases running Sequencer steps in sync with each other. All Test Cases that have SyncPoints defined with the same ID will wait at the shared SyncPoint until all test cases reach the SyncPoint.
In addition, you may also define unique SyncPoint labels to track a test case similar to a User Log. That is, the SyncPoint names/labels are sent to the Run Log to help you track and ensure that the test case has executed Sequencer steps and reached the Sync-Point ( RUNNING:3#3:Sync_ID, e.g. RUNNING:3#3:Sync_Test1).
|
||
Example SyncPoint Setup: If you wish to group many test cases together within a test session to wait at a sync point such that you send just one Continue command to one Test Case to have them all start again, set it upas follows: All of the test cases in the example above, stops at the SyncPoint Wait1, except TC0 will stop at the Wait. You can then send the ContinueSequencer to TC0 and all of the test cases will continue. |
|||
ControlAttero |
Support for adding Attero Commands. Four operations are supported :Connect, Start, Stop, Disconnect. Not available in Command mode, only Sequencer. ITEM = DELAY_ITEM | ODC_ITEM | START_TRAFFIC | WAIT | STOP_TRAFFIC | LOOP_START | LOOP_END
|
||
|
The LoopStart and LoopEnd allows you to enclose a sequence of test case commands in an iterative loop.
|
The Wait step allows you to pause the step processing until you decide to click the Continue button to execute the next step.
NOTE: If you have Wait as a step and when you run the test, the Sequencer reports a sub-state, and also a new panel with Pause, Resume or Continue buttons appears on the Session Builder tab. |
The TS will not allow you to Pause/Resume if the Sequencer is running the Wait step, that is in Waiting... state.
The Pause command does not immediately pause the step, it transitions to a Sequencer State of PAUSING, until the current command complete execution. Then reaches the PAUSED state, before executing the next command. You can resume a Sequencer when it is in either the PAUSING or PAUSED state.
When you Resume a sequence while the status is PAUSING, the next command step is executed. The following illustrates the steps executed in Pause/Resume command sequence: For example:
Pause a sequence, the sequencer state switches to PAUSING and continues to execute the current Command # (step) and increments the count #. |
RUNNING:1#1 user paused RUNNING:1#2:PAUSING (still executes 1 ) user resumed RUNNING:1#3 |
State changes to PAUSED, the Command # (step)and count # increments | user paused RUNNING:1#4:PAUSING (still executes 1) RUNNING:2#5:PAUSED (paused waiting to run 2) |
Resume a paused sequencer, it maintains the Command #, increments Command Count. | user resumed RUNNING:2#6 (executing 2) |
NOTE: The Command Counter increments twice when you Pause and Resume a test, 1 count for the Pause, and 1 count for the Resume. (see Tcl API exampleTcl API example). Example Tcl API Wait/Continue, Pause/Resume:
(The CONTINUE command, the WAIT/CONTINUE is counted as one defined command)
|