Appium is an open-source and free-to-use mobile automated testing framework that consists of an Appium server. It can be run from the command line, or it's also available as a desktop app. Appium supports a variety of programming languages for writing test cases. Once written, the automated tests are run on connected devices or simulators. All of this is covered well in our post titled "Appium Architecture, Explained."
And Appium comes with a lot of features and additional tools to add to its functionality. These tools include Appium Doctor and Appium Inspector.
Today, we're going to learn to set up Appium on macOS. We'll write automated tests in Java in Eclipse IDE. Finally, we'll run the test cases on an iPhone simulator. A Mac is required to develop iOS apps and run iOS simulators. Android apps can be created and tested on Windows system. Refer to our earlier post of testing with Python and Testing React Native app to learn about Android testing.
data:image/s3,"s3://crabby-images/667f5/667f5aa721347e43ef0e6c5d57b3270e37facbd1" alt="And Appium comes with a lot of features and additional tools to add to its functionality.".png)
Basic Setup
We need to do the proper setup even before running our tests on Mac. Here, we're first checking if Java is properly installed on the system by giving commands on the terminal.
data:image/s3,"s3://crabby-images/bf229/bf22994967147d7331e33219668172cc51b45ce6" alt="screenshot of code"
We should also have Node.js and npm installed on the system. If you don't have them installed, you can install Node.js from this link.
data:image/s3,"s3://crabby-images/5d1f6/5d1f6bc576fb872a6ae0de542b3bbd55fdbd6641" alt=""
Xcode is required to run iOS apps, which can be installed from the App Store on Mac. Besides this, we also need Xcode command line tools. And we can install it with the command xcode-select --install.
data:image/s3,"s3://crabby-images/b6570/b6570b79211ddd3c1cbda4c7ef127b39df9428ee" alt="screenshot of code"
Now, we need to have an Apple ID set in Xcode. So, open Xcode and click on Preferences.
data:image/s3,"s3://crabby-images/3c963/3c96357f9b43d81a4642c85fa00bef102886018c" alt="screenshot of Xcode menu preferences"
Here, I already have an account added. If you don't have an account added, you can add one by clicking on the plus sign on bottom-left corner of the screen.
data:image/s3,"s3://crabby-images/2b30a/2b30a7fbb81d8999a41f479aa0e20d84bb49c262" alt="screenshot of apple ID login"
The package Carthage is also required for Appium to run. We can install it using Homebrew, the package manager for macOS, by running the command brew install carthage.
data:image/s3,"s3://crabby-images/dd386/dd386eb72b16baeb5d7ce324e17874126e06fa09" alt="screenshot of code"
Xcode Setup for Appium
We need to have the Appium Server package or desktop app installed on our macOS system. You can install it with this command:
You can also install the desktop app from the Appium site for macOS. Since we've installed Appium Server using npm, we need to go to the below path and open the WebDriverAgent.xcodeproj with Xcode:
data:image/s3,"s3://crabby-images/6c577/6c5776123ce608263047a07f642c2c451223b111" alt="screenshot of opening folder"
Once you've opened the file WebDriverAgent.xcodeproj, click on the issue navigator.
data:image/s3,"s3://crabby-images/33005/3300594009a3fa1b1f96e1e4232d520243e6a1b7" alt="screenshot of opening webdriveragent"
Here, click on any warning and it will open a pop-up. We need to click Perform Changes to fix all issues.
data:image/s3,"s3://crabby-images/df7c5/df7c59098fe258425f81bad08dc8f305609e35c4" alt="screenshot of checking building phases"
Next, click on WebDriverAgentLib in the Project Explorer. Once it's open, we again need to click on WebDriverAgentLib in TARGETS.
data:image/s3,"s3://crabby-images/3a026/3a026a8550434408884f5b818f5068dbe04e60df" alt="screenshot of webdriveragent folder"
Now, click on the Signing & Capabilities tab. Here the checkbox for Automatically manage signing should be checked. Additionally, the Team should be any team we have.
data:image/s3,"s3://crabby-images/d61d6/d61d63b2a9701982f694f523feb90ac48b09eef8" alt="screenshot of checking automatically manage signing box"
Next, we're going to do the same for WebDriverAgentRunner. Here, again the Automatically manage signing checkbox and Team should be as per WebDriverAgentLib. But notice that we have some warnings.
data:image/s3,"s3://crabby-images/184c3/184c3fd675d07088724c51c0d1f336692b8207aa" alt="screenshot of status failed to register"
To fix the warnings, go to the Build Settings tab. Here, update the Product Bundle Identifier to something unique.
data:image/s3,"s3://crabby-images/93d53/93d5395396192e9380606aae411cdc05f576982a" alt="screenshot of how to fix warnings"
Now, go back to the Signing & Capabilities tab. You'll find that all warnings are gone.
data:image/s3,"s3://crabby-images/10241/1024161045aecd7739e13d9dc9ba77bc61dbc0b7" alt="screenshot of signing and capabilities"
We'll clean the project now by clicking on Product, and then clicking on Clean Build Folder.
data:image/s3,"s3://crabby-images/d3ef6/d3ef61d525875af31d1857d4b67362d274ef18a8" alt="screenshot of clicking on "product""
Once, the cleaning is done, click on Product again. Then, click Build.
data:image/s3,"s3://crabby-images/e2f32/e2f32dc6efebe2570cd34f79ab29de04f4f8b566" alt="screenshot of clicking on Product"
Once the build is done, click on the play icon to run the project.
data:image/s3,"s3://crabby-images/c47a1/c47a1ccfb19c666158dfccc9e3955a2181951784" alt="screenshot of clicking play icon"
The project will run on an iOS simulator and show the demo project. This also means that our setup was done properly.
data:image/s3,"s3://crabby-images/db08f/db08fd2a97c7bcc0084e3028b30439f944cc8136" alt=""
Now that our demo project has confirmed we properly set up Appium on Mac, let's do a different test case.
Project Setup for Test Cases in Eclipse
We'll write our test cases in Java, so we require an IDE. I'm using Eclipse, but you can use any other Java IDE.
After opening Eclipse, create a new file. The file type will be Other.
data:image/s3,"s3://crabby-images/e375a/e375acadc3fa18d94ffcdfaa3616fc34de4558c8" alt="screenshot of opening Eclipse"
Next type maven in Wizards search box. Then, select Maven Project and click on the Next > button.
data:image/s3,"s3://crabby-images/62d16/62d1631ff0b7275d1adc570e9fe6f5cb5cb58b53" alt="screenshot of typing maven in wizards"
In the next screen, the first checkbox is clicked, which is for a simple project. Click on the Next > button.
data:image/s3,"s3://crabby-images/1f389/1f38953f2fb447e50c9a6ed767d1b478c400cdae" alt="screenshot of first checkbox"
In the next pop-up, give the Group Id and Artifact Id. After that, click on the Finish button.
data:image/s3,"s3://crabby-images/43556/4355604d2fa22753ade75e80fa523e37c3b7ed12" alt="screenshot of popup group ID"
Our project will be opened now. Here, we'll see our pom.xml, which contains the requirements of the project.
data:image/s3,"s3://crabby-images/15d58/15d589a0f08e3fad76b78a1f6473686abfd24fe9" alt="screenshot of opening the project"
Now, we need to add the references for Selenium Java and Appium Java client from the MVN repository. First, search for selenium java. It'll show up as the first package.
data:image/s3,"s3://crabby-images/cac4b/cac4b8c682ef5cb88188b4d6c0ab7203f749a7ad" alt="screenshot of adding selenium java references"
Now, copy the code for Maven and keep it somewhere.
data:image/s3,"s3://crabby-images/49d90/49d90054d63c8071dc93b44f704527b56999d0db" alt="screenshot of copying code for Maven"
Next, we'll search for appium Java client for our project. Again, search for it in the MVN Repository. It's the second package here.
data:image/s3,"s3://crabby-images/00c14/00c143df1545536d37735de47f4fbfbb6cd5e2b8" alt="screenshot of search for appium java client"
Again, copy the code for Maven and keep it.
data:image/s3,"s3://crabby-images/e4383/e4383d78b466cd69748afd31c8e1221801f99618" alt="screenshot of copying Maven code"
Finally, add both code blocks in your pom.xml file inside dependencies.
data:image/s3,"s3://crabby-images/b5a02/b5a025682346112cbc5f51f6d187010fd8f81ccf" alt="screenshot of code"
Writing Test Cases
We'll first create a new test file. Right-click on src/test/java, and then click on New. After that, click on Class.
data:image/s3,"s3://crabby-images/e944c/e944c2b4a0122730dcb206fcc366fe71821c539c" alt="screenshot of creating new test file"
In the next pop-up, give the test file a name, in the Name textbox. Also, click on the checkbox to create a main method.
data:image/s3,"s3://crabby-images/a170e/a170e51417bcd8abc769062d0a00d5da190f026b" alt="screenshot of test file name"
Before writing the test case, we need desired capabilities for Appium.
In Xcode, click on Window and then on Devices and Simulators. Here, in a new pop-up we'll get all the devices. Note down the different parameters from the simulator you intend to run the application on.
data:image/s3,"s3://crabby-images/468b3/468b31cd061acc16ce036ddaf952cffeef739909" alt="screenshot of clicking on window and devices and simulators"
Open the newly created NewIosTest.java. Here, we've imported the required packages first. Then, from the main() method, we're calling the newTest() method. Inside newTest(), we have to give the desired capabilities first for Appium. Here, we've given the device name, platform name, and platform version from the earlier step.
We'll be running our simple test on Safari, so we'll give the capability type as well. After that, we've given the URL for the Appium Server. We're connecting to the iOS driver by passing the URL and capabilities.
data:image/s3,"s3://crabby-images/a8449/a84491ad08d0d28f97f4d66c4bc71424679286ca" alt="screenshot of running test on Safari"
Running Test Cases
To run the test cases, we should have Appium Server running. Since we've configured Appium from a Node.js package, we'll run Appium from the terminal.
data:image/s3,"s3://crabby-images/805a5/805a591b7b6ceca1247eed51add11db10d2cdfa3" alt="screenshot of code"
Now, we've added a log. Right-click on the code System.out.println("Started the Application");. Then, run it as a Java application.
data:image/s3,"s3://crabby-images/42933/429337edc64ceef08695de1858f7289acbd7add1" alt="screenshot of right clock on code system"
Since everything was set up correctly, we'll get the correct logs. Also, the mobile Safari app will open automatically on our connected mobile device.
data:image/s3,"s3://crabby-images/ccbb6/ccbb6e82c95405c4039ac4e826b8ea6de30c8d47" alt="screenshot of code and connecting mobile device"
Conclusion
In this post, we've set up Appium on a macOS machine. Then, we set up Xcode for Appium. Finally, we've created our automated test in Java using Eclipse IDE and ran it successfully in iOS simulator.
This all seems to be very complicated. So, we can just get the APK or IPA file and try Waldo. APK files are the file for the app which is deployed in Android Play Store. And IPA file is deployed in Apple App Store. Most of the time testers gets this file to test the app instead of the code.
With Waldo we can avoid writing test cases and learning a new language like Java in the process.
Automated E2E tests for your mobile app
Get true E2E testing in minutes, not months.