mirror of
https://github.com/golang/go
synced 2024-11-22 16:04:40 -07:00
eb5bf55496
The lldb child process is killed if a test runs too long. Also kill it when the setup times out (and is retried). Might help with builder flakes where all 5 attempts to start up lldb fail even though the tests before and after the timeouts succeed. For example: ... ok vendor/golang_org/x/net/route 37.797s lldb setup error: command timeout (lldb start for 17s) start timeout, trying again lldb setup error: command timeout (lldb start for 17s) start timeout, trying again lldb setup error: command timeout (lldb start for 17s) start timeout, trying again lldb setup error: command timeout (lldb start for 17s) start timeout, trying again lldb setup error: command timeout (lldb start for 17s) go_darwin_arm_exec: failed to start test harness (retry attempted) FAIL vendor/golang_org/x/text/transform 115.185s ok vendor/golang_org/x/text/unicode/norm 122.773s ... Change-Id: I6638860522896491dccfa12f1e520c0f23df6d66 Reviewed-on: https://go-review.googlesource.com/67791 Run-TryBot: Elias Naur <elias.naur@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org> |
||
---|---|---|
.. | ||
clangwrap.sh | ||
detect.go | ||
go_darwin_arm_exec.go | ||
README |
Go on iOS ========= To build a cross compiling toolchain for iOS on OS X, first modify clangwrap.sh in misc/ios to match your setup. And then run: GOARM=7 CGO_ENABLED=1 GOARCH=arm CC_FOR_TARGET=`pwd`/../misc/ios/clangwrap.sh \ CXX_FOR_TARGET=`pwd`/../misc/ios/clangwrap.sh ./make.bash To build a program, use the normal go build command: CGO_ENABLED=1 GOARCH=arm go build import/path To run a program on an iDevice, first make sure you have a valid developer certificate and have setup your iDevice properly to run apps signed by your developer certificate. Then install https://github.com/phonegap/ios-deploy. At a first step, you can try building the famous hello world program to run on your test device. (The needed files are provided at https://github.com/minux/go-ios-examples.) # assume your program binary is helloworld.go, build it into the # example hello.app bundle. CGO_ENABLED=1 GOARCH=arm go build -o hello.app/hello helloworld.go # sign the executable using your developer certificate codesign -f -s "iPhone Developer" --entitlements hello.app/Entitlements.plist hello.app/hello # run the program inside lldb on iDevice, run `ios-deploy` for more # command options ios-deploy --debug --uninstall --bundle hello.app # Depending on your ios-deploy version, you might need to enter "run" # into lldb to run your program, and its output will be shown by lldb. Notes: - A dummy hello.app bundle is provided in this directory to help you get started. - Running the program on an iDevice requires code sign and thus external linking, if your program uses cgo, then it will automatically use external linking. However, if your program does not use cgo, please make sure to add import _ "runtime/cgo" so that external linking will be used. Known issues ============ - crypto/x509 won't build, I don't yet know how to get system root on iOS. - Because I still want to be able to do native build, CGO_ENABLED=1 is not the default, yet.