Appium is a totally free-to-use mobile automated testing framework that comes with a lot of features and additional tools to add to its functionality.
We can also write test cases in a lot of languages including Python in Appium.
In this post, we'll learn briefly about Appium before learning to install it on our system. This will be followed by a guide to installing Python on our system, since we'll use it to write test cases.
After that, we'll install PyCharm, which is the de-facto IDE for Python development. Here, we'll also need to do some Appium-related configurations.
Finally, we'll write a simple test case with the Appium framework and Python and get the result on our mobile device.
What Is Appium?
Appium is a completely open-source and free-to-use mobile app testing framework. It can be used to test any type of mobile application, whether it's written using the native languages of Kotlin, Java, Swift, or Objective-C, or whether it's just a web app running on mobile browsers.
Appium even tests mobile apps created using languages like React Native or Flutter, which use webview to create cross-mobile apps. Cross-mobile apps can run on both iOS and Android platform using a single codebase.
We can write test cases in Appium using a variety of languages, such as Java, Python, JavaScript, or PHP. For example, we've written test cases in JavaScript. After we write test cases in Appium and execute them, it'll show us the result.
Furthermore, the app will run automatically on the connected device and show the user interactions written in the test case. The user interactions include things like logging into the app by giving a username and password and clicking on the login button. It'll seem like a real user is participating in the interactions.
Using Python in Appium
We can use Python in Appium to write test cases. In fact, we also can use other languages like Java and JavaScript. Python is a very popular language among the testing community because of the Selenium framework, and it's used here too.
Using Python to write test cases in Appium is easy. But we need to do a lot of configurations before starting to write test cases.
Let's look into these configurations first before we start successfully executing our Python test case. We'll do all of our setup on a Windows machine, but the setup on a Mac is quite similar.
Appium Installation
Appium is a complete open-source and free-to-use software. There's an npm package to install it and run through the command line. But Appium desktop gives more functionalities and also can configure a lot of things from it. We need to first go to release page and click on the Appium server for Windows.
data:image/s3,"s3://crabby-images/1bb58/1bb589da97a80773b79552955e7c2f17c7789258" alt="Automated Testing With Appium and Python Screenshot 1"
Next, it'll ask our permission to install the application. Here, we've chosen to complete everything on the Windows system.
data:image/s3,"s3://crabby-images/6c647/6c6473895ebb6eab0c14c61bf2b1e5627c8cc673" alt="Automated Testing With Appium and Python Screenshot 2"
The installation will start, and it'll take about two to three minutes.
data:image/s3,"s3://crabby-images/de2ea/de2eabe5f0d480a30849c52dfe059520e64b9c44" alt="Automated Testing With Appium and Python Screenshot 3"
Once the installation is complete, it'll ask us to run the Appium server GUI.
data:image/s3,"s3://crabby-images/27450/27450c668be6683c18c223119f65b30a8ba4efac" alt="Automated Testing With Appium and Python Screenshot 4"
Now, the login screen has a big startServer button. Click on it, and the Appium server will be started on Port 4723.
data:image/s3,"s3://crabby-images/59960/59960f19ddf95c40a24e33db650d878140dd96ab" alt="Automated Testing With Appium and Python Screenshot 5"
A terminal will open to show the Appium server running on Port 4723.
data:image/s3,"s3://crabby-images/753d6/753d6fe03d7ea82922c3c9e770a88e66feb780a9" alt="Automated Testing With Appium and Python Screenshot 6"
Python Installation
Now, let's install Python for Windows. Here, we're downloading a stable version of 3.7.9.
data:image/s3,"s3://crabby-images/841c4/841c4a7746adc8a8f6a80884338ab69d4bee0262" alt="Automated Testing With Appium and Python Screenshot 7"
Click on "Install Now," and mark the checkbox to "Add Python 3.7 to PATH."
data:image/s3,"s3://crabby-images/61ac1/61ac15a990a228974ea44789f42a859be8bc505a" alt="Automated Testing With Appium and Python Screenshot 8"
Our Python installation will start, taking about two to three minutes. If everything is OK, we'll get this screen.
data:image/s3,"s3://crabby-images/e0b83/e0b8377fb9b9972b4ff268e9a9c6fbf5ef027ffa" alt="Automated Testing With Appium and Python Screenshot 9"
Now, make sure the Python installation was successful and installed in the PATH. To do this, run the Python command from the terminal.
data:image/s3,"s3://crabby-images/6c1eb/6c1ebdca70367b908e382b4ab68e4cff42653f72" alt="Automated Testing With Appium and Python Screenshot 10"
PyCharm Installation
Now we need to install PyCharm, which is the IDE most used with Python. It also allows us to do additional configuration related to Appium.
We'll download PyCharm from the official link. Notice that we're using the free-to-use community version.
data:image/s3,"s3://crabby-images/7615e/7615ec59ae06ca7e7fc45c89fb8d94ce4582a43b" alt="Automated Testing With Appium and Python Screenshot 11"
Upon clicking on the downloaded exe file, we'll get the screen below. Here, we need to click on the "Next" button.
data:image/s3,"s3://crabby-images/2d6f8/2d6f860d9dc2bb3db0dcd4f1dab391551865dacb" alt="Automated Testing With Appium and Python Screenshot 12"
Then, it'll show the destination folder and the space required. Just click "Next."
data:image/s3,"s3://crabby-images/0ee59/0ee5956201c8e4269204cc133ff1639844596f65" alt="Automated Testing With Appium and Python Screenshot 13"
On the next screen, we need to click on some checkboxes again to add the program to PATH—this is very important.
data:image/s3,"s3://crabby-images/91519/91519ae4f7a69bea5cd8ce0578c917bc89f3de35" alt="Automated Testing With Appium and Python Screenshot 15"
Finally, we'll get the "Install" button to install PyCharm.
data:image/s3,"s3://crabby-images/0f135/0f135e2228025fb9e1323d437602860d7963b24b" alt="Automated Testing With Appium and Python Screenshot 16"
It'll take five to 10 minutes to install PyCharm. Once it's installed, it'll ask us to reboot the computer.
Configuring PyCharm
Once our system has been restarted, we need to start PyCharm. It'll ask us to accept the terms, so click on the "Continue" button.
data:image/s3,"s3://crabby-images/39e0e/39e0eec0364a51049de9e309cc560438f30df39e" alt="Automated Testing With Appium and Python Screenshot 17"
Next, we need to click on "Data Sharing." Here, we can click on any of the buttons as per our preferences.
data:image/s3,"s3://crabby-images/269c7/269c7500ba1fdaf177c3caa69cbd99fc08eb219a" alt="Automated Testing With Appium and Python Screenshot 18"
Then, we'll finally get the PyCharm screen. Here, we need to click on "New Project."
data:image/s3,"s3://crabby-images/953c4/953c442434b027dfa3d4d123c5be18e5a680df67" alt="Automated Testing With Appium and Python Screenshot 19"
On the next screen, we'll keep all the configurations and click on "Create."
data:image/s3,"s3://crabby-images/d48b4/d48b45613034b07e3aa0a1e93ea5b11971a02d6f" alt="Automated Testing With Appium and Python Screenshot 20"
Now, we'll get a default code in main.py. However, we don't need it, so right-click on it and hit "Delete."
data:image/s3,"s3://crabby-images/c6022/c60229bc597087df65925b2abb49447f00ee6071" alt="Automated Testing With Appium and Python Screenshot 21"
Next, click on "File" and then "Settings."
data:image/s3,"s3://crabby-images/00f52/00f52685a1f51104e7dd75f85f6d649550aa0a5d" alt="Automated Testing With Appium and Python Screenshot 22"
On the Settings screen, click on the Python Interpreter. This will show all of our installed packages. Here, we need to click on the + icon.
data:image/s3,"s3://crabby-images/27644/276442b02e45adf88786b311015c486de6a8372c" alt="Automated Testing With Appium and Python Screenshot 23"
Next, search for Appium in the search box. Click on Appium-Python-Client and then Install Package.
data:image/s3,"s3://crabby-images/a2ac6/a2ac6a42bcf379dbe46a8bf330c82fcf014e5f7e" alt="Automated Testing With Appium and Python Screenshot 24"
Back in the project, right-click on the file name, which is pythonProject. Then, click on New and Python Package.
data:image/s3,"s3://crabby-images/bdb6e/bdb6ea73afd90a957ce0a16bfa77c0b7b8270873" alt="Automated Testing With Appium and Python Screenshot 25"
This will open a pop-up in which we need to give the Python package a name.
data:image/s3,"s3://crabby-images/2e3ca/2e3caf482e361378687d51bd369243fd58e5eba7" alt="Automated Testing With Appium and Python Screenshot 26"
Now, right-click on the newly created package. After that, again click on New and the Python File.
data:image/s3,"s3://crabby-images/d7152/d715243c95e519c840d16e5de675a4b41377a519" alt="Automated Testing With Appium and Python Screenshot 27"
This will open a pop-up, where we need to give the Python file a name.
data:image/s3,"s3://crabby-images/8dafa/8dafa225b61c4648bcd6e9c284d98883cd21b572" alt="Automated Testing With Appium and Python Screenshot 28"
Final Steps
One final step remains before writing test cases. We need to have Android Studio installed and PATH variables properly installed on the system. The installation steps can be found on Android's official documents.
We also need Java installed on the system because Appium uses Java to run. Again, you can find the steps from the official documentation here.
For Appium to show an automated test, we need to have emulator enabled on Android Studio or a real device attached to the system. Again, we've followed the steps from the official documentation here.
Now, when we run the adb devices command from the terminal, it'll show the connected device. We need to note it to run test cases.
data:image/s3,"s3://crabby-images/25163/25163ad1f408f0a062f25081b758350d119d1858" alt="Automated Testing With Appium and Python Screenshot 29"
Test Cases
Let's write a simple test in our file.
First, import packages for time and Appium. Then, we have a Python dictionary called desired_capabilities. In Appium, we need to give the desired capabilities either through client programming, which is done here, or from the Appium Server GUI.
Here, we're giving what's required, which includes our device name, from the previous step. It also contains the platform name and browser name on which our test will run. In this test, we're just using the mobile browser to run a simple test.
Next, we need to connect to the Appium server, which is running on localhost, and pass the desired_capabilities as a second parameter.
In this small test, we'll launch Google on our connected device's browser. After that, we'll go to sleep after two seconds, as seen on line 14. And for this reason only, we imported the time module at the start. By going to sleep, we mean not doing any activity for two seconds. After that, on line 15, we're quitting the test with the driver.quit() command.
Now, after writing this test case, click on the "Run" button in the top right corner.
data:image/s3,"s3://crabby-images/6a740/6a740d10cde1ee9cf729b3fd76b1fae40d7cdebd" alt="Automated Testing With Appium and Python Screenshot 30"
In our case, we got an error message because our Chrome driver was outdated.
data:image/s3,"s3://crabby-images/899a8/899a8064af76a02c2c5bf7b3bf636d33a96f9f8a" alt="Automated Testing With Appium and Python Screenshot 31"
Fixing Errors in Test Cases
To fix this, go to this site and find the exact version for which we got the error. Click on it once you find the version.
data:image/s3,"s3://crabby-images/e4afc/e4afc8afb140a736b88c38b4e8d24689fd8c691a" alt="Automated Testing With Appium and Python Screenshot 32"
On the next page, we'll download the Chrome driver for Windows.
data:image/s3,"s3://crabby-images/7e948/7e9483f5362bcdd8bc74b525ea444a11bb5710f4" alt="Automated Testing With Appium and Python Screenshot 33"
After that, we need to extract it and put the file in the directory below:
C:\Program Files\Appium Server GUI\resources\app\node_modules\appium\node_modules\appium-chromedriver\chromedriver\win
Running Test Cases
Then, we'll again run the test, and this time we'll have success. Google will be shown on the console.
data:image/s3,"s3://crabby-images/8614f/8614f988bc8e3bba730021c3d1c0e159682680a4" alt="Automated Testing With Appium and Python Screenshot 34"
We can also see on the Appium terminal that the test was performed with success.
data:image/s3,"s3://crabby-images/5aec8/5aec88dd04c71f2dd9476ff3b3b6b83c25ae230d" alt="Automated Testing With Appium and Python Screenshot 34b"
The automated part will be performed on our connected mobile when the Google site is launched, and it'll go away after two seconds.
data:image/s3,"s3://crabby-images/7f05a/7f05ab6afe62a810b620f3241b546ecd3a8abb8f" alt="Automated Testing With Appium and Python Screenshot 36"
Conclusion
In this post, we've learned about Appium, including steps to install it and automated testing through a written test case in Python.
But you can more easily test your apps with Waldo to avoid going through the hassle of installing and configuring all of this while also writing test cases in Python.
Automated E2E tests for your mobile app
Get true E2E testing in minutes, not months.