From db7f9053b5e6bac5033117561837d64458f1b130 Mon Sep 17 00:00:00 2001 From: Audric Ackermann Date: Thu, 4 Jul 2024 11:51:03 +1000 Subject: [PATCH] feat: add self hosted runner workflow --- .dockerignore | 4 + .github/workflows/android-regression.yml | 24 ++++ .gitignore | 15 ++- Dockerfile | 20 ++++ Dockerfile.base | 119 +++++++++++++++++++ adbkey | 28 +++++ adbkey.pub | 1 + docker/README.md | 56 +++++++++ docker/dl.sh | 13 ++ docker/dl_and_test.sh | 4 + docker/etc/supervisor/conf.d/fluxbox.conf | 3 + docker/etc/supervisor/conf.d/websockify.conf | 3 + docker/etc/supervisor/conf.d/x11vnc.conf | 3 + docker/etc/supervisor/conf.d/xfvb.conf | 3 + docker/etc/supervisor/conf.d/xterm.conf | 3 + docker/etc/supervisord_test.conf | 8 ++ docker/start_4_emus.sh | 17 +++ docker/start_appium.sh | 22 ++++ docker/start_emu.sh | 26 ++++ docker/start_emu_for_state.sh | 12 ++ docker/start_emulators.sh | 58 +++++++++ docker/start_vnc.sh | 88 ++++++++++++++ docker/test.sh | 4 + 23 files changed, 532 insertions(+), 2 deletions(-) create mode 100644 .dockerignore create mode 100644 .github/workflows/android-regression.yml create mode 100644 Dockerfile create mode 100644 Dockerfile.base create mode 100644 adbkey create mode 100644 adbkey.pub create mode 100644 docker/README.md create mode 100644 docker/dl.sh create mode 100644 docker/dl_and_test.sh create mode 100644 docker/etc/supervisor/conf.d/fluxbox.conf create mode 100644 docker/etc/supervisor/conf.d/websockify.conf create mode 100644 docker/etc/supervisor/conf.d/x11vnc.conf create mode 100644 docker/etc/supervisor/conf.d/xfvb.conf create mode 100644 docker/etc/supervisor/conf.d/xterm.conf create mode 100644 docker/etc/supervisord_test.conf create mode 100644 docker/start_4_emus.sh create mode 100644 docker/start_appium.sh create mode 100644 docker/start_emu.sh create mode 100644 docker/start_emu_for_state.sh create mode 100644 docker/start_emulators.sh create mode 100644 docker/start_vnc.sh create mode 100644 docker/test.sh diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000..f314b675 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,4 @@ +README.md +.gitignore +docker-compose.yml +Dockerfile* \ No newline at end of file diff --git a/.github/workflows/android-regression.yml b/.github/workflows/android-regression.yml new file mode 100644 index 00000000..ae85116b --- /dev/null +++ b/.github/workflows/android-regression.yml @@ -0,0 +1,24 @@ +name: Android Regression Tests +on: + workflow_dispatch: + inputs: + APK_URL: + description: 'APK.tar.gz url to test' + type: string + required: true + # COMMIT_HASH: + # description: 'Commit of oxen-io/session-appium to checkout' + # type: string + # required: true + # push: + # branches: + # - test-docker-container + +jobs: + run-tests-android: + runs-on: [self-hosted, linux, x64, qa-android] + steps: + - name: print APK to test + run: echo "APK_URL=${{ inputs.APK_URL }}" + - name: run the tests in the (already running) docker container + run: docker exec --env APK_URL=${{ inputs.APK_URL }} $(docker ps -q) sh -c "dl_and_test" diff --git a/.gitignore b/.gitignore index c8f58663..2424162d 100644 --- a/.gitignore +++ b/.gitignore @@ -17,9 +17,20 @@ apps/ chromeDriver .tmp -run/**/*.js +**/run/**/*.js *.js.map -run/test/specs/to do +run/test/specs/to do to do .vscode/ +!.yarn/patches/*.patch +.yarn/*.gz +*.cjs +*.mjs + +config/local* +config/*.js + + +.eslintcache +avd/* \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 00000000..12085804 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,20 @@ +FROM android-emulator-base + + + +#========================= +# Copying Scripts to root +#========================= + +RUN chmod a+x /session-appium/docker/*.sh +RUN ln -s /session-appium/docker/dl.sh /usr/bin/dl && ln -s /session-appium/docker/test.sh /usr/bin/ci_test && ln -s /session-appium/docker/dl_and_test.sh /usr/bin/dl_and_test + + + +WORKDIR /session-appium + +EXPOSE 8080 + +# COPY avd /root/.android/avd + +ENTRYPOINT [ "/usr/bin/supervisord", "-c", "/etc/supervisord_test.conf", "-n" ] diff --git a/Dockerfile.base b/Dockerfile.base new file mode 100644 index 00000000..f10b7f30 --- /dev/null +++ b/Dockerfile.base @@ -0,0 +1,119 @@ +# syntax=docker.io/docker/dockerfile:1.7-labs + +FROM openjdk:18-ea-11-jdk-slim-bullseye + +LABEL maintainer "Audric Ackermann" + +ENV DEBIAN_FRONTEND noninteractive + +WORKDIR / +#============================= +# Install Dependenices +#============================= +SHELL ["/bin/bash", "-c"] + +RUN apt-get update +RUN apt install -y ca-certificates curl git cpu-checker supervisor vim bash wget unzip xvfb x11vnc fluxbox xterm novnc net-tools htop libpulse-dev libnss3 libxcursor1 libasound2 libqt5gui5 libc++-dev libxcb-cursor0 htop tree tar gzip + + +#============================== +# Android SDK ARGS +#============================== +ARG ARCH="x86_64" +ARG TARGET="google_apis_playstore" +ARG API_LEVEL="34" +ARG BUILD_TOOLS="34.0.0" +ARG ANDROID_ARCH=${ANDROID_ARCH_DEFAULT} +ARG ANDROID_API_LEVEL="android-${API_LEVEL}" +ARG ANDROID_APIS="${TARGET};${ARCH}" +ARG EMULATOR_PACKAGE="system-images;${ANDROID_API_LEVEL};${ANDROID_APIS}" +ARG PLATFORM_VERSION="platforms;${ANDROID_API_LEVEL}" +ARG BUILD_TOOL="build-tools;${BUILD_TOOLS}" +ARG ANDROID_CMD="commandlinetools-linux-11076708_latest.zip" +ARG ANDROID_SDK_PACKAGES="${EMULATOR_PACKAGE} ${PLATFORM_VERSION} ${BUILD_TOOL} platform-tools" + +#============================== +# Set JAVA_HOME - SDK +#============================== +ENV ANDROID_SDK_ROOT=/opt/android +ENV PATH "$PATH:$ANDROID_SDK_ROOT/cmdline-tools/tools:$ANDROID_SDK_ROOT/cmdline-tools/tools/bin:$ANDROID_SDK_ROOT/emulator:$ANDROID_SDK_ROOT/tools/bin:$ANDROID_SDK_ROOT/latform-tools:$ANDROID_SDK_ROOT/build-tools/${BUILD_TOOLS}:$ANDROID_SDK_ROOT/platform-tools/" +ENV DOCKER="true" + +#============================================ +# Install required Android CMD-line tools +#============================================ +RUN wget https://dl.google.com/android/repository/${ANDROID_CMD} -P /tmp && \ + unzip -d $ANDROID_SDK_ROOT /tmp/$ANDROID_CMD && \ + mkdir -p $ANDROID_SDK_ROOT/cmdline-tools/tools && cd $ANDROID_SDK_ROOT/cmdline-tools && mv NOTICE.txt source.properties bin lib tools/ && \ + cd $ANDROID_SDK_ROOT/cmdline-tools/tools && ls + +#============================================ +# Install required package using SDK manager +#============================================ +RUN yes Y | sdkmanager --licenses +RUN yes Y | sdkmanager --verbose --no_https ${ANDROID_SDK_PACKAGES} + +#============================================ +# Create required emulators +#============================================ +RUN adb devices # keep this one to make sure adb is initialized (and creates a dummy adbkey, then erase it) +RUN rm /root/.android/adbkey +COPY adbkey /root/.android/adbkey +COPY adbkey.pub /root/.android/adbkey.pub +RUN chmod 600 /root/.android/adbkey +RUN chmod 644 /root/.android/adbkey.pub +RUN adb devices + +ARG EMULATOR_NAME="emulator1" +ARG EMULATOR_DEVICE="pixel_6" # all emulators are created with the pixel 6 spec for now + +RUN yes | sdkmanager emulator +RUN echo "no" | avdmanager --verbose create avd --force --name "${EMULATOR_NAME}" --device "${EMULATOR_DEVICE}" --package "${EMULATOR_PACKAGE}" + +#========================== +# Install node & yarn berry +#========================== + +RUN curl -sL https://deb.nodesource.com/setup_18.x | bash && \ + apt-get -qqy install nodejs && npm install -g yarn && corepack enable && \ + yarn set version 4.1.1 + + +# Install websokify and noVNC +RUN curl -O https://bootstrap.pypa.io/get-pip.py && \ + python3 get-pip.py && \ + pip3 install --no-cache-dir \ + setuptools && \ + pip3 install -U https://github.com/novnc/websockify/archive/refs/tags/v0.11.0.tar.gz + +RUN wget -O x11vnc.zip https://github.com/x11vnc/noVNC/archive/refs/heads/x11vnc.zip && \ + unzip x11vnc.zip && mv noVNC-x11vnc /usr/local/noVNC/ && ls -la /usr/local/noVNC/utils && \ + (chmod a+x /usr/local/noVNC/utils/launch.sh || \ + (chmod a+x /usr/local/noVNC/utils/novnc_proxy && \ + ln -s -f /usr/local/noVNC/utils/novnc_proxy /usr/local/noVNC/utils/launch.sh)) && \ + rm -rf /tmp/* /var/tmp/* + + +ENV HOME=/root \ + DEBIAN_FRONTEND=noninteractive \ + LANG=en_US.UTF-8 \ + LANGUAGE=en_US.UTF-8 \ + LC_ALL=C.UTF-8 \ + DISPLAY=:0.0 \ + DISPLAY_WIDTH=1920 \ + DISPLAY_HEIGHT=900 \ + RUN_XTERM=yes \ + RUN_FLUXBOX=yes + + +#========================== +# copy the appium current folder +#========================== + +COPY --exclude="node_modules" --exclude="avd" --exclude=".git" --exclude="etc" --exclude="config/local*" ./ /session-appium + + +COPY docker/etc /etc + + +EXPOSE 8080 \ No newline at end of file diff --git a/adbkey b/adbkey new file mode 100644 index 00000000..2159b95e --- /dev/null +++ b/adbkey @@ -0,0 +1,28 @@ +-----BEGIN PRIVATE KEY----- +MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQDGvv6TARgHpm86 +ROYUGk7YJ0AT7A61Sa74YaNz2IiE8nqECpEQ25NJyg0jZluXSb99XEAFjVDOGswh +nJtsrFmG0IEQh9kiQuLOVcyW5pxLiwoRaQgdcUlrocwe/HPkdQ6FbFqm+m9v8wJ3 +6zqLp6dm3xPpIdfp11ZTvPb1uRTEXF7ciRzq1I25h7spDXVJcA4yECooD4gvWUrd +FqoxL88pn/9MVjqKYQYUeC+pUbwkdm5fn4jWBcP5zFVB2fvzup9R3C0D1vuN2V5Z +Ef9P+XjJw9TUfKTQxzAHfQsHhkau5SGut+UCwpdSn9wDcgFpQhby4rAcPN1IFshD +/BYxwfM/AgMBAAECggEAHX+3ysX8yms6UyHALKJYVYjt39xyX8IXWv0oWkd8wTmO +/w46czrED8289CYl2Ly01BHfMXPE10fu8zDgI4R+p/NGqizKXmV4beZvlBjtKzab +QJ5K+rkX4VvbL4uKVWcdHVH0hULioMZ8SqRQGkPA0GoH9dsfcFvqj59FNeT0tM2Q +oCPg4wuEhQdSSmBGHyDH1B7vPMJJ5i9Rqe2+hT8WMhIvlAdDVpA3AY9xpg2PsBYb +JSMhjbeQz5OoHSsfw6+KsQcKoA2xqnwFDUz5VtnWhnUvarVbBfPZ+LJ30NB8oz3M +i/vt7qs2BKr1Eo36cQuVtskDnq7jHbXFOXnYiUCuIQKBgQDvai3CSftMW/GEMh91 +FCY9+2TtrFQHz92bqY4EEo11mCGOXiU06U15KXuONz4ntTCoPjk/+e0+iQ0G05dT +P+zHTwiAcMkVE7NpaReArowD+xV4Bax0pLq6QYSE9/uzy4OJlrTVsGrklfAUMvsk +Sg06zgBUBPY9fIR8P/qqkiNguQKBgQDUg5cjWsfTtkx9oGHxanYSZ6b0YZXQnJP8 +/5S1RSNtEMX2yyq9b5Nyn7BrDTaSTa3fGXY//qXMOOOZArYvrDmu8MwsiW5jUrca +C6n2qTRCHKQ1DbWhy2etx7+zAzL8V1e0S18Rf8ESw63SgxkYIlQs6WwhZKLhpMYH +wAZ9mIjHtwKBgQDpmGfdUeHnty4HFgCrc2V8xHTNkX7LwH0xDFaMkq2DN1RGXIVh +AuGcfmUXdb8nbxpyjYO+cFSS15XmOz1C9PRJ40sgRutrrTU4fFl6LNRgbfOcj6yc +gr3OTW7Hbk4gN0m4TVtTxDYHomQE0VlJJxeRcL3RPKYliACcWrBxDPWHwQKBgGPZ +5ITHHccbC7unRP3SwOGK9EY1J9haCarBR9UYRDn1vJ5l/ZH+v/AGmjTig3agqwZ9 +hzMwaiSXwlDdlk62BHBvUe/HLyfZ8JB7VIPCIvzBSmJnK6V21iMwDKGG6kjonRvo +oiWtukEf0idsU7kkQBrOHnFeQK325tkzX5lZt0LnAoGBAN+ZocRrObAYtaZ9AB5h +imN+fX2tm07UbkHiIlADlVINI9X26PkzkZHUzuAoniWh+ScxBlLzA80IR8BfbK5Y +Lq6oiVq7P627938L4hQV6z0OyijV+xkz5zJG61KClbd6dUJXS0fx4ZxuD5EP8y0D +M/SZ1KBz7Vg/LLeSpdVbqDnM +-----END PRIVATE KEY----- diff --git a/adbkey.pub b/adbkey.pub new file mode 100644 index 00000000..d186e4e0 --- /dev/null +++ b/adbkey.pub @@ -0,0 +1 @@ +QAAAAEGDuHc/88ExFvxDyBZI3TwcsOLyFkJpAXID3J9Sl8IC5beuIeWuRoYHC30HMMfQpHzU1MPJePlP/xFZXtmN+9YDLdxRn7rz+9lBVcz5wwXWiJ9fbnYkvFGpL3gUBmGKOlZM/58pzy8xqhbdSlkviA8oKhAyDnBJdQ0pu4e5jdTqHIncXlzEFLn19rxTVtfp1yHpE99mp6eLOut3AvNvb/qmWmyFDnXkc/wezKFrSXEdCGkRCotLnOaWzFXO4kIi2YcQgdCGWaxsm5whzBrOUI0FQFx9v0mXW2YjDcpJk9sQkQqEevKEiNhzo2H4rkm1DuwTQCfYThoU5kQ6b6YHGAGT/r7G4qMNYnPnzAoCHKvL7n1oNNGqrbRETN3blNtQfjzzoCAZMIE+1gAK9BMaJu2gdsn8py1Ri8wejmcwL6/1eXtjrEVXByMQh8Tv4WcgMkQQzdjkafuwOxZaLVvlCqZvSgPpCpBKPgnvRSTlQJt185/k0D+lBocKUZNQ84QDLfQhV+0+uBssaUGc9lNcXDtHC1DvhmR9gThAAJqvazHMoskprLoLqySWqAgVJs3x/bsWJhy8Cnslfx5nGk3EG3wpVrjuc9lwauFEHef/5x1M4+Ofag+iVIqoscjMKNq8TIXl0APfgm6c4CF41poUhQccfAJ2tOaSm7txfnpRiUBh4wzoHAEAAQA= @buildkitsandbox \ No newline at end of file diff --git a/docker/README.md b/docker/README.md new file mode 100644 index 00000000..7e34362b --- /dev/null +++ b/docker/README.md @@ -0,0 +1,56 @@ +### Build the base image without the adb in it + +**This has to be done once on each computers you use this docker, and if you ever change the Dockerfile.base settings related to the avd.** + +Comment this line in the Dockerfile: +`COPY avd /root/.android/avd` + +then run build both docker images (base and test one) so you can manually build a snapshot for your avds. (step 1) +```sh +clear; sudo docker build -t android-emulator-base -f Dockerfile.base . && sudo docker build -t android-emulator -f Dockerfile . && sudo docker run --privileged -it --device /dev/kvm -p 8080:8080 android-emulator +``` + +Once that's done, open a browser to http://localhost:8080/vnc.html, you should see the novnc connect button. +Connect, and in the terminal opened, enter this (copy/paste doesn't work for now) +``` +./docker/start_emu_for_state.sh +``` + +Let the emulator start, and give it a few more minutes so the snapshot is as complete as possible. +Then, close manually the emulator, it should display the "saving state" dialog. +Once the state is saved, do on a host terminal from the root of the `appium` folder: +``` +sudo rm -rf avd; sudo docker cp $(sudo docker ps -q):/root/.android/avd/ ./avd # sudo docker ps -q returns the running container hash directly +``` + + +Once that's done, stop the current docker container (ctrl-c should be enough). + +Then, uncomment the line +``` +COPY avd /root/.android/avd +``` + +in the Dockerfile, and rebuild the 2 images +``` +clear; sudo docker build -t android-emulator-base -f Dockerfile.base . && sudo docker build -t android-emulator -f Dockerfile . # (step 1) +``` +Once that's done, you can start the docker with the apk to test with + +``` +sudo docker run --privileged -it --device /dev/kvm -e APK_URL='' -e NODE_CONFIG_ENV="ci" -e APK_TO_TEST_PATH="/session.apk" -p 8080:8080 android-emulator # (step 2) +``` + +Then, reconnect via vnc http://localhost:8080/vnc.html, and run in the terminal +``` +./docker/start_4_emus.sh & +``` +The 4 emulators should start hopefully not too slowly. + +You can then trigger the dl of the APK (from the APK_TO_TEST_PATH env variable above) and the integration tests by running the command +`dl_and_test` + + +### Daily use + +No need to rebuild the avds every time you use the docker image/start integration tests, but you will have to rebuild both docker images after a `git pull` the session-appium repository (i.e. updating the integration tests themselves). That step should be very fast though, as everything should be cached by docker. I usually just have one big command to rebuild the changes and restart the container. \ No newline at end of file diff --git a/docker/dl.sh b/docker/dl.sh new file mode 100644 index 00000000..6ca1f2c2 --- /dev/null +++ b/docker/dl.sh @@ -0,0 +1,13 @@ +#!/bin/bash + +set -ex + +echo "APK_URL: $APK_URL" +apk_url=${APK_URL} +apk_saved_on=${APK_TO_TEST_PATH} + +cd / +wget -O /session.apk.tar.xz $apk_url +tar xvf /session.apk.tar.xz +mv /session*/*.apk /session.apk +cd - diff --git a/docker/dl_and_test.sh b/docker/dl_and_test.sh new file mode 100644 index 00000000..ab5c1683 --- /dev/null +++ b/docker/dl_and_test.sh @@ -0,0 +1,4 @@ +#!/bin/bash +set -ex + +/session-appium/docker/dl.sh && /session-appium/docker/test.sh \ No newline at end of file diff --git a/docker/etc/supervisor/conf.d/fluxbox.conf b/docker/etc/supervisor/conf.d/fluxbox.conf new file mode 100644 index 00000000..b301a332 --- /dev/null +++ b/docker/etc/supervisor/conf.d/fluxbox.conf @@ -0,0 +1,3 @@ +[program:fluxbox] +command=fluxbox +autorestart=true \ No newline at end of file diff --git a/docker/etc/supervisor/conf.d/websockify.conf b/docker/etc/supervisor/conf.d/websockify.conf new file mode 100644 index 00000000..fbbd0301 --- /dev/null +++ b/docker/etc/supervisor/conf.d/websockify.conf @@ -0,0 +1,3 @@ +[program:websockify] +command=websockify --web /usr/share/novnc 8080 localhost:5900 +autorestart=true \ No newline at end of file diff --git a/docker/etc/supervisor/conf.d/x11vnc.conf b/docker/etc/supervisor/conf.d/x11vnc.conf new file mode 100644 index 00000000..4b045796 --- /dev/null +++ b/docker/etc/supervisor/conf.d/x11vnc.conf @@ -0,0 +1,3 @@ +[program:x11vnc] +command=x11vnc -forever -shared +autorestart=true \ No newline at end of file diff --git a/docker/etc/supervisor/conf.d/xfvb.conf b/docker/etc/supervisor/conf.d/xfvb.conf new file mode 100644 index 00000000..08d35fcb --- /dev/null +++ b/docker/etc/supervisor/conf.d/xfvb.conf @@ -0,0 +1,3 @@ +[program:xvfb] +command=Xvfb :0 -screen 0 "%(ENV_DISPLAY_WIDTH)s"x"%(ENV_DISPLAY_HEIGHT)s"x24 -listen tcp -ac +autorestart=true \ No newline at end of file diff --git a/docker/etc/supervisor/conf.d/xterm.conf b/docker/etc/supervisor/conf.d/xterm.conf new file mode 100644 index 00000000..9cd92be0 --- /dev/null +++ b/docker/etc/supervisor/conf.d/xterm.conf @@ -0,0 +1,3 @@ +[program:xterm] +command=xterm +autorestart=true \ No newline at end of file diff --git a/docker/etc/supervisord_test.conf b/docker/etc/supervisord_test.conf new file mode 100644 index 00000000..e400e38a --- /dev/null +++ b/docker/etc/supervisord_test.conf @@ -0,0 +1,8 @@ +[supervisord] +nodaemon = false +user = root +loglevel = info + + +[include] +files = /etc/supervisor/conf.d/fluxbox.conf /etc/supervisor/conf.d/websockify.conf /etc/supervisor/conf.d/x11vnc.conf /etc/supervisor/conf.d/xfvb.conf /etc/supervisor/conf.d/xterm.conf \ No newline at end of file diff --git a/docker/start_4_emus.sh b/docker/start_4_emus.sh new file mode 100644 index 00000000..1674a58b --- /dev/null +++ b/docker/start_4_emus.sh @@ -0,0 +1,17 @@ +#!/bin/bash + +set -ex + +DIR="$(cd "$(dirname "$0")" && pwd)" + +start_emu=$DIR/start_emu.sh + +adb devices + +export EMULATOR_NAME="emulator1" # they all share the same avd, but started with the -read-only flag to make it work +DEVICE_NAME="emulator-5554" nice ionice $start_emu & +DEVICE_NAME="emulator-5556" nice ionice $start_emu & +DEVICE_NAME="emulator-5558" nice ionice $start_emu & +DEVICE_NAME="emulator-5560" nice ionice $start_emu & + +wait # wait for the 4 emulators above to be started diff --git a/docker/start_appium.sh b/docker/start_appium.sh new file mode 100644 index 00000000..89606656 --- /dev/null +++ b/docker/start_appium.sh @@ -0,0 +1,22 @@ +#!/bin/bash + +BL='\033[0;34m' +G='\033[0;32m' +RED='\033[0;31m' +YE='\033[1;33m' +NC='\033[0m' # No Color + +function start_appium () { + if [ "$APPIUM_PORT" == "" ] || [ "$APPIUM_PORT" == null ]; + then + printf "${G}==> ${YE}No port provided, instance will run on 4723 ${G}<==${NC}""\n" + sleep 0.5 + appium + else + printf "${G}==> ${BL}Instance will run on ${YE}${APPIUM_PORT} ${G}<==${NC}""\n" + sleep 0.5 + appium -p $APPIUM_PORT + fi +}; + +start_appium \ No newline at end of file diff --git a/docker/start_emu.sh b/docker/start_emu.sh new file mode 100644 index 00000000..a7f8ae4e --- /dev/null +++ b/docker/start_emu.sh @@ -0,0 +1,26 @@ +#!/bin/bash +set -ex + +BL='\033[0;34m' +G='\033[0;32m' +RED='\033[0;31m' +YE='\033[1;33m' +NC='\033[0m' # No Color + +emulator_name=${EMULATOR_NAME} +device_name=${DEVICE_NAME} + +function start_emulator() { + emulator -avd "${emulator_name}" -read-only -gpu off + printf "${G}==> ${BL}Emulator has ${YE}${EMULATOR_NAME} ${BL}started in headed mode! ${G}<==${NC}""\n" +} + +function disable_animation() { + adb -s ${device_name} shell "settings put global window_animation_scale 0.0" + adb -s ${device_name} shell "settings put global transition_animation_scale 0.0" + adb -s ${device_name} shell "settings put global animator_duration_scale 0.0" +} + +start_emulator +sleep 1 +disable_animation \ No newline at end of file diff --git a/docker/start_emu_for_state.sh b/docker/start_emu_for_state.sh new file mode 100644 index 00000000..67e0fb27 --- /dev/null +++ b/docker/start_emu_for_state.sh @@ -0,0 +1,12 @@ +#!/bin/bash +set -x + +emulator_name="emulator1" + +function start_emulator_for_state() { + rm -rf /root/.android/avd/emulator1.avd/snapshots/ # delete any saved snapshots + nohup emulator -avd "${emulator_name}" -gpu off -no-snapshot-load & # no -read only flag here + printf "==> Emulator ${emulator_name} has started IN HEADED mode! \n" +} + +start_emulator_for_state diff --git a/docker/start_emulators.sh b/docker/start_emulators.sh new file mode 100644 index 00000000..628f5383 --- /dev/null +++ b/docker/start_emulators.sh @@ -0,0 +1,58 @@ +#!/bin/bash + +set -ex + +DIR="$(cd "$(dirname "$0")" && pwd)" + +start_emu=$DIR/start_emu.sh + +adb devices + +function wait_emulator_to_be_ready() { + to_wait_for="${1}" + start_time=$(date +%s) + timeout=200 + sleep_interval=1 + printf "==> Waiting booted emulator ... \n" + + while [ "`adb -s ${to_wait_for} shell getprop sys.boot_completed | tr -d '\r' `" != "1" ] ; do + adb devices + current_time=$(date +%s) + elapsed_time=$((current_time - start_time)) + if [ $elapsed_time -gt $timeout ]; then + printf "==> Timeout after ${timeout} seconds elapsed .. \n" + break + fi + printf "==> Emulator not reported as booted yet ... sleeping ${sleep_interval} before retry\n" + sleep $sleep_interval; + done + + if [ "`adb -s ${to_wait_for} shell getprop sys.boot_completed | tr -d '\r' `" == "1" ] ; then + printf "==> Emulator is booted! \n" + fi +} + +export EMULATOR_NAME="emulator1" # they all share the same avd, but started with the -read-only flag to make it work +DEVICE_NAME="emulator-5554" $start_emu & +sleep 1 +DEVICE_NAME="emulator-5556" $start_emu & +sleep 1 +DEVICE_NAME="emulator-5558" $start_emu & +sleep 1 +DEVICE_NAME="emulator-5560" $start_emu & +sleep 1 + +sleep 30; +adb devices;sleep 30; +adb devices;sleep 30; +adb devices;sleep 30; +adb devices;sleep 30; +adb devices;sleep 30; +adb devices;sleep 30; +adb devices; +# wait_emulator_to_be_ready "emulator-5554" +# wait_emulator_to_be_ready "emulator-5556" +# wait_emulator_to_be_ready "emulator-5558" +# wait_emulator_to_be_ready "emulator-5560" + +# wait # hang in here while the emulators are running diff --git a/docker/start_vnc.sh b/docker/start_vnc.sh new file mode 100644 index 00000000..33d581d8 --- /dev/null +++ b/docker/start_vnc.sh @@ -0,0 +1,88 @@ +#!/bin/bash + +readonly G_LOG_I='[INFO]' +readonly G_LOG_W='[WARN]' +readonly G_LOG_E='[ERROR]' +BL='\033[0;34m' +G='\033[0;32m' +NC='\033[0m' # No Color + +main() { + launch_xvfb + launch_window_manager + run_vnc_server + printf "${G}==> ${BL}Welcome to android-emulator VNC by amrsa ${G}<==${NC}""\n" +} + +launch_xvfb() { + # Set defaults if the user did not specify envs. + export DISPLAY=${XVFB_DISPLAY:-:1} + local screen=${XVFB_SCREEN:-0} + local resolution=${XVFB_RESOLUTION:-1280x1024x24} + local timeout=${XVFB_TIMEOUT:-5} + + # Start and wait for either Xvfb to be fully up or we hit the timeout. + Xvfb ${DISPLAY} -screen ${screen} ${resolution} & + local loopCount=0 + until xdpyinfo -display ${DISPLAY} > /dev/null 2>&1 + do + loopCount=$((loopCount+1)) + sleep 1 + if [ ${loopCount} -gt ${timeout} ] + then + echo "${G_LOG_E} xvfb failed to start." + exit 1 + fi + done +} + +launch_window_manager() { + local timeout=${XVFB_TIMEOUT:-5} + + # Start and wait for either fluxbox to be fully up or we hit the timeout. + fluxbox & + local loopCount=0 + until wmctrl -m > /dev/null 2>&1 + do + loopCount=$((loopCount+1)) + sleep 1 + if [ ${loopCount} -gt ${timeout} ] + then + echo "${G_LOG_E} fluxbox failed to start." + exit 1 + fi + done +} + +run_vnc_server() { + local passwordArgument='-nopw' + + if [ -n "${VNC_PASSWORD}" ] + then + local passwordFilePath="${HOME}/x11vnc.pass" + if ! x11vnc -storepasswd "${VNC_PASSWORD}" "${passwordFilePath}" + then + echo "${G_LOG_E} Failed to store x11vnc password." + exit 1 + fi + passwordArgument=-"-rfbauth ${passwordFilePath}" + echo "${G_LOG_I} The VNC server will ask for a password." + else + echo "${G_LOG_W} The VNC server will NOT ask for a password." + fi + + x11vnc -ncache_cr -display ${DISPLAY} -forever ${passwordArgument} & + wait $! +} + + +control_c() { + echo "" + exit +} + +trap control_c SIGINT SIGTERM SIGHUP + +main + +exit \ No newline at end of file diff --git a/docker/test.sh b/docker/test.sh new file mode 100644 index 00000000..d295b4a9 --- /dev/null +++ b/docker/test.sh @@ -0,0 +1,4 @@ +#!/bin/bash +set -ex + +cd /session-appium && yarn install --immutable && yarn tsc && yarn test-no-retry "" \ No newline at end of file