Test Automation: Handling your first Exception!

Test Automation: Handling your first Exception!

Test Automation is an important sub-area from the Software Quality Control field, and a must-have to evolve from being a traditional manual tester into a generalizing expert Software Development Engineer in Test (SDET).

It is a common practice to break into the Test Automation domain via a Selenium WebDriver course/tutorial/playlist. And it is common to find many Test Specialists with little or no development background transitioning into test automation that way, which makes it difficult for them to "improvise, adapt, and overcome" any challenges that are not directly covered in the content of the material that they are following.

The simple fact is that if you choose to write code to fulfill your test automation needs, then you need to learn some coding fundamentals. The most important of which is understanding exceptions, troubleshooting, Googling, and searching stack overflow for the most suitable answer.

The efficiency of that search is one of the main telltale signs of experience, and the first step is to define the problem at hand by learning how to understand and analyze an exception.

Sample Case:

This is probably among the first exceptions you'll face when you're learning about Selenium WebDriver.

You just wrote your first lines of code

No alt text provided for this image

And you happily execute and you're expecting to see the browser open up and your first automated test to succeed.

Instead you find that the test had failed. This is where you should feel more curious than discouraged.

No alt text provided for this image
Know that with Test Automation there will always be new exceptions and challenges.

Now you start to investigate... So you copy the error message and start to Google it.

No alt text provided for this image
java.lang.IllegalStateException: The path to the driver executable must be set by the webdriver.chrome.driver system property; for more information, see https://github.com/SeleniumHQ/selenium/wiki/ChromeDriver. The latest version can be downloaded from https://chromedriver.storage.googleapis.com/index.html

Your search should lead you to understand that you need to download the driver executable that is compatible with your browser version and operating system. And then add this line of code so that Selenium WebDriver can connect to your browser and manipulate it.

No alt text provided for this image

Here you should ask yourself, where exactly does that line of code go? And that's where understanding the stack trace becomes useful

No alt text provided for this image

In the above screenshot there are three components.

  1. Exception name: java.lang.IllegalStateException
  2. Exception message: The path to the driver executable must be set by the webdriver.chrome.driver system property; for more information, see https://github.com/SeleniumHQ/selenium/wiki/ChromeDriver. The latest version can be downloaded from https://chromedriver.storage.googleapis.com/index.html
  3. Exception Stack trace: This represents the steps that the exception took to bubble up, and this is especially helpful to understand where the exception happened. And in most cases where the exception message is missing or non-descriptive this is the only way to start investigating how to solve the problem.

Initially the stack trace may be overwhelming for someone who didn't write any code before. But the trick it to *for starters* ignore everything that you didn't write yourself.

You only wrote one method (f) inside one class (NewTest2.java) which is inside a package called (seleniumDemoPackage)... So you can ignore all the other lines at the moment, and zoom in on this one

No alt text provided for this image

This tells you that the exception happened in line 12 of this class

No alt text provided for this image

By examining this line you should understand that the problem happened when you tried to initialize a new ChromeDriver without setting the path to the driver executable... and hence the proper fix would be to add the line that you found on stack overflow before line 12.

No alt text provided for this image

After downloading the correct executable file, using the line we got from stack overflow, updating the path to point to the executable file, and placing the line in the correct location. We can see that the exception is resolved and the test is passed.

No alt text provided for this image

Congratulations on handling your first exception! Keep up the good work! And do not be discouraged!!!

Ahmed Gawad

SDET Team Lead | ISTQB ?? (CTFL | CTFL-AT)

3 年

Very insightful and organized.,As this article is well organized it's still a valid reference on handling exceptions.

要查看或添加评论,请登录

社区洞察