Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
tutorial:sequencers [2020/07/15 03:40]
admin [Sequencer - Pairwise]
tutorial:sequencers [2020/07/16 16:12]
admin removed
Line 11: Line 11:
   * [[#Sequencer - Mark Serial]]   * [[#Sequencer - Mark Serial]]
   * [[#Sequencer - MCase]]   * [[#Sequencer - MCase]]
-  * [[#Dynamic MCase]] 
   * [[#Sequencer - Concurrent]]   * [[#Sequencer - Concurrent]]
   * [[#Combinatorial Algorithms]]   * [[#Combinatorial Algorithms]]
Line 74: Line 73:
 //Pairwise// sequencer offers more extensive model coverage than most of the sequencers ([[#Sequencer - Optimal | Optimal]] and [[#Sequencer - Priority | Priority]], and others) with a deterministic test sequence.  //Pairwise// sequencer offers more extensive model coverage than most of the sequencers ([[#Sequencer - Optimal | Optimal]] and [[#Sequencer - Priority | Priority]], and others) with a deterministic test sequence. 
 =====Sequencer - Mark Optimal===== =====Sequencer - Mark Optimal=====
 +Often times you may want to only test certain part of the model.  //Mark Optimal// sequencer (and [[#Sequencer - Mark Serial| Mark Serial]]) generates test cases to cover the marked transitions.
  
 +//Mark Optimal// sequencer generates the test cases using the same [https://en.wikipedia.org/wiki/Route_inspection_problem | Route inspection problem (aka Chinese Postman Problem)]] as [[#Sequencer - Optimal | Optimal]] sequencer except that only the marked transitions are required to be covered.
 +
 +//Mark Optimal// sequencer (and [[#Sequencer - Mark Serial| Mark Serial]]) can be used for [[https://en.wikipedia.org/wiki/Exploratory_testing | Exploratory Testing]], e.g. testing a new user stories just added to the model.
 +
 +//Mark Optimal// sequencer is only available when running model in IDE.
 =====Sequencer - Mark Serial===== =====Sequencer - Mark Serial=====
 +//Mark Serial// sequencer is similar to [[#Sequencer - Mark Optimal]], it generates test cases to cover the marked transitions in the model.
 +
 +What distinguishes //Mark Serial// sequencer from //Mark Optimal// sequencer is that the test cases generates follows the order the transitions are marked.  As the result, the test sequence generated by //Mark Serial// sequencer is usually longer.
 +
 +//Mark Serlia// sequencer (and [[#Sequencer - Mark Optimal| Mark Optimal]]) can be used for [[https://en.wikipedia.org/wiki/Exploratory_testing | Exploratory Testing]], e.g. testing a new user stories just added to the model.
 +
 +//Mark Serial// sequencer allows you to test scenarios that require traversing transitions in a specific order.
 +
 +
 +//Mark Optimal// sequencer is only available when running model in IDE.
  
 =====Sequencer - MCase===== =====Sequencer - MCase=====
 +//MCase// is a collection of transitions that represents a custom test case.  //MCase// sequencer generates the actual test sequence (test steps) to navigate through the model to cover the transitions included in the //MCase//.
 +
 +
 +The main use of //MCase// sequencer is to generate custom test cases, which can be used to test a bug fix, regression testing of important workflows and smoke testing.
 +
 +Since //MCase// is built with scripting, you can dynamically build any number of //MCases// through //REST// api.  This provides an option to allow ALM process to test bug fixes remotely.
  
-=====Dynamic MCase===== 
  
 =====Sequencer - Concurrent===== =====Sequencer - Concurrent=====
 +//Concurrent// sequencer is the only sequencer that supports concurrent system models.  //Concurrent// models allows simultaneous firing of multiple transitions from the state and it's used to simulate processing of event-driven system or concurrent systems.
 +
 +===== Combinatorial Algorithms =====
 +In the ideal world we would want exhausted testing, but we all know that's not practical and in many cases not feasible.
 +
 +//Combinatorial Algorithms// are used to generate test cases for //Combinatorial Data// models. //TestOptimal// supports following combinatorial algorithms:
 +
 +  * pairwise
 +  * 3-wise
 +  * 4-wise
 +  * 5-wise
 +  * 6-wise
 +
 +
 +Pairwise algorithm geneartes the least number of test cases (permutations of variables) while 6-wise generates the most test cases but provides most coverage among the algorithm listed above.
 +
 +Empirically most of defects are caused by the interaction between two variables, hence pairwise algorithm would provide decent coverage with least amount of test cases for most of the system.  This is commonly used especially for larger models as it could potentially cut down the test cases by 99%.
 +
 +
 +
 +