Docker-Android-Appium ===================== [![Build Status](https://travis-ci.org/butomo1989/docker-appium.svg?branch=master)](https://travis-ci.org/butomo1989/docker-appium) [![codecov](https://codecov.io/gh/butomo1989/docker-appium/branch/master/graph/badge.svg)](https://codecov.io/gh/butomo1989/docker-appium) Android emulator and Appium server in docker solution with noVNC supported. Requirements ------------ Docker is installed in your system. Quick Start ----------- 1. Enable **Virtualization** under **System Setup** in **BIOS**. (It is only for Ubuntu OS. If you use different OS, you can skip this step). 2. Run docker-appium with command: ```bash docker run -d -p 6080:6080 -p 4723:4723 -v :/target_apk -e ANDROID_VERSION= -e EMULATOR_TYPE= --name appium-container butomo1989/docker-appium ``` An Example: ```bash docker run -d -p 6080:6080 -p 4723:4723 -v $PWD/example/sample_apk:/target_apk -e ANDROID_VERSION=4.2.2 -e EMULATOR_TYPE=armeabi --name appium-container butomo1989/docker-appium ``` **Note: use flag *--privileged* and *EMULATOR_TYPE=x86* for ubuntu OS to make emulator faster** 2. Verify the ip address of docker-machine. - For OSX, you can find out by using following command: ```bash docker-machine ip default ``` - For different OS, localhost should work. 3. Open ***http://docker-machine-ip-address:6080/vnc.html*** from web browser and connect to it without password. ![][noVNC] 4. Wait until the installation of selected android version packages is done and appium is ready to use by waiting following message shown in Terminal: ![][Appium is ready] *The name of created emulator can be seen in that terminal. In screenshot above, the emulator name is* ***emulator_4.2.2***. 5. Run your UI tests by using docker-appium and Android emulator will be started automatically by following desire capability: ``` desired_caps = { 'avd': 'emulator_4.2.2' } ``` ***Note: In folder "example" there is an example of Appium-UITest that is written in python.*** [noVNC]: "login with noVNC to see what happen inside container" [Appium is ready]: "appium is ready"