Mobile Testing using iOS

Purpose

Rapise lets you record and play automated tests on real iOS devices (iPad and iPhone) as well as test applications using the iOS simulator that ships with Xcode. No jailbreaking needed! With Rapise you can record on one device and playback on multiple.

Prerequisites

This section assumes that you have already installed and configured all of the necessary components. For details on this, please refer to the Preparing Environment for iOS Mobile Testing section.

Configure the Mobile Profile

To begin the actual mobile testing, create a new test, using the File > New Test option in Rapise. Make sure you choose the mobile methodology option Mobile: Mobile Support:

create new test dialog mobile selected

Once you have entered the name for the new test (with the mobile methodology selected) you will be asked to choose the mobile profile. Rapise ships with several default profiles, for now select the one that is closer to the device you want to test (we recommend the iOS App Simulator generic profile):

mobile_choose_profile_iphone

When you click the OK button, Rapise will ask you to choose the Scripting Language:

clip0121

Please choose the Rapise Visual Language (RVL). Rapise will then create a new mobile test with the iOS App Simulator profile selected.

clip0122

Now you need to modify the profile so that it correctly matches the type of device you are testing and also so that it correctly points to the Appium server that you are using to host the mobile devices. Click ... button in the top right corner of Rapise window

open mobile profile button

mobile_settings_dialog_ios

The example screeenshot above is for an iPhone X simulator running iOS 11.4. For any iOS device (real or simulated) you will need to provide the following:

In addition, for physical devices only, you need to specify:

Once you have entered in the information and saved the profile, make sure that Appium is running on the Mac and then click the Test Url button to verify the connection with Appium:

mobile_settings_dialog_ios_success

Now you can start testing your mobile iOS application.

Using the Mobile Spy

The Mobile Spy will let you view an application running on the mobile device, take a snapshot of its screen and then interactively inspect the objects in the application being tested. This is a useful first step to make sure that Rapise recognizes the application and has access to the objects in the user interface.

If you do not see Mobile Spy button mobile spy button on the toolbar then choose Mobile Spy from the main menu: Tools > Spy > Mobile. Click Mobile Spy button, Mobile Spy will be displayed in Discovery Mode. Now click the Get Snapshot button to display the application specified in the mobile profile on the screen:

spy_dialog_mobile_ios

In the example above, we are displaying the sample iOS application that is available in AUTiOS Repository.

If you click on one objects in the user interface, it will be highlighted in Red and the tree hierarchy on the left will expand to show the properties of that object:

spy_dialog_mobile_ios_2

If you want to view the contents of the Spy as a text file, just click Spy > Page Source menu and you will see the contents of the Spy properties window as a text file.

If you want to perform an action on the application (e.g. click on the selected item) use toolbar buttons.

toolbar events

Now click on Tap and Rapise will send a tap event to the application, switching the application to the next page:

after tap screen

Assuming that you can see your application in the Spy and that the objects can be inspected (similar to that shown above) you can now begin the process of testing your mobile application. Click on Spy > Disconnect menu to end your Spy session and close the Rapise Spy dialog. You will now be returned back to your test script.

Recording and Playing a Test

With the new Rapise mobile test script open, click on the Record button on the toolbar and that will display the recording activity dialog:

recording activity dialog_mobile

Now click on the Spy button and the Rapise Spy will be displayed in Recording Mode:

spy_dialog_mobile_ios_3

We now want to record a click on one of the menu options, simply click on the Basic Controls list item on the screenshot you see in Mobile Spy:

spy_dialog_mobile_ios_4

Now click the Tap button to move the sample app to the next screen; Rapise will automatically reload the page in the Mobile Spy to get the updated screen:

spy_dialog_mobile_ios_5

Now highlight user name field, put text into the edit field on the toolbar and press Send Keys button. Do the same for password field and record tap action on the Login and Home (back arrow) buttons. You will see the events in the recording activity dialog:

recording activity dialog mobile ios

Now click on the Finish button and you will be taken back to the test script with the iOS objects listed and actions displayed on the RVL sheet:

object_tree_ios_recording

Now to playback the test simply click Play in the Rapise toolbar and the test will play back in the iOS Simulator. This is the report of the test being executed.

report_mobile_ios

Sample Application and Tests

You can find the Android sample tests and sample Application in AUTiOS Repository.

See Also