As software testers and automation engineers, we often think about the "Happy Path"- the path that the user will most likely take when they are using our application. When we write our automated UI tests, we want to make sure that we are automating those Happy Paths, and when we write API automation, we want to verify that every endpoint returns a "200 OK" or similar successful response.
But it's important to think about negative testing, in both our manual and automated tests. Here are a few reasons why:
Our automated tests might be passing for the wrong reasons.
Negative testing can expose improperly handled errors that could impact a user.
In API testing, any client-related error should result in a 400-level response, rather than a 500-level server error. If you are doing negative testing and you discover that a 403 response is now coming back as a 500, this could mean that the code is no longer handling that use case properly. A 500 response from the server could keep the user from getting the appropriate information they need for fixing their error, or at worst, it could crash the application.
Negative testing can find security holes.
Just as important as making sure that a user can log in to an application is making sure that a user can't log into an application when they aren't supposed to. If you only run a login test with a valid username and password, you are missing this crucial area! I have seen a situation where a user could log in with anything as the password, a situation where a user could log in with a blank password, and a situation where if both the username and password were wrong the user could log in.
It's also crucial to verify that certain users don't have access to parts of an application. Having a carefully tested and functional Admin page won't mean much if it turns out that any random user can get to it.
Negative testing keeps your database clean.
As I mentioned in my post two weeks ago on input validation, having good, valid data in your database will help keep your application healthy. Data that doesn't conform to expectations can cause web pages to crash or fail to load, or cause information to be displayed incorrectly. The more negative testing you can do on your inputs, the more you can ensure that you will only have good data.
For every input field I am responsible for testing, I like to know exactly which characters are allowed. Then I can run a whole host of negative tests to make sure that entries with the forbidden characters are refused.
Sometimes users take the negative path.
It is so easy, especially with a new feature that is being rushed to meet a deadline, to forget to test those user paths where they will hit the "Cancel" or "Delete" button. But users do this all the time; just think about times where you have thought about making an online purchase and then changed your mind and removed an item from your cart. Imagine your frustration if you weren't able to remove something from your cart, or if a "Cancel" button didn't clear out a form to allow you to start again. User experience in this area is just as crucial as the Happy Path.
Software testing is about looking for unexpected behaviors, so that we find them before a user does. When negative testing is combined with Happy Path testing, we can ensure that our users will have no unpleasant surprises.
I don't generally editorialize in my blog- I prefer to focus on what to test rather than theories of testing- but I feel compelled to sa...
This week I'm writing about three things not often associated with testing: logging, monitoring, and alerting. Perhaps you've taken...
There are a great many articles, blog posts, and presentations that discuss automation frameworks and strategies. But even the most robust ...
Anyone who has spent time working on test automation has likely heard of the Test Automation Pyramid. The pyramid is typically made of thre...