docker-android/README.md

177 lines
7.1 KiB
Markdown
Raw Permalink Normal View History

2017-04-04 16:57:55 +01:00
Docker-Android
==============
2016-12-22 13:29:57 +00:00
2017-04-12 16:19:03 +01:00
[![Build Status](https://travis-ci.org/butomo1989/docker-android.svg?branch=master)](https://travis-ci.org/butomo1989/docker-android)
[![codecov](https://codecov.io/gh/butomo1989/docker-android/branch/master/graph/badge.svg)](https://codecov.io/gh/butomo1989/docker-android)
2016-12-22 13:33:30 +00:00
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
-------
2017-04-12 13:25:12 +01:00
1. Build android project / application and run unit test
2017-04-04 16:57:55 +01:00
2. Run UI Test for mobile website with appium framework
3. Run UI Test for mobile application with different frameworks (appium, espresso, etc.)
2017-04-12 13:25:12 +01:00
4. Simulate Short Message Service (SMS)
2017-04-04 16:57:55 +01:00
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
2017-04-12 14:39:40 +01:00
4. Appium server for automation test framework and it is able to connect with selenium grid
2017-04-04 16:57:55 +01:00
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/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/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/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")|
2017-04-21 10:23:24 +01:00
|Linux|7.0|24|butomo1989/docker-android-x86-7.0|[![](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")|
2017-04-21 14:06:53 +01:00
|Linux|7.1.1|25|butomo1989/docker-android-x86-7.1.1|[![](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/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/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/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")|
2017-04-21 10:23:24 +01:00
|OSX / Windows|7.0|24|butomo1989/docker-android-arm-7.0|[![](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")|
2017-04-21 14:06:53 +01:00
|OSX / Windows|7.1.1|25|butomo1989/docker-android-arm-7.1.1|[![](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
2017-04-21 14:18:01 +01:00
docker run --privileged -d -p 6080:6080 -p 4723:4723 -p 5554:5554 -p 5555:5555 -e DEVICE="Samsung Galaxy S6" --name android-container butomo1989/docker-android-x86-5.0.1
2017-04-04 16:57:55 +01:00
```
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-21 12:46:04 +01:00
-v <android_project_or_apk>:/root/tmp : 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.
2017-04-04 16:57:55 +01:00
-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-12 13:25:12 +01:00
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-04-12 13:25:12 +01:00
Control android emulator outside container
------------------------------------------
```bash
adb connect <docker-machine-ip-address>:5555
```
![][adb_connection]
**Note:** You need to have Android Debug Bridge (adb) installed in your host machine.
SMS Simulation
--------------
1. Using telnet
- Find the auth_token and copy it.
```bash
docker exec -it android-container cat /root/.emulator_console_auth_token
```
- Access emulator using telnet and login with auth_token
```bash
telnet <docker-machine-ip-address> 5554
```
- Login with given auth_token from 1.step
```bash
auth <auth_token>
```
- Send the sms
```bash
sms send <phone_number> <message>
```
2. Using adb
```bash
docker exec -it android-container adb emu sms send <phone_number> <message>
```
3. You can also integrate it inside project using [adblib].
![][sms]
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
2017-04-12 13:25:12 +01:00
docker exec -it android-container tail -f /var/log/supervisor/docker-appium.stdout.log
2017-02-28 14:36:43 +00:00
```
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>
2017-04-12 13:25:12 +01:00
[adb_connection]: <images/adb_connection.png>
[sms]: <images/SMS.png>
[adblib]: <https://github.com/tananaev/adblib>