diff options
author | cyBerta <cyberta@riseup.net> | 2018-02-06 15:05:02 +0100 |
---|---|---|
committer | cyBerta <cyberta@riseup.net> | 2018-02-06 15:05:02 +0100 |
commit | 1a37ac3f86e0bd44842a0fcd86de7c160acfbb04 (patch) | |
tree | bc32fb50b59c415097804fd7bbdb296641310cde /.gitlab/wait-for-emulator.sh | |
parent | a1ac4910f062ca8aca06e0468fffef751d3bb714 (diff) | |
parent | edd34192484f4eb618fdcc2a68b18168c155d63c (diff) |
Merge branch 'origin_0.9.8' into fupduck_8826_custom_provider
Diffstat (limited to '.gitlab/wait-for-emulator.sh')
-rwxr-xr-x | .gitlab/wait-for-emulator.sh | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/.gitlab/wait-for-emulator.sh b/.gitlab/wait-for-emulator.sh new file mode 100755 index 00000000..cd51428a --- /dev/null +++ b/.gitlab/wait-for-emulator.sh @@ -0,0 +1,44 @@ +#!/bin/bash + +# from https://gitlab.com/fdroid/fdroidclient + +sec=0 +timeout=360 + +err() { + echo "$@" + exit 1 +} + +explain() { + if [[ "$1" =~ "not found" ]]; then + printf "device not found" + elif [[ "$1" =~ "offline" ]]; then + printf "device offline" + elif [[ "$1" =~ "running" ]]; then + printf "booting" + else + printf "$1" + fi +} + +while true; do + if [[ $sec -ge $timeout ]]; then + err "Timeout ($timeout seconds) reached - Failed to start emulator" + fi + out=$(adb -e shell getprop init.svc.bootanim 2>&1 | grep -v '^\*') + if [[ "$out" =~ "command not found" ]]; then + err "$out" + fi + if [[ "$out" =~ "stopped" ]]; then + break + fi + let "r = sec % 5" + if [[ $r -eq 0 ]]; then + echo "Waiting for emulator to start: $(explain "$out")" + fi + sleep 1 + let "sec++" +done + +echo "Emulator is ready" |