Writing Appium tests in Kotlin
Kotlin is a modern programming language that focuses on conciseness, clarity, and code safety. Google officially adopted Kotlin by adding support into Android Studio in 2017 and since then has announced it as the preferred language for Android developers at Google I/O 2019. Perhaps your Android app team has incrementally added Kotlin code to your project or have elected to start new Android projects in Kotlin moving forward. Having the app code and UI automation code in the same language helps engineering and QA teams level set on the critical user journeys being tested. I’d like to share the basics of getting started with writing an Appium test in Kotlin. I’ll be using the Google Maps Android app as the target for this example and test on a Google Pixel 3a emulator.
Kotlin is fully compatible with Java so we can fortunately leverage the Appium Java client and JUnit libraries in addition to writing our code in the IntelliJ IDE. IntelliJ has a free community version called IntelliJ IDEA CE, which can be downloaded from their website or via your package manager.
Getting Started
In IntelliJ IDE, navigate to File > New Project. Select Gradle and under Additional Libraries and Frameworks select Kotlin/JVM.
In the Project file view on the left, open the build.gradle file and add the following dependencies:
We will add the Appium tests in the src/test/kotlin project directory.
Right click the kotlin subdirectory and select New > Kotlin File/Class. Create three new classes:
- ProjectCapabilities
- TestBase
- GoogleMapsAndroidTest
We will structure the project in these three classes to make the organization clear. The ProjectCapabilities class will return the Desired Capabilities, TestBase will be a base class for our test for scaffolding the test setup and teardown, and lastly the GoogleMapsAndroidTest class will inherit from our TestBase, use the Desired Capabilities, and contain our test logic.
1. ProjectCapabilities Class
Let’s get started with the ProjectCapabilities class. This class will have a method to return the Desired Capabilities.
Functions and Methods in Kotlin are declared with the “fun” keyword. You can also indicate the function return type with a colon followed by the type. We can make this a static class method by declaring it in a “companion object.” You can create read-only variables with “val” and variables that can be reassigned with “var”.
In this case I am targeting a local Pixel 3a emulator. For the appPackage and appActivity I am specifying the associated values for the Google Maps Android app.
2. TestBase Class
Next, let’s work on our TestBase class. By default classes in Kotlin are implicitly final and can’t be inherited. To make a class inheritable, we’ll mark it with the “open” keyword. In this class we will create property variables for the: driver, capabilities, and WebDriver URL. We’ll provide visibility modifiers to our properties, in this case:
- Protected: Only visible in the class or subclasses
- Private: Only visible in the class
We’ll also mark our Desired Capabilities variable as “open” so it can be overridden from our GoogleMapsAndroidTest class which inherits from the TestBase class.
In addition you can indicate whether a variable can be null. The ability to declare this upfront is a great feature of the Kotlin language because it protects against unexpected NullPointerExceptions from our code. In this case we can indicate that the driver and caps can be null with “?” after the type and and set them to null. Kotlin also supports string interpolation by using the “$” character to interpolate a variable or “${}” to interpolate an expression.
Our TestBase will also have two JUnit annotations: @Before for our setup function and @After for our teardown to perform a driver quit. Our setup function will be straightforward and it will instantiate the driver object. In our teardown function we’ll check to see if the driver object is not null and if so quit our session. Otherwise we will throw an Exception. Kotlin provides a convenience operator for checking for a null condition with “?:”. This is called the Elvis Operator because if you turn your head sideways the question mark character looks like a swoosh of hair and the colon looks like eyes.
Do you see the resemblance now? Haha either way, the source code for the class can be found below and let’s carry on.
3. GoogleMapsAndroidTest Class
Our last class, GoogleMapsAndroidTest will have our test logic. Here we have one test function annotated with the JUnit Test annotation. Our test will be simple and straightforward, we will tap on the Headlines tab button and then scroll down from the list of news articles. Since we will be performing driver actions we’ll need to first ensure the driver is not null. Kotlin provides a way to perform an operation only if the value is not null using the “?” (the safe call operator) together with “let.”
Conclusion
Our work here is done! We can now execute our test and watch it in action.
Congratulations you now have a taste of what it’s like to write an Appium test in Kotlin! You can download the full project source code here.