In the last piece, we looked at the benefits I've seen at other companies using strict encapsulation at the page level. But in my current gig, we take it a step farther. We have another layer between tests and pages called flows. A flow interacts with one or more page objects.
This means that pages are the workers, they know how to do specific pieces of work.
Flows are the managers, they line up which workers and in what order. Flows are also a series of interactions the user will take to perform some action. They model the end user's interaction with the system.
The tests are the executives that decide which flows to call to test a specific underlying feature or group of features.
In practice, this looks like a lot of unnecessary complexity, especially for test cases who's flows are one line long. But it also further isolates the test from the changes in the UI.
We've had large scale redesigns that mostly take page object updates. Sometimes flows need to be updated. But the underlying functionality hasn't really changed.
This means tests are updated more quickly, and so the automation can do more for less effort.
It also means we can write automated tests and flows before we have page mockups, as long as we have detailed enough specs. We can add the page objects as they become available.
Woo hoo!
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment