docker-android/README.md

123 lines
8 KiB
Markdown
Raw Normal View History

2017-04-04 16:57:55 +01:00
Docker-Android
==============
2016-12-22 13:29:57 +00:00
2016-12-22 13:33:30 +00:00
[![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)
2017-04-04 16:57:55 +01:00
Android in docker solution with noVNC supported
2016-12-22 13:29:57 +00:00
Requirements
------------
Docker is installed in your system.
2017-04-04 16:57:55 +01:00
Purpose
-------
1. Build android project / application and run unit test inside docker-container
2. Run UI Test for mobile website with appium framework
3. Run UI Test for mobile application with different frameworks (appium, espresso, etc.)
Features
--------
2017-03-16 15:33:26 +00:00
1. Android emulator with different devices
2017-04-04 16:57:55 +01:00
2. latest build-tool (version 25.0.2)
3. noVNC to see what happen inside docker container
4. Appium server and it is able to connect with selenium grid
List of Docker images
---------------------
|Supported OS |Android version |API level |Image name |Image status |
|:---|:---|:---|:---|:---:|
|Linux|5.0.1|21|butomo1989/docker-android-x86-5.0.1|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-x86-5.0.1.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-5.0.1 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-x86-5.0.1.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-5.0.1 "Get your own image badge on microbadger.com")|
|Linux|5.1.1|22|butomo1989/docker-android-x86-5.1.1|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-x86-5.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-5.1.1 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-x86-5.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-5.1.1 "Get your own image badge on microbadger.com")|
|Linux|6.0|23|butomo1989/docker-android-x86-6.0|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-x86-6.0.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-6.0 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-x86-6.0.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-6.0 "Get your own image badge on microbadger.com")|
|Linux|7.0|24|butomo1989/docker-android-x86-7.0|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-x86-7.0.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-7.0 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-x86-7.0.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-7.0 "Get your own image badge on microbadger.com")|
|Linux|7.1.1|25|butomo1989/docker-android-x86-7.1.1|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-x86-7.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-7.1.1 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-x86-7.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-x86-7.1.1 "Get your own image badge on microbadger.com")|
|OSX / Windows|5.0.1|21|butomo1989/docker-android-arm-5.0.1|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-arm-5.0.1.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-5.0.1 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-arm-5.0.1.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-5.0.1 "Get your own image badge on microbadger.com")|
|OSX / Windows|5.1.1|22|butomo1989/docker-android-arm-5.1.1|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-arm-5.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-5.1.1 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-arm-5.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-5.1.1 "Get your own image badge on microbadger.com")|
|OSX / Windows|6.0|23|butomo1989/docker-android-arm-6.0|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-arm-6.0.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-6.0 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-arm-6.0.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-6.0 "Get your own image badge on microbadger.com")|
|OSX / Windows|7.0|24|butomo1989/docker-android-arm-7.0|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-arm-7.0.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-7.0 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-arm-7.0.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-7.0 "Get your own image badge on microbadger.com")|
|OSX / Windows|7.1.1|25|butomo1989/docker-android-arm-7.1.1|[![](https://images.microbadger.com/badges/version/butomo1989/docker-android-arm-7.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-7.1.1 "Get your own version badge on microbadger.com") [![](https://images.microbadger.com/badges/image/butomo1989/docker-android-arm-7.1.1.svg)](https://microbadger.com/images/butomo1989/docker-android-arm-7.1.1 "Get your own image badge on microbadger.com")|
2016-12-22 13:29:57 +00:00
Quick Start
-----------
2017-01-23 16:25:21 +00:00
1. Enable **Virtualization** under **System Setup** in **BIOS**. (It is only for Ubuntu OS. If you use different OS, you can skip this step).
2017-04-04 16:57:55 +01:00
2. Run docker-android
2016-12-22 13:29:57 +00:00
2017-04-04 16:57:55 +01:00
```bash
docker run --privileged -d -p 6080:6080 -p 4723:4723 -e DEVICE="Samsung Galaxy S6" -e APPIUM=False --name appium-container butomo1989/docker-android-x86-5.0.1
```
2017-02-28 14:36:43 +00:00
2017-04-04 16:57:55 +01:00
**Optional arguments**
2016-12-22 13:29:57 +00:00
2017-04-04 16:57:55 +01:00
-v <android_project_or_apk>:/root : You need to share volume or apk file if for example you want to build the android project inside docker container or you want to run UI test by using appium.
-e APPIUM=True: If you want to use appium as UI test framework to test mobile website or android application
2016-12-22 13:29:57 +00:00
2017-04-04 16:57:55 +01:00
3. Verify the ip address of docker-machine.
2016-12-22 13:29:57 +00:00
2017-01-08 16:24:38 +00:00
- For OSX, you can find out by using following command:
2016-12-22 13:29:57 +00:00
2017-02-11 22:37:27 +00:00
```bash
docker-machine ip default
```
2016-12-22 13:29:57 +00:00
2017-01-08 16:24:38 +00:00
- For different OS, localhost should work.
2017-04-06 15:29:11 +01:00
4. Open ***http://docker-machine-ip-address:6080*** from web browser.
2017-01-08 16:24:38 +00:00
![][noVNC]
2016-12-22 13:29:57 +00:00
2017-02-28 14:36:43 +00:00
Connect to Selenium Grid
------------------------
2017-04-04 16:57:55 +01:00
This feature can be used only if you set **APPIUM=True** in environment variable.
2017-02-28 14:36:43 +00:00
2017-04-04 16:57:55 +01:00
**Arguments**
2017-02-28 14:36:43 +00:00
2017-04-04 16:57:55 +01:00
-e CONNECT_TO_GRID=True : to connect appium server to your selenium grid.
-e APPIUM_HOST="<host_ip_address>": where / on which instance appium server is running. Default value: 127.0.0.1
-e APPIUM_PORT=<port_number>: which port appium server is running. Default port: 4723
-e SELENIUM_HOST="<host_ip_address>": where / on which instance selenium grid is running. Default value: 172.17.0.1
-e SELENIUM_PORT=<port_number>: which port selenium grid is running. default port: 4444
2017-02-28 14:36:43 +00:00
![][connect to grid 1] ![][connect to grid 2]
List of Devices
---------------
2017-02-28 14:36:43 +00:00
Type | Device Name
--- | ---
2017-03-16 15:33:26 +00:00
Phone | Samsung Galaxy S6
2017-02-28 14:36:43 +00:00
Phone | Nexus 4
Phone | Nexus 5
Phone | Nexus 5x
Phone | Nexus 6
Phone | Nexus 6P
Phone | Nexus One
Phone | Nexus S
Tablet | Pixel C
Tablet | Nexus 7
Tablet | Nexus 9
Tablet | Nexus 10
2017-04-04 16:57:55 +01:00
![][galaxy s6] ![][nexus 5]
2017-02-28 14:36:43 +00:00
Troubleshooting
---------------
All logs inside container are stored under folder **/var/log/supervisor**. you can print out log file by using **docker exec**. Example:
```bash
docker exec -it appium-container tail -f /var/log/supervisor/docker-appium.stdout.log
```
2017-01-08 16:24:38 +00:00
[noVNC]: <images/noVNC.png> "login with noVNC to see what happen inside container"
2017-02-28 14:36:43 +00:00
[connect to grid 1]: <images/appium_with_selenium_grid_01.png>
[connect to grid 2]: <images/appium_with_selenium_grid_02.png>
2017-03-16 15:33:26 +00:00
[galaxy s6]: <images/run_under_galaxy_s6.png>
2017-02-28 14:36:43 +00:00
[nexus 5]: <images/run_under_nexus_5.png>