If a carpenter wants to build a cabinet, then he collects base materials (wood, nails, paint), opens his toolbox, and starts working. He may use a hammer, a saw, a drill, a screwdriver, a measure stick, painting brush, etc.
Let's attempt to write the steps of the use case to build a cabinet:
- Get the base materials
- Use tools to make wooden parts
- Put the parts together
- Paint the cabinet
Not correct: the steps are not necessarily done in this sequence - the carpenter could paint the wood before putting the parts together. (BTW: As a scenario it would be OK.)
- Get materials
- Use tools
Not correct. The carpenter could get some material, start working with his tools, then collect some more materials.
- Make cabinet.
Correct. This is a correct use case, but it is not very useful...
Why is this so? All actions performed with the tools from the toolbox may or may not occur, and in any given sequence, repeatedly or not. This I call the toolbox pattern.