diff options
author | Till Höppner | 2016-02-23 17:00:53 +0100 |
---|---|---|
committer | Till Höppner | 2016-02-24 18:21:24 +0100 |
commit | e866dceae987acd51d43bd457351bd2188c5f95a (patch) | |
tree | 2cc5a67492bdf00ff68041656a1e870b2b4de17f /ci/script.sh | |
parent | 815f31f5cef61709c50087c9f7601ea330929bb7 (diff) | |
download | ilc-e866dceae987acd51d43bd457351bd2188c5f95a.tar.gz ilc-e866dceae987acd51d43bd457351bd2188c5f95a.tar.xz ilc-e866dceae987acd51d43bd457351bd2188c5f95a.zip |
Test CI
Diffstat (limited to 'ci/script.sh')
-rw-r--r-- | ci/script.sh | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/ci/script.sh b/ci/script.sh new file mode 100644 index 0000000..e5f113b --- /dev/null +++ b/ci/script.sh @@ -0,0 +1,36 @@ +# `script` phase: you usually build, test and generate docs in this phase + +set -ex + +# TODO modify this phase as you see fit +# PROTIP Always pass `--target $TARGET` to cargo commands, this makes cargo output build artifacts +# to target/$TARGET/{debug,release} which can reduce the number of needed conditionals in the +# `before_deploy`/packaging phase + +case $TARGET in + # use an emulator to run the cross compiled binaries + arm-unknown-linux-gnueabihf) + # build tests but don't run them + cargo test --target $TARGET --no-run + + # run tests in emulator + find target/$TARGET/debug -maxdepth 1 -executable -type f | \ + xargs qemu-arm -L /usr/arm-linux-gnueabihf + + # build the main executable + cargo build --target $TARGET + + # run the main executable using the emulator + qemu-arm -L /usr/arm-linux-gnueabihf target/$TARGET/debug/ilc + ;; + *) + cargo build --target $TARGET --verbose + # this isn't even a temporary solution. :( + # cargo test --target $TARGET --verbose + ;; +esac + +cargo build --target $TARGET --release + +# sanity check the file type +file target/$TARGET/release/ilc |