Page tree
Skip to end of metadata
Go to start of metadata

Last updated: Jun 14, 2019 08:58

Instrumentation is a process to prepare the application for testing or automation. Part of the instrumentation process, may add "instruments" that allow the testing framework to gain access to parts of the application.

Perfecto provides tools for instrumenting mobile applications for different purposes:

Instrumenting Hybrid Applications

Hybrid applications, applications that display parts of the UI in WebView objects, require basic instrumentation to provide access to the parts of the UI hosted in the WebView objects.

Perfecto supports three types of instrumentation:

  1. On-the-fly instrumentation (iOS and Android)
    • This instrumentation is performed when installing the app on the device. Perfecto Mobile updates the instrumentation library but the customer needs to re-install the app after every version update and not to use previously installed app.
  2. Customized instrumentation (only for iOS)
    Instrumentation of the application from a Mac workstation, using a Python script to activate the different instrumentation flavors.
    Users have the ability to instrument the app while maintaining the original application entitlements and signature.

  3. Offline Instrumentation (only for Android)
    • This instrumentation is performed on the application apk file, and generates an instrumented apk file that can be stored by the user and later installed directly onto the Android device.
    • Customers need to download a new version of the "Perfecto-Lib" and re-instrument after every Perfecto version update.

Hybrid application instrumentation notes:

  • Instrumentation is required to gain access to DOM objects in Hybrid apps.
  • As a general rule, on-the-fly instrumentation is preferred over framework instrumentation.
  • Perfecto also supports instrumentation for MultiDex apps (Android) and for Swift apps (iOS), in addition to SingleDex and Objective-C apps.
  • Instrumentation only affects the application code and does not affect the mobile OS performance or activity.

Sensor Instrumentation

Perfecto supports interaction with the different input sensors, of the Perfecto Lab mobile devices, to inject different data to allow easy, reproducible testing of applications. For example, the Image inject functionality allows the tester to provide an image file to the device camera. Before using the sensor functionality the application needs to be instrumented to provide an indication to the Perfecto Lab when the sensor prompts the user for data.

The Sensor Instrumentation is activated during the application installation:

  • Manual testing - install the application using the Install app widget. After providing the application's repository location, Several instrumentation options are offered. The second instrumentation is sensor instrumentation - set the value to True.
  • Perfecto Automation/UFT - use the Install application function and set the sensor Instrumentation parameter to sensor.
  • Selenium - set the "sensorInstrument" parameter of the mobile:application:install Perfecto command to sensor.
  • Appium - set the "sensorInstrument" capability to true, when starting the application during driver creation.

Instrumentation in Manual Testing - Install application

Instrumentation parameters of Install application - Native Automation

Camera Instrumentation

Perfecto supports an image injection feature that simulates image input from the device camera. The application must be prepared for image injection during the installation process using sensor instrumentation.

Authentication Instrumentation

Perfecto supports a sensor authentication simulation feature that simulates an authorization analysis using the device fingerprint reader or face recognition system. Using this feature requires that the application that accesses the authentication sensor, be instrumented (with sensor instrumentation) to let the test/automation script to identify the activation of the sensor.

Re-sign application:

For more information see Re-sign application - iOS

Known Limitations

See the general limitations article.