File: emulator-wait-for-ready.sh

package info (click to toggle)
llvm-toolchain-18 1%3A18.1.8-18
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,908,340 kB
  • sloc: cpp: 6,667,937; ansic: 1,440,452; asm: 883,619; python: 230,549; objc: 76,880; f90: 74,238; lisp: 35,989; pascal: 16,571; sh: 10,229; perl: 7,459; ml: 5,047; awk: 3,523; makefile: 2,987; javascript: 2,149; xml: 892; fortran: 649; cs: 573
file content (30 lines) | stat: -rwxr-xr-x 1,207 bytes parent folder | download | duplicates (10)
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
#!/usr/bin/env bash
#===----------------------------------------------------------------------===##
#
# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
# See https://llvm.org/LICENSE.txt for license information.
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
#
#===----------------------------------------------------------------------===##

set -ex

# Time to wait in seconds. The emulator ought to start in 5-15 seconds or so,
# so add a safety factor in case something takes longer in CI.
TIMEOUT=${1-300}

# This syntax (using an IP address of 127.0.0.1 rather than localhost) seems to
# prevent the adb client from ever spawning an adb host server.
export ADB_SERVER_SOCKET=tcp:127.0.0.1:5037

# Invoke nc first to ensure that something is listening to port 5037. Otherwise,
# invoking adb might fork an adb server.
#
# TODO: Consider waiting for `adb shell getprop dev.bootcomplete 2>/dev/null
# | grep 1 >/dev/null` as well. It adds ~4 seconds to 21-def-x86 and ~15 seconds
# to 33-goog-x86_64 and doesn't seem to be necessary for running libc++ tests.
timeout ${TIMEOUT} bash -c '
until (nc -z localhost 5037 && adb wait-for-device); do
    sleep 0.5
done
'