Stopping at the Simplest Implementation of POM
I don't love the Page-Object Model (POM). Actually, I just don't love the way many teams implement it. When they stop at giving their page elements locators, they end up with elements that look likeReusing Page Objects in Other Page Objects
It's these last few that get me. Any time I see redundant code it makes me cringe. Let's level-up:This can probably only be achieved if you've wrapped your Selenium tool's WebElement and WebDriver class. Hopefully you did this. It will take a little cleverness and adding some constructors, but it should be doable.
Dynamic Elements Using Methods, Not Variables
I find myself kicking the can down the road, or pushing the work down to a lower level like this all the time. "Make someone else do the work" I say. If I'm in the middle of writing a method and I think for one second that what I'm about to write could be used somewhere else, I try to encapsulate that work in a method. Better yet, I imagine what I'd pass into that method, what it would return to me, and continue writing my current method as if that helper method exists and keep going. Later on I'll write the helper methods into existence.In this case, while we're writing createAndViewOrder(), we don't want to worry about how we find the orderConfirmation element, we just want to assume it works and use it, so let's move it out of the method. Before:
After:
Does this buy you a lot right now? Not really. But
- it might buy you something down the road during a refactor
- it makes your functional method easier to read
- it literally takes 15 extra seconds
No comments:
Post a Comment