We use multiple applications on a daily basis. The internet is a part of our life.
Behind every application, whether shopping, learning, ticket booking etc there are multiple people whose contribution has made our life so comfortable through these applications.
Among these multiple technical people are “Testers” and “Developers”.
In this article, we will see the different perspectives of Testers and Developers and their relationship to make a successful application together.
The aim of testers and developers is the same i.e. to provide a quality product to the stakeholders. But their way of thinking is different.
It is rightly said, “Testers and Developers are not different but they follow a different path to achieve the same goal”.
Developers think: ‘How can I make the application?’
Testers think: ‘How can I break the application?’
Testers and Developers act like Tom and Jerry. But the end result is positive only when they both work together.
By saying ‘How can I break the application’ it does not mean that a tester’s motto is to spoil the work done by developers. It means that the testers by their out-of-box thinking and by placing themselves in the customer’s shoes, apply all possible scenarios on the application. This is done so that the application does not break when it is in the live environment.
For any software application development, Software Development life Cycle (SDLC) plays an important role. Earlier, software testing was done at the last stage of development. But repairing the errors/bugs at the last stage proved to be very difficult and expensive.
So, to avoid such complexities, now, software testing is a part of every phase of SDLC. This means testing starts from the very first phase of development.
“Testers” look at an application from a different creative perspective and if the requirements of the end-users are clearly understood, it makes a lot of difference.
What You Will Learn:
Let us see and get a brief idea of tester’s perspective at different phases of SDLC:
#1) Requirement gathering and Analysis:
In this phase as per the requirement of the stakeholder and by accumulating suitable necessities of the application a requirement document is prepared.
Requirement document is shared with the testing team to have their view on the proposed requirement as well as send their queries in the form of ‘Review comment’. The queries could be anything, be it the understanding of any particular section or prediction of some future possibilities of errors.
Let us take a very common example: Requirement of the end-user is “No special character is allowed in Input field “.
Developer’s role: Clearly, write a code for inserting an Input field by keeping a check that when a user enters any special character, an error is thrown or proper error message is displayed.
Tester’s perspective: Tester will first check the stated requirement but then he will have multiple scenarios in mind. He will have questions like:
- What if only special characters are included in the input box? Will it display the same or a different message to the user?
- What if the user copies and pastes any combination of special characters and alphanumeric characters into the input box?
There are many other such scenarios which testers think of while reviewing Requirement document.
For evaluating any product or application, testing means questioning a product in order to cover almost every scenario because an end-user could be anyone and can use the application in any manner that they want to.
#2) System/Application design:
After collecting the data and after finalization of requirements, the Developers start their designing on the application. This includes a review of the design documents before implementation by the developers.
Testers from their understanding and creative thinking analyse all the possible scenarios for all new features, enhancements, integrations, UI update, anything mentioned in the requirement. They create test cases, sanity check lists and data so that when the application comes for testing, they are ready with their testing parameters.
#3) Implementation phase:
In this phase, developers actually implement the finalized system design.
When we see from the developer’s perspective, they are focused on building functionality that is the requirement. In their view, functionality will work perfectly and efficiently.
But when we see from tester’s perspective, it is the exact opposite of a developer’s. When developers focus on implementing the functionality, testers apply all of their creativity to test the functionality. There also might be a case when developers misunderstood the requirement and in that case when testers apply their scenarios, there will be a failure in the application.
#4) System Testing:
In this phase, developers upload the application to staging/QA environment (environment that is available for testers to test) with defined set of functionalities that have been implemented by the developer in that particular sprint/release.
Developers upload the application with a notion that the functionality implemented is developed perfect as per the requirements specified; they are just giving application to the testers to re-verify.
But for testers, other than the desired functionality there are many other different ways an end-user can think to use a particular application. It is the task of the testers to use their creative thinking and explore each and every possible scenario.
#5) Maintenance phase:
This phase is to check the combined effort of Testers and developers.
The final application after all implementation is sent to the user to use it live. If it is working as desired then there is no problem. But if there is any deviation, it again requires the combined effort of both testers and developers in the maintenance phase.
Testers and Developers together make an effective team as it is the responsibility of both to ensure the best product. This is achieved if both work hand in hand with proper understanding and taking feedback positively.
Let us see some important points that define the role of Testers and Developers:
- While the developers should ensure that there are no bugs in what they develop, the Testers should make sure that if there are bugs, those should be reported and get fixed at the correct time.
- A developer should take the feedback from tester in a positive and constructive manner.
- It is imperative to say that developers are ‘specialists’ in a particular technical area and they could use all their technical skills to develop a project as per the requirement. Testers are the third-party (assume a virtual user for the application) that report errors or bugs in an effective manner based on which the application’s Quality can be determined and areas for improvement identified.
Working as a Tester:
There are of course, many good developers who can test well. The important point is being a human we can’t test our things/ application on our own, and we do require a second person opinion and feedback.
“Tester” is the person who is not influenced by the application developed and he gives his own judgements based on practical hands-on experience from using the application with all possible scenarios.
A Good Tester knows that a user makes numerous errors while learning and using a new product. Real-time users like to learn using a new product by trying and seeing what happens rather than reading a manual.
So, the main focus of the Tester is “What can go wrong”. The main focus of the Developer is to deliver the project as per the requirement.
Recommended read => Why Do You Like Testing?
A Good Tester and A Good Developer:
A Good Tester is one who is comfortable with conflicts. Many times it becomes very hard to pinpoint the source of the bug i.e. it may be a coding bug, documentation bug, design bug or may not be a bug even. But it’s the job of the tester to report every bug.
A Good Developer is one who takes feedback in a positive & constructive manner, diagnoses the problem, and debugs it. But developers often avoid conflicts and that causes hindrance.
Further good read => Who Earns More, Software Tester Or Developer?
Conclusion:
So, I conclude my article by saying that, appreciating differences is critical for productive teams but different approaches aid in finding solutions, and lead to delivering a product that works at its best.
Everyone is doing their own task. Developers are there to develop an application. Testers are there to test an application.
Through this article, I have one more point to add “If we need to make Project/ Application the best, we need a critic with us who can give reliable feedback”.
About the author: This is a guest post by Sushma S. She is working as a Senior Software Test Engineer in a MNC.
Do you agree with me? Let me know your thoughts by adding comments below.
GOOD INFORMATION ALWAYS GIVEN BY SOFTWARE TESTING HELP………
thanks.
There will be always cold war between testers and developers 🙂
Nice Article…
Yah. It is a nice talk about the role of testing engineer differing from a developer.
It is real fun when your app is live and then comes a bug….
@Prasant But when bug is being encountered and reported by end user after app is live, that means it has been somehow missed by developers and testers.
Perfect
Superb article Sushma. Many real facts has been mentioned.
Great Article Sushma. Thanks so much.
nice Article.
Superb Article
Ya, of course, You are right.Every time I used to argue with developers to prove my bug is a valid one.At last, sometimes I will win or loss.Anything may happen I won’t stop finding Bugs.
very good article,clearly explained the testers and developers thinking, thank you for this.
Nice Artical.
@All Thank you for all of your reviews. It always feel good to hear reviews from the readers.
Well said about the perspective with which a developer and a tester thinks . especially the Tom n Jerry comparison 🙂
Great Article.
Nice one.
Nice