# Based on the "trust" template v0.1.2 # https://github.com/japaric/trust/tree/v0.1.2 dist: trusty language: rust services: docker sudo: required # TODO Rust builds on stable by default, this can be # overridden on a case by case basis down below. env: global: # TODO Update this to match the name of your project. - CRATE_NAME=wireguard-proxy - OPENSSL_STATIC=1 - CARGO_FEATURES=async matrix: # TODO These are all the build jobs. Adjust as necessary. Comment out what you # don't need include: # Android - env: TARGET=aarch64-linux-android - env: TARGET=arm-linux-androideabi - env: TARGET=armv7-linux-androideabi - env: TARGET=i686-linux-android - env: TARGET=x86_64-linux-android # iOS - env: TARGET=aarch64-apple-ios DISABLE_TESTS=1 os: osx - env: TARGET=x86_64-apple-ios DISABLE_TESTS=1 os: osx # Linux - env: TARGET=aarch64-unknown-linux-gnu - env: TARGET=aarch64-unknown-linux-musl - env: TARGET=arm-unknown-linux-gnueabi - env: TARGET=arm-unknown-linux-gnueabihf - env: TARGET=arm-unknown-linux-musleabi - env: TARGET=arm-unknown-linux-musleabihf - env: TARGET=armv5te-unknown-linux-gnueabi - env: TARGET=armv5te-unknown-linux-musleabi - env: TARGET=armv7-unknown-linux-gnueabihf - env: TARGET=armv7-unknown-linux-musleabihf - env: TARGET=i586-unknown-linux-gnu - env: TARGET=i586-unknown-linux-musl - env: TARGET=i686-unknown-linux-gnu - env: TARGET=i686-unknown-linux-musl - env: TARGET=mips-unknown-linux-gnu CARGO_FEATURES=openssl_vendored - env: TARGET=mips-unknown-linux-musl CARGO_FEATURES=openssl_vendored - env: TARGET=mips64-unknown-linux-gnuabi64 CARGO_FEATURES=openssl_vendored - env: TARGET=mips64el-unknown-linux-gnuabi64 CARGO_FEATURES=openssl_vendored - env: TARGET=mipsel-unknown-linux-gnu CARGO_FEATURES=openssl_vendored - env: TARGET=mipsel-unknown-linux-musl CARGO_FEATURES=openssl_vendored - env: TARGET=powerpc-unknown-linux-gnu CARGO_FEATURES=openssl_vendored - env: TARGET=powerpc64le-unknown-linux-gnu CARGO_FEATURES=openssl_vendored # neither openssl nor rustls support poor riscv64gc... - env: TARGET=riscv64gc-unknown-linux-gnu CARGO_FEATURES=verbose - env: TARGET=s390x-unknown-linux-gnu DISABLE_TESTS=1 CARGO_FEATURES=openssl_vendored - env: TARGET=x86_64-unknown-linux-gnu - env: TARGET=x86_64-unknown-linux-musl # Solaris, neither openssl nor rustls support poor solaris... - env: TARGET=sparcv9-sun-solaris DISABLE_TESTS=1 CARGO_FEATURES=verbose - env: TARGET=x86_64-sun-solaris DISABLE_TESTS=1 CARGO_FEATURES=verbose # OSX - env: TARGET=x86_64-apple-darwin os: osx # *BSD - env: TARGET=x86_64-unknown-netbsd DISABLE_TESTS=1 # Windows # wine blows up in testing with async build - env: TARGET=x86_64-pc-windows-gnu DISABLE_TESTS=1 # Bare metal # These targets don't support std and as such are likely not suitable for # most crates. # - env: TARGET=thumbv6m-none-eabi # - env: TARGET=thumbv7em-none-eabi # - env: TARGET=thumbv7em-none-eabihf # - env: TARGET=thumbv7m-none-eabi # Testing other channels - env: TARGET=x86_64-unknown-linux-gnu rust: nightly - env: TARGET=x86_64-apple-darwin os: osx rust: nightly before_install: - set -e - rustup self update install: - sh ci/install.sh - source ~/.cargo/env || true script: - bash ci/script.sh after_script: set +e before_deploy: - sh ci/before_deploy.sh deploy: # TODO update `api_key.secure` # - Create a `public_repo` GitHub token. Go to: https://github.com/settings/tokens/new # - Encrypt it: `travis encrypt 0123456789012345678901234567890123456789 # - Paste the output down here api_key: secure: $GITHUB_OAUTH file_glob: true file: $CRATE_NAME-$TRAVIS_TAG-$TARGET* on: # TODO Here you can pick which targets will generate binary releases # In this example, there are some targets that are tested using the stable # and nightly channels. This condition makes sure there is only one release # for such targets and that's generated using the stable channel condition: $TRAVIS_RUST_VERSION = stable tags: true provider: releases skip_cleanup: true cache: cargo before_cache: # Travis can't cache files that are not readable by "others" - chmod -R a+r $HOME/.cargo branches: only: # release tags - /^v\d+\.\d+\.\d+.*$/ - master - travis - ci - openssl