Friday, October 11, 2013

Mobile Application Testing Interview Questions

Note: These questions were asked to me by someone to answer,so it might be these questions might appear on some other blogs but answers are purely mine.

1. How to sign the Android Build (APK)? 
Using IDE like eclipse when you create a debug build the build is by default signed using the key generated by the keytool utility present in JDK.

In release build you sign by your private key using these steps (presuming that you already have a private key to sign your application if not you can go through this URl for more info http://docs.oracle.com/javase/6/docs/technotes/tools/windows/keytool.html):
a)open your project in eclipse
b)Press right click on mouse and then click on export  then click on Android
c)Then click on Export Android Application then click on next button
d)Select the name of Project (What is of your application) then click on next
e)Select Use existing Keystore and browse the path of your private keystore
f)Enter Password of keystore in required field and click on next
g)Select Use existing Key and provide password and click on next
h)Now click on finish 

2. Which are the different Internet protocols? 
TCP - Transmission Control Protocol : TCP is used for transmission of data from an application to the network. TCP is responsible for breaking data down into IP packets before they are sent, and for assembling the packets when they arrive.
IP - Internet Protocol:  IP supports unique addressing for computers on a network. Data on an Internet Protocol network is organized into packets. Each IP packet includes both a header (that specifies source, destination, and other information about the data) and the message data itself.

3.Have you ever done Security Testing on Mobile Devices/Apps? What kind of Security have you performed for Android & iOS
You have to check and test unlock  patterns, passwords, by creating multiple profiles if you phone supports it.
For App you have to check App permissions, Need to test the data encryption if supported in OS or not. You should verify is data leaking to log files, or out through notifications& also server side control.
For mobile websites use tools like SQL Inject Me, XXS Me, WebScarab. A web proxy can also be used to intercept all mobile device traffic to monitor data and test for security issues.


4. How do you Find the UDID of the iOS devices ? 
• Connect the Device to iTunes 
• Click on Device name present on left side of Panel 
• Click on Summary (It shows device summary) 
• Click on Serial number  
• It shows you the 40 digit hexadecimal number

Use of UDID: It is basically used for Device Provisioning.

For QA you have to just copy and paste it using Edit button of iTunes and provide this number to developer so that they can add it to provisioning file which came along with testing builds.


5. What are the different types of IP’s ? 
1) Static IP address : It is that IP which is unique for one customer and he will always get same  IP address
2) Dynamic IP address: Its is that IP that whenever you connect to internet you get a new IP for your machine.
Also we can classify IP’s into:  
Global IP addresses : These are unique and cannot be shared by two or more computers. 
Private LAN IP addresses: As name suggest they are for private LAN network and they cannot be directly connected accessed from global Internet.

6. How do you assign IP’s to android Devices? 
I am providing steps for assigning static IP for as you need not to assign any IP which Dynamically they are assigned.
Steps are:
1. Click "Settings.
2. Click "WIFI."
3. Connect any WIFI
4. Tap and hold on your WIFI network
5. Tap on Modify Network
6. Select or check the Show Advance Options
7. Dismiss the keyboard using back button
8. Tap on IP settings(DHCP) and select static 
9. Enter new IP settings as you want

7. What is the latest version of iOS ? iOS 7.0.2(At the time of writing this blog)

8. What is the latest version of Android OS? 4.3(Jelly Bean)(At the time of writing this blog)

9. List down the Mobile Test Automation Tools? 

Popular Open Source Tools:
a)  MonkeyTalk  for Android, iphone 
b)  Robotium  for Android
c)  Selenium for iOS & Android
d) Appium for iOS & Android
e) Frank for iOS
f) Calabash for iOS & Android

Paid Tools :
a) Device Anywhere
b) SeeTest
c) PerfectoMobile
d) ZapFix 

10.What is your approach while Testing ?
Following Test Strategy can be followed while testing Mobile Application:
• First and foremost point is application installation on device , the application installation testing that application should be easily and completely installed on device.
• Then comes the smoke or sanity testing, do basic verification of application whether it is testable or not, if no then file a bug or suspend the testing effort.
• Then do the functionality testing of Application, whether it is meeting the functional requirement or not.
• Then verify the GUI of application.
• After this much is done you have to take care of the
• Performance of application, i.e. how much time application screens are taking in responding to user action for static applications.
• Network testing i.e., using application on EDGE, WIFI, 3G or 4G networks, Airplane modes and observe the behavior of application as some applications crashes on low networks.
• Testing call feature from application (if application has that feature) with and without SIM card installed in it.
• As now a day’s most of the devices are coming with touch screens so you have to take care to multi touch using more than one finger, tap & hold on screen and just a small touch etc.
• Open all the native application if device is multi tasking then observe the response/behavior of application under test.
• Do orientation multiple times if application support orientations. 
• Then check the uninstallation Testing of application i.e., all the components of application should get removed from device when user uninstall it   

After these things are done you have to take care of various other scenarios like 
• Interruption in the process of installation and at various other place of request/receiving from server etc by receiving call/SMS etc ,low battery indicator, Alarm/Calendar event indicators .
• Application specific testing scenarios depend on which type of application you are testing.
• Check the compatibility of application on different hardware’s which includes different screen size/resolution on real devices like iPhone platform check on iPhone/iPod touch and on iPad which are running on different or same iOS or on different manufacturer devices of same /other device OS like Android or Windows phones or on different emulators as emulators always do not provide complete support to all kind of application.
• Do some destructive testing like passing large input at different places or by doing something which is not expected.
• Security Testing which also depends upon application to application, basic application like password encryption etc
• Retesting and regression testing are continuous part of any kind of testing


11. Which is the prominent feature introduced in iOS 7 which are very important?  
Control Center, AirDrop for iOS, and smarter multitasking

12. Which are the prominent feature introduced in iOS 6? 
New privacy settings, Google Maps & YouTube removed, New Maps introduced, Intelligent Siri, Facebook comes integrated , Passbook app.

13. Which is the prominent feature introduced in iOS 8 which are very important? 
AirDrop between mac, iPhone & iPad, Health and HealthKit, Interactive notifications, iCloud Drive, Customized Keyboard and HomeKit

14. Which is the prominent feature introduced in Android L a.k.a 5.0 or Lollipop which are very important? 
Material Design






Interview Questions on Mobile application Testing

Interview Questions on Mobile application Testing.

These are some of the basic questions asked in interview of Mobile application Testing.I am writing my point of view please add or delete content in the answers as per your knowledge.

Question 1:  What is mobile application testing and how is it different from Mobile Testing?

Answer: Mobile Application Testing (MAT) is the testing of application on mobile devices and it is different from Mobile Testing (MT) in the term that in MT we focus on the native application features of the Mobile devices like Call, SMS, Media Player etc while in MAT we focus only on the functionality & features of the application under Test. i.e, MT is generally done in handset makers like Samsung, HTC, Nokia, Sony, Apple etc while MAT is done in various product based companies and through there vendors like service based companies which  do testing of various mobile applications products on different devices like Gmail on mobile, Skype on mobile etc. 

Question 2: What kind of application you have tested and on which platform of mobile ?

Answer: The kind of application depends upon project on which you have worked on like from multimedia application, banking applications, healthcare applications, social networking application so this part is specific to your particular application and any one can explain about his/her work easily.

Regarding Second part of question:

Platform is also specific to your project/product on which you worked but now a day’s generally all applications are generally developed for iOS (Apple), Android, Blackberry & Windows platforms mainly and on Symbian & Bada platforms also.
While explaining these platforms the interviewers generally want to know about your knowledge of devices or OS that what are specific features on these devices/OS and how does these impact any kind of application.

For example-
  • What is the extension of application developed on different platforms OS : Answer is *.ipa for iOS,*.apk for Android, Blackberry *.jad, for windows  phone *.exe and for palm *.prc file.
  • How can a testable build installed on device: For iOS platform iTunes is required, for Android you need android SDK &; adb install command is used to install build on device.
  • What is latest OS version: 8.0 beta for iOS , Blackberry has OS 10.2.1, Android has 4.4.3 (Kit Kat){at the time of writing blog} 
Question 3: What are the names of various Android OS (Generally asked about latest and just previous) ?

Answer: 

Android 1. 0  (Name not applicable):
·  Was released on 23 September 2008. The first Android device, the HTC Dream (G1),
·  Download and upgrade support from Market.
·  WiFi and Bluetooth support.
·  Google Sync support.
·  Maps with street view  support
·  Voice dialer without typing Name.
·  Static Wallpaper Support      

Android 1. 1  (Name not applicable):
·   Was released on 9 February 2009. 
·    Support Map view with business details
·    Support Saving the attachment from MMS.

Android 1. 5  (Cupcake):
·   Was released on 30 April 2009 based on Linux Kernel 2.6.27.
·   Support third party virtual keyboard with text prediction.
·   Support widget
·   Supports video Recording
·   Copy Paste feature
·   Shows user picture & thumbs for Favorites
·   Animated screen transitions. 

Android 1. 6  (Donut):
·   Was released on 15 September 2009 based on Linux Kernel 2.6.29.
·    Voice and text entry search
·    Multi-lingual speech synthesis engine
·    Updated technology support for CDMA/EVDO802.1xVPNs, and a text-to-speech engine

Android 2.0/2.1 (Eclair):
·    Was released on 26 October 2009 based on Linux Kernel 2.6.29.
·    Can add multiple account and performed sync.
·    Exchange Email supports
·    Ability to search saved SMS or MMS
·    Improve Google Maps
·    Addition of Live wallpaper
·    2.1 SDK was released on 12 January 2010

Android 2.2 (Froyo):
·    Was released on 20 May 2010based on Linux Kernel 2.6.32.
·    Speed, memory and performance optimization
·    Support for the Android Cloud to Device Messaging (C2DM) service, enabling push notifications
·    USB tethering and Wi-Fi hotspot functionality
·    Support for installing applications to the expandable memory

Android 2.3 (Gingerbread):
·     Was released on 6 December 2010 based on Linux Kernel 2.6.35.
·     Updated user interface design with increased simplicity and speed
·     Native support for SIP VoIP internet telephony
·     Support for Near Field Communication (NFC)
·     Supports for multiple Camera , Front Camera Support,
·     OS 2.3.4 supports voice & Video chat using Gtalk.
·     OS 2.3.7 introduced Google Wallet support for the Nexus S 4G

Android 3.0 (Honeycomb):
·     Was released on 22 February 2011 based on Linux Kernel 2.6.36.
·     First android OS Tablet support for Motorola Xoom .
·     Multi-tasking Supports
·     Multiple browser tap
·     Supports Video Chat by Gtalk.
·     Supports for Multi-Core processors.
·     New two-pane Email UI
·     Resizable home screen widget
·     Supports Joysticks and gamepads.
·     Improved Adobe Flash supports in browser.
·     Added System Bar, featuring quick access to notifications, status, and soft navigation buttons, available at the bottom of the screen.
·     Ability to view albums and other collections in full-screen mode in Gallery, with easy access to thumbnails for other photos

Android 4.0 (Ice Cream Sandwich):
·    Was released 19 October 2011
·    Speed, memory and performance optimization
·    Support for the Android Cloud to Device Messaging (C2DM) service, enabling push notifications
·    Separation of widgets in a new tab, listed in a similar manner to apps
·    Ability to access apps directly from lock screen
·    Unlock, a feature that allows users to unlock handsets using facial recognition software. 
·    Supports Google+ , hangout feature.


Android 4.1 (Jelly Bean):
·    Was released 27 June 2012
·     Google Voice Search and Google Now
·      Smart App Updates
·      High Resolution Contact Photos
·      Expandable Notifications
·      Resizeable App Widgets

Android 4.2 (Jelly Bean):
·    Was released 13 November 2012
·     Ability to swipe to open camera from locked screen
·     New redesigned camera app
·     New redesigned clock app
·     New Gesture Keyboard

·     Always-on VPN


Android 4.3 (Jelly Bean):
·    Was released 24 July 2013
·     Autocomplete in dial pad 
·     Support to high performance graphics
·     Location detection through Wi-Fi
·     Restricted profiles - put your tablet into a mode with limited access to apps and content

·     Bluetooth Smart support


Android 4.4 (Kit Kat):
·    Was released 31 October 2013
·     Dialer Search which help in searching nearby thing by phone number
·     Hangouts SMS Integration
·     Wireless printing capability
·     Music and movie-seeking from lock screen
·     Location in Quick Settings
·     Downloads app redesign


Few more question n answers

1. What are some tools used to capture app logs on Android: 

We can use monitor.bat file located under tools folder of android sdk to see log and we can select and save the log from it.other than this alogcat is a free log getting tool which is present in Google Play

2. Screenshot capabilities for Android, and Android phones: 

Same with Android Debug Monitor (Monitor.bat) if device is connected use screen capture  feature and also for Samsung device like note2: Power and Home buttons at the same time & wait for capture sound

3. How do you perform end to end testing in respect to mobiles:

It totally depend upon the project to project,can you please elaborate on the question because this is project specific as starting from installation and version upgrade ,uninstallation etc we do apart from functional testing. Security and Performance of application also need to be tested.

4. Some issues you faced during testing in regards to the platforms you used: 

Some time some issue appear on particular version device and OS of device also do matter.

5. Issues faced with cross platform testing: 

Generally the issue depends upon the different OS/device version, it might be same thing is working on one OS while it might not work on another version.Example we faced issue that our application was working fine on iOS 6.x version devices but on tapping few modules on iOS 5.x devices application crashes and same happened with 2.3.5 Vs 

6. What kind of testing did you perform (functional, interruption, connectivity, etc) : 
Very first test we have to perform installation , after that we check the basic functionality and after that we check the connectivity related stuff of the application, Then we uninstall the build and verify how application respond when we interrupt during installation and also we check interruption scenarios when our application request network call .

We also do low network/poor connectivity testing during network call. Upgrade from older version to newer version. navigation in the application without network if it supports this feature.Compatibility of  app on different kind of phones like having external buttons & devices do not have external buttons or other than this flip phone etc

1) When performing end to end Mobile Testing what major criteria are taken into consideration

Major areas are Installation,first time launching application without having network , uninstallation of app, orientation of app if it support it , testing application performance on different kind of devices and network scenarios , testing the application response how it is responding when invalid user credentials are provided and try to change them after installation n so on.

Also if your application is accessing network then you must see the logs generated during that period so that sensitive information should always go in encrypted form, like if it is payment related CC number etc . 

2) Examples of Defects found during Mobile Testing

Issue is saving contact on phone memory or deleting it or some time conference call issue while an active call is there n like that.

3) Testing on Different Networks (WiFi/Cellular Data Plan)

We have to test the application on 2G/EDGE, 3G and Wifi network because some times application faces issues on slower networks 

4) How do you test patches/defect fixes intended for an app already in production 

We generally do regression of relative module and mainly focus on the area which are related to the bug fixes as per  the developer as we can not do entire regression in very short span of time, so just do sanity of rest of the application modules on high priority devices(on which you have major customer base if you have crunch of time members & if team size is not an issue do sanity on all major devices)

5) what major criteria are taken into consideration when testing sms/mms/call logs

6) Defect Tracking Mechanism

This is of same nature like any other software testing project using any tool like Jira, Bugzilla etc

7) What are the tools used in debugging ?

We generally use logs to see the cause of issue where the failure is occurring , so for iOS iPhone configuration utility  for Android Monitor.bat etc can be used and if you provided logs from these tools developer can easily under stand the cause of issue.

8) Testing performed/modules handled by testers based on their project

We generally divide the modules among the team members and then shuffle the modules among team member with different devices.

9) Data Generation Tools

This is generally done by the Use cases, SRS and FRS document as you application specific test data can be only created using these things.

10) what tools you use for performance testing and automation ?

@ Performance testing of the Web service which your application uses you can use jMeter, it is an open source tool which can be used to test the api's performances.

@Automation: It is very subjective term & totally depends on the project need and type of application , there are several paid tools available in the market like SeeTest, Ranorex, Silk Mobile etc while good free automation tools are  Calabash, Appium , Robotium for Android, KIF for iOS and using free tools you require some coding skills like ruby or Java.
If you can send me you specific requirement, i can help you more on this.

11) tell about filter what you can create while checking logs.. ?

Filters helps you in finding relevant information about your application and you can create filter based on the application package name like com.abc.com and save this filter by name as My application ,when you click on this filter then you will see only logs which are from your application.

You can create filter based on Log tag which is related to the thing that line is doing example if you have placed system.out to print the output put then you can create a filter by tag System.out, then it will short list all the print output.
And you can create filter by Choreographer which helps in finding the skipped frames if you want to see it.

You can create filter corresponding to your PID and log message which is coming as text also.

12) How to check CPU usage and memory utilization of an app ?

You can use various tools like Usemon,CPU Usage Monitor, CPU Usage& Process List Viewer etc available in Google Play store and if you want to use sdk, then you can use systrace feature of Android Monitor

13) one thing which you cannot do with Emulator but can do with real device? 

You can test the interrupts like phone call, messages, battery drain out completely while you were using the application under test, low battery scenarios etc  on real devices , memory card mount/unmount scenarios , actual performance of you application can be test on real devices only, Bluetooth related testing can be only done on real devices.


14) Types of mobile applications? 

Mobile applications can be broadly categorized into three categories i.e, Native app, Web app and Hybrid App.

Native App: Native app are developed specifically for one platform, which is coded with a specific programming language (like Objective C for iOS, Java for Android) and installed directly onto the device and can take full advantage of all the device features — they can use the camera, the GPS, the accelerometer, the compass, the phone book etc. Native apps can use the device’s notification system and can work offline. Native apps are installed through an application store (such as Google Play or Apple’s App Store).Native mobile apps provide fast performance and a high degree of reliability. Example of native app: Temple Run, Candy Crush etc. 
 
Web App:Web applications are mobile web portals that are designed, customized and hosted specifically for mobiles. They are accessed through the mobile device’s web browser using a URL. Web apps became really popular when HTML5 came around and people realized that they can obtain native-like functionality in the browser. Mobile web applications cannot use device functionality. Example of web app: google.com, m.snapdeal.com, m.yahoo.com etc.

Hybrid App:Hybrid Apps are Web apps embedded in a native app, run on the device, and are written with web technologies (HTML5, CSS and JavaScript). Hybrid apps run inside a native container, and leverage the device’s browser engine (but not the browser) to render the HTML and process the JavaScript locally. A web-to-native abstraction layer enables access to device capabilities that are not accessible in Mobile Web applications, such as the accelerometer, camera and local storage. An hybrid app is NOT tied to any platform or any particular mobile device. So, it can run on any device once built. Write Once Run Anywhere (WORA) type of app. Example of hybrid app: Flipkart, Facebook, Twitter etc.


Full Form of various application extensions:

1. iPA: iOS APP Store Package
2. APK: Android Application Package file
3. exe: Executable File
4. jad: Java Application Descriptor 
5. prc: Palm Resource Compiler 

Monday, August 5, 2013

Basic SQL Queries used in Testing



SQL stands for Structured Query Language which is used to managing data in relational database management systems.

1. To check which database is using currently use:  SELECT database();

2. use databasename to select any database;

3. Select * from tablename; to retrieve all data from a particular table

4. Select * from tablename where condition; to retrieve  data for specific Condition

Joins : These are used to retrieve data from two or more than two tables based on some common attributes in these tables.

Use these commands to create two sample tables:

CREATE TABLE school
(
SectionID
INT,
SectionName
VARCHAR(20)
);
CREATE TABLE teacher
(
FirstName
VARCHAR(20),
SectionID
INT
);
 
Insert this data in above tables:
---------------------------------------------------------------------------------------------INSERT INTO school(SectionID, SectionName) VALUES(10, 'Science');INSERT INTO school(SectionID, SectionName) VALUES(11, 'Sports');INSERT INTO school(SectionID, SectionName) VALUES(12, 'Commerce');INSERT INTO school(SectionID, SectionName) VALUES(14, 'Arts');
INSERT INTO teacher(FirstName, SectionID) VALUES('Amit', 10);INSERT INTO teacher(FirstName, SectionID)  VALUES('Deepak', 11);INSERT INTO teacher(FirstName, SectionID)  VALUES('Stuti', 12);INSERT INTO teacher(FirstName, SectionID)  VALUES('Devendra', 14);INSERT INTO teacher(FirstName, SectionID)  VALUES('Dinesh', 14);INSERT INTO teacher(FirstName, SectionID)  VALUES('Jay', NULL);
INSERT INTO teacher(FirstName, SectionID)  VALUES('Mukesh', 11);

---------------------------------------------------------------------------------------------

1. Cross Join: CROSS Join returns the Cartesian product of rows from tables in the join. In other words, it will produce rows which combine each row from the first table with each row from the second table.


Query:

a) select * from school CROSS JOIN teacher; will have 1st school row with all teacher row and then 2 school row than all teacher rows


can also used as SELECT * FROM school,teacher;

b) select * from teacher CROSS JOIN school;will have 1st teacher row with all school row and then 2 teacher row than all school rows


2. Inner Join: Inner join creates a new result table by combining column values of two tables (A and B) based upon the join-predicate.

The result of the join can be defined as the outcome of first taking the Cartesian product (or Cross join) of all records in the tables (combining every record in table A with every record in table B)—then return all records which satisfy the join predicate. This can include duplicate data from another table for corresponding matching condition in first table.


SELECT * FROM school  INNER JOIN teacher ON school.SectionID = teacher.SectionID;


or we can write it as : SELECT * FROM teacher, school WHERE teacher.SectionID = school.SectionID;


3. Equi Join: An equi-join is a specific type of comparator-based join, that uses only equality comparisons in the join-predicate. Using other comparison operators (such as <) disqualifies a join as an equi-join.


Above query of inner join can be used in this example also as those have = inthem.


If columns in an equi-join have the same name, an optional shorthand notation for expressing equi-joins, by way of the USING construct: Select * FROM teacher INNER JOIN school USING (SectionID);

Any columns mentioned in the USING list will appear only once, with an unqualified name, rather than once for each table in the join

"1. Inner join can have equality (=) and other operators (like <,>,<>) in the join condition.
2. Equi join only have equality (=) operator in the join condition.
3. Equi join can be an Inner join, Left Outer join, Right Outer join
4. The USING clause is not supported by SQL Server and Sybase. This clause is supported by Oracle and MySQL."



4.Outer Join:An outer join does not require each record in the two joined tables to have a matching record. The joined table retains each record—even if no other matching record exists. Outer joins subdivide further into left outer joins, right outer joins, and full outer joins, depending on which table's rows are retained (left, right, or both).


a)Left Outer Join:The result of a left outer join (or simply left join) for table A and B always contains all records of the "left" table (A), even if the join-condition does not find any matching record in the "right" table (B)


SELECT * FROM teacher LEFT OUTER JOIN school ON teacher.SectionID = school.SectionID;

b)Right Outer Join:A right outer join (or right join) closely resembles a left outer join, except with the treatment of the tables reversed. Every row from the "right" table (B) will appear in the joined table at least once. If no matching row from the "left" table (A) exists, NULL will appear in columns from A for those records that have no match in B.

SELECT * FROM teacher Right OUTER JOIN school ON teacher.SectionID = school.SectionID;


5. Natural Join:A natural join is a type of equi-join where the join predicate arises implicitly by comparing all columns in both tables that have the same column-names in the joined tables. The resulting joined table contains only one column for each pair of equally named columns.




SELECT * FROM teacher NATURAL JOIN school;