The Android Emulator, unfortunately, doesn’t work in CircleCI’s conventional (Docker-based) Android build environment. With a little tinkering, though, we can make it work in another environment!
KO Player is an emulator software that allows Android apps run on Mac. This is basically an application to play Android games on your Mac. Android gamers and content creators can benefit largely from this software. You can control the game settings by swiping and tapping the controls as it maps keyboard and mouse commands. Setup Android Emulator on Mac OS X The purpose of this section is to guide you to create in your development environment an Android emulator. Android emulators are managed through a UI called AVD Manager AVD Manager has a nice interface when started from Android Studio. Jun 25, 2021 Mac users can use this Android emulator with strong sensors, including GPS and multi-touch. Platforms: Android, Mac OS, and Microsoft Windows. Price: Free Using PrimeOS is similar to using Mac OS or Windows, and many Android applications can be accessed. This Android emulator blends Android with PC in a complete fusion.
What Doesn’t Work
Since CircleCI 2.0, the recommended build environment for most projects is the Docker Executor. Overall, it’s great: Docker images are fast, portable, and cacheable. Chances are you can start with a prebuilt one.
One of the jobs in our current workflow boots up the circleci/android:api-29-node
image in about four seconds with all the build tools we need. For building and publishing, this is fantastic.
Unfortunately, when you begin configuring your tests, you’ll soon realize that this environment can’t run the Emulator.
Why?
To achieve reasonable performance, the Android Emulator needshardware acceleration, which depends on supporting capabilities from the processor and operating system. We can use the Emulator’s -accel-check
flag to interrogate a system’s compatibility. Here’s what it says in a CircleCI Docker environment:
(That means “no.”)
But wait! Docker is but one of several executors available on CircleCI. What if we use a conventional Linux VM instead of Docker? (This is called the machine executor).
That doesn’t work either. Bummer.
At this point, you might heed CircleCI’s advice and pursue a third-party service like Firebase Test Lab or AWS Device Farm, but I wasn’t ready to give up yet.
What Works
We were already using CircleCI’s MacOS support to build and test our React Native app for iOS. I had one last wacky idea to try: could we run the Android Emulator on MacOS?
It works!
Configuration
Without the convenience of an externally-maintained Docker image, it’s on you to install the Android tools. If you want to try Android testing on MacOS, hopefully our configuration can save you some time:
And here’s install-android-tools.sh
:
Conclusion
It’s unorthodox, but this approach has worked reasonably well so far for our small React Native project. One set of Appium tests can run against both iOS and Android, and they run the same way in CircleCI that they do locally.
I’d be interested to hear about your experiences with Android UI tests in CircleCI, whether via a third-party service, a CI host that supports the Emulator, or another approach altogether.
The purpose of this section is to guide you to create in your development environment an Android emulator.
Android emulators are managed through a UI called AVD Manager
AVD Manager has a nice interface when started from Android Studio.
Start Android Studio app, then create a blank project.
Go to the Tools menu -> :Android -> AVD Manager:
If no emulator has been created you should start with this screen:
Click the Create Virtual Device button.
In the Select Hardware window , select Nexus 5 as shown in the following snapshot:
Click the Next button.
In the System Image, select the system image Nougat, API Level 25 , ABI x86 :
Click on the download link to download the selected System Image. This download process is done through SDK Manager.
Once the download is complete, click on the Next button.
In the Verify Configuration window, check any parameter :
Android Emulator Macbook Air M1
Then click on the Finish button.
AVD Manager shows you the newly created device:
Click on the launch button to launch the newly created AVD in the emulator.
Notice in the Run Window of Android Studio the command line used to start the device:
which can be shortened to :
How to start Android Emulator from Terminal?
Stop the emulator started by Android Studio. Open the Terminal app and type the following command:
Android Mac Transfer
This should start the emulator with the selected AVD.