Reading an environment variable from Android build.gradle

Have you ever had the need to read an external variable like an environment variable from your Android build.gradle file?

On a recent project of mine we needed to enable our QA engineers to specify different login urls (for dev, staging, production, etc) to run our test automation against.  The idea is that they would set a specific environment variable, ‘ANDROIDDOMAIN’ in this case, and our build script would read in this variable and add it to the BuildConfig class, which we then reference via our test.

Below is the code that reads in the environment variable:

As you can see, here we look for the environment variable named ‘ANDROIDDOMAIN’, and if it is present we print it out and return it from this method.

The next code snippet shows how to add the result of the ‘getAndroidDomain()’ call to the BuildConfig class (in this case we add to the BuildConfig debug class:

Now in our test class we can access the ‘TEST_ANDROID_DOMAIN‘ field on this class, like so:

Do you have a better way of doing this?  Let me know!

Kotlin for Android: new project

For this tutorial, I’m going to walk you through a sample project that gets you set up for development in Kotlin for Android, using Android Studio and the Kotlin plugin.

Create a new project

As you would normally do with a Java-based Android application, create a new project in Android Studio by choosing ‘Start a new Android Studio project’:

Start a new Android Studio application
Start a new Android Studio project

or if you already have a project open, go to ‘File > New Project’:

New Project
File > New Project

Give your project a name.  I gave mine the name ‘FirstKotlin’:

First Kotlin
I named mine ‘FirstKotlin’

Choose the defaults on the next screen.  Mine looked like this:

Target Android Devices

On the ‘Add an Activity to Mobile’ dialog, choose ‘Basic Activity’:


On the ‘Customize the Activity’ screen, just leave the defaults:


Click finish to create the project.

Run the application

After your project is created, go ahead and run it to make sure that you have a working application.

running app
running app

Download Kotlin plugin

Pull up Android Studio preferences (Android Studio > Preferences…).  Go to Plugins in the left navigation, and search for ‘Kotlin’.  Install this plugin.

kotlin plugin
kotlin plugin

Modify application build.gradle to add Kotlin plugin as a dependency

Add classpath org.jetbrains.kotlin:kotlin-gradle-plugin:1.0.6 as a dependency to your application’s root build.gradle file.  My full application build.gradle is below:


Modify module build.gradle to apply Kotlin plugin

Add these two lines to your module’s build.gradle.  My module’s build.gradle is found at app/build.gradle:

Full build.gradle is found below:

Convert default to Kotlin

Now here’s the fun part.  Let’s convert the file to Kotlin.  Open the file (mine’s at app/src/main/java/com/devdustin/firstkotlin/  Then, go to Code > Convert Java File to Kotlin File:

convert java to kotlin
convert java to kotlin

Your converted class should look something like this:


Run the application

Now, run your first Kotlin app!

running app
running app

If you get the same result as from before converting your Java file to Kotlin, good job!

Kotlin vs Java analysis

What differences do you notice between Kotlin and Java?

Here are a few to pay particular attention to:

  • Override as a keyword, not an annotation: in Java, the @Override annotation is used to indicate the developer’s intention in overriding a method, and if not properly overridden, will cause a compile time check. But it’s not required (though you’ll likely get a compiler error, depending on the compiler you’re using).  In Kotlin, you are required to use it.
  • Primary and secondary constructors: shown in the class above only as a primary constructor in ‘AppCompatActivity()‘, Kotlin classes have a unique way of handling object construction.  I’ll dig into this more in future posts.
  • Null Safety: one of the goals of the Kotlin type system is to avoid NullPointerException from occurring.  The ‘?’ after Bundle indicates that savedInstanceState could potentially be null.  You can also expect future posts on this topic, as it’s key to understanding Kotlin.
  • ‘fun’ indicates function: Kotlin uses the ‘fun’ keyword to indicate what would be a method in Java.
  • ‘extends’ and ‘implements’ are represented using a colon: very much like C# and other modern languages.
  • Semicolons are optional: though you can add them if you’d like to.
  • Function parameters are written ‘backwards’ compared to Java: they are defined using Pascal notation: name: type, and are separated using commas. A type is required for each parameter.


In this sample Android project you get a taste of what it’s like to develop with Kotlin. The Kotlin plugin for Android Studio includes a great tool for converting Java files to Kotlin, which helps developers ease into developing with Kotlin.

I went over a few language features that are expressed in this simple example.  Future posts will touch more in depth on these and many other Kotlin topics, with an emphasis on Android development.

Genymotion device goes offline after Mac screen locks

Have you ever had your Genymotion device go offline after locking your Mac screen?

After debugging in Android Studio, locking my Macbook Pro screen, and then logging back in, frequently my Genymotion device will show as [OFFLINE] to the Android Studio debugger.  It’s really an inconvenience, as restarting the device and app often take a while.

If so, rather than restart the device  completely, try this from a terminal window:

Give adb a moment to restart, then issue this command:

Once adb has restarted, you’ll see your device listed, like below:



Note: if you get ‘command not found’ after typing ‘adb’, then it must not be on your PATH.  Add ‘ANDROID_HOME/platform-tools’ to your PATH environment variable.  The location of ‘adb’ on my machine (after typing ‘which adb’) is ‘/Users/dustinkendall/Library/Android/sdk/platform-tools/adb’

Hope this helps!