State & Transition
There are 2 important terminologies we have to know before take a look at workflow:
Place, is a particular condition that your system under test is in at a specific time. If your system under test is a website, we can define each page as a
place. For example, home page is a
place, profile page is a
Transition, is the process or a period of changing from one state (or
place) to another. Similar to above, let take a look at a website. A transition can be an action of clicking a button, click on a link, or type a text box.
What is workflow
Workflow is just a combination of states and conditions in order to describe a business logic. Depend on the type, a
workflow can be used to describe simple or very complex logic.
There are 2 types of workflow: workflow & state machine.
- State machine: the system under test cannot be in more than one place simultaneously.
- Workflow: the system under test can be in more than one places simultaneously.
If the system under test is a website, we can define a workflow with type
state machine with places are pages, and transitions are actions (click button, fill text box). We can't simply at 2 pages (e.g. home page and profile page) at the same time.
Still a website, but this time we will create a workflow for a contact form with 4 fields: name, email, subject and message. At the same time, we can have more than 1 field is filled. For example, we can fill name and email because they are required, but leave subject and message empty because they are not required. That workflow will have type
Back to the examples we started early. mobile_home is an example of a workflow with type
In this image, there are only arrows and circles. Arrows (with name) are transitions, and circles are places.
checkout is an example of a workflow with type
In this image, there are arrows, circles and squares. We can ignore arrows. Squares are transitions, and circles are places.
To summarize, let take a look at this table:
|Can be in more than one places simultaneously||Yes||No|
|Image||Arrows, circles and squares||Arrows and circles|