Appium

  

TensorFlow Brain

and its

PROBLEMStatement

elementByClassname("android.v4.ViewPage")
elementByXpath(".//*[@text='cart']")
elementById("cart")
elementByClassChain(".//XCUITypeWindow//*//XCUIClassName")

Locator Strategies

elementByCustom("ai:cart")

AI Locator

Demo

Appium AI Plugin 

  • Get all leaf DOM elements from the application under test, including each element’s coordinates and size.

 

  • Get a screenshot of the application.

 

  • Crop the screenshot into lots of little screenshots

 

  • Run each element’s cropped screenshot through the neural network.

How does

it WORK?

MODEL WORK?

How does the

The model is a neural network that takes a 224✕224 pixel 3-channel color image as input and outputs 105 numbers that represent the confidence or probability that the input image matches each of the 105 labels that the model knows about (cart, edit, twitter, etc.

The model is MobileNet v1,2 which is a pre-trained model released by Google AI. MobileNet is a “deep”, “convolutional” neural network.

Neural Network

RECOGNIZE APP ICONS

Training the model to 

Demo

Selector Strategy  
CSS/XPath When your app’s DOM changes  Easy to understand why
Easy to fix
Test.ai’s image classifier When your app’s icons change visibly
When the model changes
(that is, when you upgrade the Appium plugin)
Hard to understand why
Hard to fix

PROS

CONS

OBJECT DETECTION TECHNIQUE

Demo

  • Greyscale images for training
  • Usage of XPath (//*[not(child::*)]) to identify all the elements in the screen
  • Pass all images to tensorflow at once
  • Use of SSD (Single Shot MultiBox Detector)
  • Usage of another MobileNet model for e.g 128✕128 pixels
  • Model benchmarking requires a more accurate test dataset
  • Reduce false positives and mis-classification

Future Improvements

Appium and AI

By Sai Krishna

Appium and AI

  • 1,451