Skip to content

Latest commit

 

History

History
196 lines (133 loc) · 8.88 KB

README.md

File metadata and controls

196 lines (133 loc) · 8.88 KB

test-ai-appium-demo

JDK-11+ Apache 2.0 Discord

Welcome to the test.ai Appium Java demo!

This repository contains a pre-configured project and basic tutorial, so you can hit the ground running with test.ai enhanced Appium!

👉 This tutorial uses Android, but you will be able to use test-ai-appium with iOS as well.

Pre-requisites

Before we get started, please ensure that you have installed the following software on your computer:

You will also need a test.ai account, please visit https://sdk.test.ai (it's free!) to register.

An Introduction to the test.ai SDK

In the following tutorial, you will learn how to set up and run AI-enhanced Appium with test.ai.

Now that you have the pre-requisites installed, let's get started.

Please begin by cloning this repository to your computer.

git clone https://github.com/testdotai/java-appium-sdk-demo.git

Configure Java

Now we'll install Java dependencies. cd into the root directory of this repository and run

./gradlew build

If you're using Windows, please run the following command instead:

gradlew.bat build

Configure the Android emulator

Next, we'll set up an Android emulator.

  1. Open Android Studio and create a new project.

    ⚠️ if the Setup Wizard appears, please complete the wizard and install all the additional dependencies it suggests.

  2. In the menu bar, go to Tools -> AVD Manager (Device Manager on newer versions of Android Studio). Click + Create Virtual Device... (Create Device on newer versions of Android Studio), and select the option for Pixel 4.

  3. Click Next and choose the option for Pie.

    👉 If there is a download button next to Pie, please click it, wait for the download to complete, and then click Finish.

  4. Click Next, and under AVD Name, call your new emulator Pixel 4 Test.ai. Click Finish.

  5. Now click the green ▶ icon in the same row as your newly created Android emulator to start it (may take a few seconds to launch).

  6. (Optional) If you are using a newer version of Android Studio, you can undock the emulator by clicking the ⚙️ icon in the upper right corner of the Emulator sub-window, and click View Mode -> Window

Configure Appium

Next, we'll set up Appium. cd into the root directory of this repository and run

npm install

to install Appium. To start Appium, run

npx appium

👉 It is advisable to launch Appium in its own terminal window since it does not return terminal control back to you after starting.

Run the demo

We're almost there! Please visit https://sdk.test.ai, and log into your account. Please copy your API key (in the upper right corner of your screen), you will need this for the next step.

Example API Key

It's now finally time to run the demo! cd into the root directory of this repository, and run the following command, replacing the text YOUR_API_KEY with your test.ai API key.

./gradlew run --args=YOUR_API_KEY

If using Windows, please run

gradlew.bat run --args=YOUR_API_KEY

If everything worked, the Wikipedia app will be installed in the emulator and launched. Then, the sample code in this demo will tap the button to skip the app setup, tap on the search button, type in a search term, and click the button to view an article.

🎥 Click here to see a video of the expected behavior.

Thus far, this sample code is using the standard Appium selectors without any AI, which is how apps today are commonly tested. However, these selectors are fragile and break easily, as even minor changes to an App may cause them to immediately stop working. Fortunately, the test.ai SDK is equipped to help you avoid this unecessary hassle.

Using test.ai with Appium

Please visit https://sdk.test.ai (and log in to your test.ai account if you've been logged out).

You should see the following new entries on this page:

namely,

  • skip_button
  • search_wiki_button
  • search_wiki_field
  • shang_chi_button

Start by clicking on the link in the Element column for skip_button.

On this new page, scroll down until you see the skip_button. Now, using your mouse, click and drag a box around the button that reads SKIP. A green box will appear around your selection. Release your mouse button to save the selection.

skip button demo

Believe it or not, you just used AI! test.ai is visual-based, so there's no need to mess around with Appium selectors. The test.ai classifier will train itself using the element inside the box you just drew with your mouse, and now, when it encounters this element in the future, it will be able to recognize it!

Let's do the same thing for the other elements.

search_wiki_button

(click to expand)

search wiki button demo

search_wiki_field

(click to expand)

search wiki field demo

shang_chi_button

(click to expand)

shang chi button demo

👉 Training takes a few minutes, you can check training status by visiting https://sdk.test.ai/training_status

training status

Next, let's simulate what happens when a developer changes an App's code.

In the IDE of your choice, please open src/main/java/ai/test/sdk/demo/Example.java. This Java file contains an abridged form of what you might find in typical Appium-based test suite.

A few noteworthy items:

  • The AndroidDriver gets passed as a parameter to a TestAiDriver, along with your API key.
  • Each call to findElementByXPath contains a second parameter, which is used to give the element a human-readable name for use at https://sdk.test.ai

As you can see, it is very easy to integrate test.ai into your existing Appium-based test cases.

Now, let's change a couple of the XPath selectors:

// Change this line:
MobileElement searchField = driver.findElementByXPath("//android.widget.TextView[@text='Search Wikipedia']", "search_wiki_button");

//to:
MobileElement searchField = driver.findElementByXPath("//android.widget.Button[@text='Search Wikipedia']", "search_wiki_button");
// Change this line:
searchField = driver.findElementByXPath("//android.widget.TextView[@text='Shang-Chi and the Legend of the Ten Rings']", "shang_chi_button");

// to:
searchField = driver.findElementByXPath("//android.widget.ShangChiButton", "shang_chi_button");

As you may have already guessed, a standard Appium test would certainly fail, but test.ai won't!

Re-run using AI selectors

⚠️ If you closed Appium and/or the Android emulator, please restart them with the instructions in the section at the beginning of this tutorial.

Using your terminal, cd into the root directory of this project, and run the following command, replacing the text YOUR_API_KEY with your test.ai API key.

./gradlew run --args=YOUR_API_KEY

If using Windows, please run

gradlew.bat run --args=YOUR_API_KEY

The demo will repeat the same steps that it did previously, only this time, it's using test.ai! The "developer's breaking changes" we introduced in the code have no effect on the test's ability to run, all thanks to test.ai AI.

And that wraps up this tutorial! As far as next steps go, feel free to experiment more with this code and try out some of the other selectors. Good luck and have fun! 🎉

Additional Resources

Contact

Questions? Comments? We'd love to hear from you!