| #!/usr/bin/env bash |
| # Copyright 2014 The Go Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style |
| # license that can be found in the LICENSE file. |
| |
| # For testing Android. |
| # The compiler runs locally, then a copy of the GOROOT is pushed to a |
| # target device using adb, and the tests are run there. |
| |
| set -e |
| ulimit -c 0 # no core files |
| |
| if [ ! -f make.bash ]; then |
| echo 'androidtest.bash must be run from $GOROOT/src' 1>&2 |
| exit 1 |
| fi |
| |
| if [ -z $GOOS ]; then |
| export GOOS=android |
| fi |
| if [ "$GOOS" != "android" ]; then |
| echo "androidtest.bash requires GOOS=android, got GOOS=$GOOS" 1>&2 |
| exit 1 |
| fi |
| |
| export CGO_ENABLED=1 |
| |
| # Run the build for the host bootstrap, so we can build go_android_exec. |
| # Also lets us fail early before the (slow) adb push if the build is broken. |
| ./make.bash |
| export GOROOT=$(dirname $(pwd)) |
| export PATH=$GOROOT/bin:$PATH |
| GOOS=$GOHOSTOS GOARCH=$GOHOSTARCH go build \ |
| -o ../bin/go_android_${GOARCH}_exec \ |
| ../misc/android/go_android_exec.go |
| |
| # Push GOROOT to target device. |
| # |
| # The adb sync command will sync either the /system or /data |
| # directories of an android device from a similar directory |
| # on the host. We copy the files required for running tests under |
| # /data/local/tmp/goroot. The adb sync command does not follow |
| # symlinks so we have to copy. |
| export ANDROID_PRODUCT_OUT=/tmp/androidtest-$$ |
| FAKE_GOROOT=$ANDROID_PRODUCT_OUT/data/local/tmp/goroot |
| mkdir -p $FAKE_GOROOT |
| mkdir -p $FAKE_GOROOT/pkg |
| cp -a "${GOROOT}/src" "${FAKE_GOROOT}/" |
| cp -a "${GOROOT}/test" "${FAKE_GOROOT}/" |
| cp -a "${GOROOT}/lib" "${FAKE_GOROOT}/" |
| cp -a "${GOROOT}/pkg/android_$GOARCH" "${FAKE_GOROOT}/pkg/" |
| echo '# Syncing test files to android device' |
| time adb sync data &> /dev/null |
| echo '' |
| rm -rf "$ANDROID_PRODUCT_OUT" |
| |
| # Run standard build and tests. |
| ./all.bash --no-clean |