What is the Testing process you follow in your project?
#Q 1) What is the Process for Creating a Test Script?
Answer:
Step 1: is to get a thorough understanding of the AUT:
This could be by reading the requirement documents thoroughly.
In the absence of docs, we could try to understand any point of reference that we
have – a previous version of the application or wire-frames or screenshots
Step 2: After understanding the requirements, we make a list of what are the areas in
this application that will have to be tested. In other words, we identify the test
requirements. The focus in this step is to identify “What” to test. The outcome of this step
is a list of Test Scenarios.
Step 3: Once we have the test scenarios, we concentrate next on “How” to test them.
This phase involves writing detailed steps about how to test a particular feature, what
data to enter (Test Data) and what is the expected result.
Once these 3 steps are done, we are ready for testing.
#Q 2) What are the fields in a Bug Report?
Answer: Following important fields should be included in a good Bug Report:
1. A unique ID
2. Defect Description: a short describing what the bug is.
3. Steps to Reproduce: details about how to arrive at the error, exact test data, the
time at which defect was found(if applicable) environment: any information that
will help re-encounter the issue
4. Module/section of the application (if applicable)
5. Severity
6. Screenshot
7. Responsible QA: in case of any follow-up questions regarding this issue
#Q 3) How to test a customer-facing software?
Answer: With any application that we test, we are trying to see if a certain set of
requirements are met by the application or not. But when it comes to a user-facing site,
apart from concentrating on functionality, we also have to look into a few usability
features, maybe performance and security aspects also to a certain extent.
The first level of testing is: Does the site satisfy its functional requirements.
For Example, if it is a loan management site, we need to look at – are the new customer
able to apply for a loan, are the existing customer able to access their loan info, is the
interest % applied to the loan amount correct, etc.
The next level of testing is: how easy is it to use the site, do the options make a logical
sense and meet the expectations of the user or not.
For Example, if the user has to be pass 3-4 screens to submit the basic information they
are going to be annoyed, so such issues have to be addressed.
Another example, after entering username and password, the user might click on the
tab- which means the control should go to “Sign in” button, instead if it’s going to cancel,
the user is going to be really annoyed and the experience of using the site is going to be
compromised. Such issues have to be caught.
Performance Testing to the complete extent might not be in scope but simple situations
like, how long does the search results take to be displayed and how much time does it
take for the system to retrieve a customer info at the peak hour – these are some
example of the kind of things we would want to keep an eye on.
Security – for sites where there is a secure login to access the site, the minimum
functionality around it has to be tested. For Example, if I leave the site idle for more than
10 minutes, is it auto logging out or not. Something as basic as that should be focused
on.
#Q 4) How to overcome the challenge of not having input documentation for
testing?
Answer: IF the detailed standard documentation like BRD and FSD are unavailable, the
tester will have to depend on some point of reference.
Screenshots
A previous version of the application
Wireframes, etc
Another factor that helps immensely, is to talk to the developers or the business analysts
(when available) to get a confirmation on our understanding or clarifications in case of
doubts.
When none of these situations works, we can just conceptualize the application based
on our previous IT application experience and create the basic set of test scripts. When
the testing phase comes up, we can set up a portion of test cycle time and do some test
case management (make the already created scripts perfect) so we have the doc for the
next phases.
#Q 5) How to get maximum productivity from an offshore team?
Answer: The key is to make sure that all the testers know about all the modules and
that there is no knowledge concentration in one place. Involving everyone in test script
peer reviews, defect meetings, and KT sessions are going to ensure that everyone is
aware of the application to the best extent possible.
Also, by encouraging the concept of teamwork we can have the team members
collaborate, help and aid each other for better productivity.
Regular follow up meetings also help the process very much.
#Q 6) What are the Roles and Responsibilities of an onsite coordinator? Does
he/she test too?
Answer: The onsite coordinator is a point of contact for the offshore team and to the
client for any information regarding the testing engagement.
This job includes:
KT from and to offshore and clients
Getting the environment to test all ready
Sanity testing, smoke testing
Testing – the key functionality.
Bug review – found by the offshore team
Bug assigning to the respective dev
Presenting metrics
Providing sign off
Yes, even an onsite coordinator has to test.
#Q 7) Inconsistent bugs- Why onsite can find it, but offshore can’t and vice versa
– How to handle this situation?
Answer: Every bug has to be noted and analyzed – whether it is encountered at onsite
or offshore, whether repeatable or not. A real value-add to a tester’s job is when we
involve ourselves in the Root Cause Analysis process for a bug rather than simply
reporting it.
Some of the ways we can handle this situation are:
All the onsite and offshore team members should follow a guideline that
screenshots had to be taken for every error that we encounter – repeatable or
not.
If there are logs, system files or anything like that, that might help us find any
evidence of the issue- we should try to find it.
Despite all these steps, if we still can’t tell why and when the problem occurs- we
should report it to the developer all the same – with as much information as we
can.
#Q 8) Video/audio related testing – What does this include?
Answer: How to test an application having video or audio?
Here are the important points to consider:
Access levels (restricted or not – password controlled)
Different kinds of environments
Browser compatibility
Screen resolutions
Internet connection speeds
The specific options on a video – like play, stop, mute, etc.
Video by size
Response to the videos – comments (limitations on the comment length and
number of comments it can take)
Video responses to the videos
Interface with social networking sites – Interoperability
Buffering speed
Embedding the video
#Q 9) Mobile Application Testing – What does it include briefly?
Answer: Mobile App Testing Important Test Scenarios:
Check if the app works well with multiple carriers and multiple devices.
Usability of the features on a mobile screen.
Testing it on different mobile platforms – like Android and iOS.
Installations, uninstalling, launching the app with network and without a network,
testing functionality.
Network connections –WiFi, 2G, etc.
Logs at iOS iPhone configuration utility for Android Monitor.bat can be used for
debugging.
That was it. Now, it wasn’t that simple.
In an application currently in production, one module of code is being modified. Is
it necessary to re-test the whole application or is it enough to just test
functionality associated with that module?
What is the most challenging situation you have faced during testing?
What are you going to do if there is no Functional Spec or any documents related
to the system and developer who wrote the code does not work in the company
anymore, but you have a system and need to test?
How to handle a situation when you don’t have time for complete testing?
How you performed as a troubleshooter in your last job? Any event you
remember?
How to improve skills designing test cases and make sure a high coverage rate?
What is "use case testing"?
In order to identify and execute the functional requirement of an application
from start to finish "use case" is used and the techniques used to do this is
known as "Use Case Testing."
Explain what Test Deliverables is?
What all things you should consider before selecting automation
tools for the AUT?
On what basis you can arrive at an estimation for your project?
Explain in a testing project what testing activities would you
automate?
In testing project testing activities, you would automate are
Tests that need to be run for every build of the application
Tests that use multiple data for the same set of actions
Identical tests that need to be executed using different browsers
Mission critical pages
A transaction with pages that do not change in a short time