So in part 2 I'm introducing the chaining of pages, this is all about how one object (page) seamlessly hands responsibility to another page. By now you need to almost think of pages and objects as one and the same.
One of the biggest problems in any GUI type testing is that often you need to visit a few different dialogues in an app to set up initial system state. Even before you can run your actual test check. Something that is a few steps or pages and becomes a mini-test in itself, or in unit testing parlance a "fixture".
Please be sure to read part 1 first where I talk about the simple problem, driving web pages or dialogs as objects in your Python script with helpers that make all of the fields in pages. Dynamic variables in the object (Page) that correspond to each field on the page lets you simply get or set in order to populate form fields or click on buttons.
Part 2 chaining pages together.
This is exactly the same functionality as all the objects in main.py, but this time they support chaining together as well. Here you see this in Action, we have
- a login page for a username
- another page for the password
- the main app page
- a profile page (with only one button, logout)
@next_page("DemoProfilePageV2") def login_to_profile(self, username, password): """ Does the whole shebang in one go - show how to make sure we always return the object the decorator says we should do. :param username: The user name :param password: The password :return: the profile page """ return self.next(username).next(password).next()
def next(self): raise NotImplemented("Must be implemented to return the Chained PageObject!")
[WDM] - Current google-chrome version is 86.0.4240 [WDM] - Get LATEST driver version for 86.0.4240 [WDM] - Driver [C:\Users\cb\.wdm\drivers\chromedriver\win32\86.0.4240.22\chromedriver.exe] found in cache [16:13:17][POM] pre_navigate:http://localhost:8080/loginuser.html [16:13:17][POM] __setattr__ editUserName = 'user' [16:13:17][POM] __getattr__ btnContinue [16:13:18][POM] __setattr__ editPassword = 'pass' [16:13:19][POM] __getattr__ btnLogin [16:13:20][POM] __getattr__ btnProfile [16:13:20][POM] __getattr__ btnLogout [16:13:21][PB] teardown: quit chromedriver
[WDM] is the webdriver Manager which keeps chromedriver up to date
[POM] is page object model base class
[PB] is the test fixture class
Probably in a real implementation, you might want to not print passwords, even test passwords. So any values that perhaps match "pass" or "password", you replace with ****. I'll leave that up to you the reader to add.
Comments
Post a Comment