Android in docker solution with noVNC supported and video recording
Find a file
thelittlefireman f7b30c3129 fix python error when files already exist
related to :
```
  File "/usr/lib/python3.5/runpy.py", line 184, in _run_module_as_main                                                                                                                                 
    "__main__", mod_spec)                                                                                                                                                                              
  File "/usr/lib/python3.5/runpy.py", line 85, in _run_code                                                                                                                                            
    exec(code, run_globals)                                                                                                                                                                            
  File "/root/src/app.py", line 189, in <module>                                                                                                                                                       
    run()                                                                                                                                                                                              
  File "/root/src/app.py", line 178, in run                                                                                                                                                            
    prepare_avd(device, avd_name)                                                                                                                                                                      
  File "/root/src/app.py", line 74, in prepare_avd                                                                                                                                                     
    os.symlink(os.path.join(skin_rsc_path, s), os.path.join(skin_dst_path, s))                                                                                                                         
FileExistsError: [Errno 17] File exists: '/root/devices/skins/galaxy_nexus' -> '/root/platforms/android-25/skins/galaxy_nexus'                                                                         
Traceback (most recent call last):                                                                                                                                                                     
  File "/usr/lib/python3.5/runpy.py", line 184, in _run_module_as_main                                                                                                                                 
    "__main__", mod_spec)                                                                                                                                                                              
  File "/usr/lib/python3.5/runpy.py", line 85, in _run_code                                                                                                                                            
    exec(code, run_globals)                                                                                                                                                                            
  File "/root/src/app.py", line 189, in <module>                                                                                                                                                       
    run()                                                                                                                                                                                              
  File "/root/src/app.py", line 178, in run                                                                                                                                                            
    prepare_avd(device, avd_name)                                                                                                                                                                      
  File "/root/src/app.py", line 74, in prepare_avd                                                                                                                                                     
    os.symlink(os.path.join(skin_rsc_path, s), os.path.join(skin_dst_path, s))                                                                                                                         
FileExistsError: [Errno 17] File exists: '/root/devices/skins/galaxy_nexus' -> '/root/platforms/android-25/skins/galaxy_nexus' 
```
2017-07-28 15:13:45 +02:00
devices Enable Samsung Galaxy S6 2017-03-16 16:33:26 +01:00
docker Using docker-appium as base image 2017-06-14 15:04:19 +02:00
example Refactored 2017-06-02 15:30:51 +02:00
images Cleaned up 2017-05-29 14:34:35 +02:00
src fix python error when files already exist 2017-07-28 15:13:45 +02:00
.gitignore First commit 2016-12-22 14:29:57 +01:00
.travis.yml Use build matrix to speed up build and push processes 2017-04-26 11:42:40 +02:00
docker-compose.yml Cleaned up 2017-05-29 14:34:35 +02:00
LICENSE First commit 2016-12-22 14:29:57 +01:00
MAINTAINERS First commit 2016-12-22 14:29:57 +01:00
README.md All badges in one line 2017-06-29 09:05:56 +02:00
release.sh Automated all steps from PR #12 2017-06-14 15:06:01 +02:00
requirements.txt Downgraded selenium to be able to run E2E Tests 2017-06-02 16:55:51 +02:00
setup.cfg Refactored code, added log and emulator skins 2017-02-27 14:53:48 +01:00
supervisord.conf Renamed log file 2017-04-26 14:19:46 +02:00
travis.sh Use build matrix to speed up build and push processes 2017-04-26 11:42:40 +02:00

Docker-Android

Join the chat at https://gitter.im/butomo1989/docker-android Build Status codecov Codacy Badge

Docker-Android is a docker image built to be used for everything related to mobile website testing and Android project.

Samsung Device Google Device

Purpose

  1. Run UI tests for mobile websites with appium
  2. Build Android project and run unit tests with the latest build-tools
  3. Run UI tests for Android applications with different frameworks (appium, espresso, robotium, etc.)
  4. Run monkey / stress tests
  5. SMS testing

Advantages compare with other docker-android projects

  1. noVNC to see what happen inside docker container
  2. Emulator for different devices / skins, such as Samsung Galaxy S6, LG Nexus 4, HTC Nexus One and more.
  3. Ability to connect to Selenium Grid
  4. Ability to control emulator from outside container by using adb connect
  5. Open source with more features coming (monkey test, support real devices with screen mirroring and video recording)

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
Linux 5.1.1 22 butomo1989/docker-android-x86-5.1.1
Linux 6.0 23 butomo1989/docker-android-x86-6.0
Linux 7.0 24 butomo1989/docker-android-x86-7.0
Linux 7.1.1 25 butomo1989/docker-android-x86-7.1.1
OSX / Windows 5.0.1 21 butomo1989/docker-android-arm-5.0.1
OSX / Windows 5.1.1 22 butomo1989/docker-android-arm-5.1.1
OSX / Windows 6.0 23 butomo1989/docker-android-arm-6.0
OSX / Windows 7.0 24 butomo1989/docker-android-arm-7.0
OSX / Windows 7.1.1 25 butomo1989/docker-android-arm-7.1.1

List of Devices

Type Device Name
Phone Samsung Galaxy S6
Phone Nexus 4
Phone Nexus 5
Phone Nexus One
Phone Nexus S
Tablet Nexus 7

Requirements

Docker is installed in your system.

Quick Start

  1. Run docker-android

    • For Linux OS, please use image name that contains "x86"

      docker run --privileged -d -p 6080:6080 -p 5554:5554 -p 5555:5555 -e DEVICE="Samsung Galaxy S6" --name android-container butomo1989/docker-android-x86-7.1.1
      
    • For OSX and Windows OS, please use image name that contains "arm"

      docker run --privileged -d -p 6080:6080 -p 5554:5554 -p 5555:5555 -e DEVICE="Samsung Galaxy S6" --name android-container butomo1989/docker-android-arm-7.1.1
      
  2. Verify the ip address of docker host.

    • For OSX, you can find out by using following command:

      docker-machine ip default
      
    • For different OS, localhost should work.

  3. Open http://docker-host-ip-address:6080 from web browser.

Run Appium Server

Appium is automation test framework to test mobile website and mobile application, including android. To be able to use appium, you need to run appium-server. You run appium server inside docker-android container by opening port 4723 and passing an environment variable APPIUM=TRUE.

docker run --privileged -d -p 6080:6080 -p 5554:5554 -p 5555:5555 -p 4723:4723 -e DEVICE="Samsung Galaxy S6" -e APPIUM=True --name android-container butomo1989/docker-android-x86-7.1.1

Connect to Selenium Grid

It is also possible to connect appium server that run inside docker-android with selenium grid by passing following environment variables:

  • CONNECT_TO_GRID=True
  • APPIUM_HOST="<host_ip_address>"
  • APPIUM_PORT=<port_number>
  • SELENIUM_HOST="<host_ip_address>"
  • SELENIUM_PORT=<port_number>

To run tests for mobile browser, following parameter can be passed:

  • MOBILE_WEB_TEST=True
docker run --privileged -d -p 6080:6080 -p 4723:4723 -p 5554:5554 -p 5555:5555 -e DEVICE="Samsung Galaxy S6" -e APPIUM=True -e CONNECT_TO_GRID=True -e APPIUM_HOST="127.0.0.1" -e APPIUM_PORT=4723 -e SELENIUM_HOST="172.17.0.1" -e SELENIUM_PORT=4444 -e MOBILE_WEB_TEST=True --name android-container butomo1989/docker-android-x86-7.1.1

Share Volume

If you want to use appium to test UI of your android application, you need to share volume where the APK is located to folder /root/tmp.

docker run --privileged -d -p 6080:6080 -p 4723:4723 -p 5554:5554 -p 5555:5555 -v $PWD/example/sample_apk:/root/tmp -e DEVICE="Nexus 5" -e APPIUM=True -e CONNECT_TO_GRID=True -e APPIUM_HOST="127.0.0.1" -e APPIUM_PORT=4723 -e SELENIUM_HOST="172.17.0.1" -e SELENIUM_PORT=4444 --name android-container butomo1989/docker-android-x86-7.1.1

Docker-Compose

There is example of compose file to run complete selenium grid and docker-android container as nodes. docker-compose version 1.13.0 or higher is required to be able to execute that compose file.

docker-compose up -d

Control android emulator outside container

adb connect <docker-machine-ip-address>:5555

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.
    docker exec -it android-container cat /root/.emulator_console_auth_token
    
    • Access emulator using telnet and login with auth_token
    telnet <docker-machine-ip-address> 5554
    
    • Login with given auth_token from 1.step
    auth <auth_token>
    
    • Send the sms
    sms send <phone_number> <message>
    
  2. Using adb

    docker exec -it android-container adb emu sms send <phone_number> <message>
    
  3. You can also integrate it inside project using adb library.

Troubleshooting

All logs inside container are stored under folder /var/log/supervisor. you can print out log file by using docker exec. Example:

docker exec -it android-container tail -f /var/log/supervisor/docker-android.stdout.log