summaryrefslogtreecommitdiff
path: root/.gitlab/wait-for-emulator.sh
blob: cd51428a6d29aa2ff24ea0d499daa5e28cd574fb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
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"