815f427c95
add rust beta&nigthly test for master add more triggers
674 lines
31 KiB
YAML
674 lines
31 KiB
YAML
stages:
|
|
- test
|
|
- js-build
|
|
- push-release
|
|
- build
|
|
variables:
|
|
GIT_DEPTH: "3"
|
|
SIMPLECOV: "true"
|
|
RUST_BACKTRACE: "1"
|
|
RUSTFLAGS: ""
|
|
CARGOFLAGS: ""
|
|
cache:
|
|
key: "$CI_BUILD_STAGE/$CI_BUILD_REF_NAME"
|
|
untracked: true
|
|
linux-stable:
|
|
stage: build
|
|
image: parity/rust:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- rustup default stable
|
|
- cargo build -j $(nproc) --release --features final $CARGOFLAGS
|
|
- cargo build -j $(nproc) --release -p evmbin
|
|
- cargo build -j $(nproc) --release -p ethstore
|
|
- cargo build -j $(nproc) --release -p ethkey
|
|
- strip target/release/parity
|
|
- strip target/release/parity-evm
|
|
- strip target/release/ethstore
|
|
- strip target/release/ethkey
|
|
- export SHA3=$(target/release/parity tools hash target/release/parity)
|
|
- md5sum target/release/parity > parity.md5
|
|
- sh scripts/deb-build.sh amd64
|
|
- cp target/release/parity deb/usr/bin/parity
|
|
- cp target/release/parity-evm deb/usr/bin/parity-evm
|
|
- cp target/release/ethstore deb/usr/bin/ethstore
|
|
- cp target/release/ethkey deb/usr/bin/ethkey
|
|
- export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
- dpkg-deb -b deb "parity_"$VER"_amd64.deb"
|
|
- md5sum "parity_"$VER"_amd64.deb" > "parity_"$VER"_amd64.deb.md5"
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu/parity --body target/release/parity
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu/parity.md5 --body parity.md5
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu/"parity_"$VER"_amd64.deb" --body "parity_"$VER"_amd64.deb"
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu/"parity_"$VER"_amd64.deb.md5" --body "parity_"$VER"_amd64.deb.md5"
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/x86_64-unknown-linux-gnu
|
|
tags:
|
|
- rust
|
|
- rust-stable
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity
|
|
- target/release/parity-evm
|
|
- target/release/ethstore
|
|
- target/release/ethkey
|
|
name: "stable-x86_64-unknown-linux-gnu_parity"
|
|
linux-snap:
|
|
stage: build
|
|
image: parity/snapcraft:gitlab-ci
|
|
only:
|
|
- snap
|
|
- beta
|
|
script:
|
|
- rm -rf *snap
|
|
- cd scripts
|
|
- snapcraft
|
|
tags:
|
|
- rust
|
|
- rust-stable
|
|
artifacts:
|
|
paths:
|
|
- scripts/parity_master_amd64.snap
|
|
name: "stable-x86_64-unknown-linux-gnu_parity-snap"
|
|
allow_failure: true
|
|
linux-stable-debian:
|
|
stage: build
|
|
image: parity/rust-debian:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- cargo build -j $(nproc) --release --features final $CARGOFLAGS
|
|
- cargo build -j $(nproc) --release -p evmbin
|
|
- cargo build -j $(nproc) --release -p ethstore
|
|
- cargo build -j $(nproc) --release -p ethkey
|
|
- strip target/release/parity
|
|
- strip target/release/parity-evm
|
|
- strip target/release/ethstore
|
|
- strip target/release/ethkey
|
|
- export SHA3=$(target/release/parity tools hash target/release/parity)
|
|
- md5sum target/release/parity > parity.md5
|
|
- sh scripts/deb-build.sh amd64
|
|
- cp target/release/parity deb/usr/bin/parity
|
|
- cp target/release/parity-evm deb/usr/bin/parity-evm
|
|
- cp target/release/ethstore deb/usr/bin/ethstore
|
|
- cp target/release/ethkey deb/usr/bin/ethkey
|
|
- export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
- dpkg-deb -b deb "parity_"$VER"_amd64.deb"
|
|
- md5sum "parity_"$VER"_amd64.deb" > "parity_"$VER"_amd64.deb.md5"
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu/parity --body target/release/parity
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu/parity.md5 --body parity.md5
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu/"parity_"$VER"_amd64.deb" --body "parity_"$VER"_amd64.deb"
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu/"parity_"$VER"_amd64.deb.md5" --body "parity_"$VER"_amd64.deb.md5"
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/x86_64-unknown-debian-gnu
|
|
tags:
|
|
- rust
|
|
- rust-debian
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity
|
|
name: "stable-x86_64-unknown-debian-gnu_parity"
|
|
linux-beta:
|
|
stage: build
|
|
image: parity/rust:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- rustup default beta
|
|
- cargo build -j $(nproc) --release $CARGOFLAGS
|
|
- strip target/release/parity
|
|
tags:
|
|
- rust
|
|
- rust-beta
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity
|
|
name: "beta-x86_64-unknown-linux-gnu_parity"
|
|
allow_failure: true
|
|
linux-nightly:
|
|
stage: build
|
|
image: parity/rust:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- rustup default nightly
|
|
- cargo build -j $(nproc) --release $CARGOFLAGS
|
|
- strip target/release/parity
|
|
tags:
|
|
- rust
|
|
- rust-nightly
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity
|
|
name: "nigthly-x86_64-unknown-linux-gnu_parity"
|
|
allow_failure: true
|
|
linux-centos:
|
|
stage: build
|
|
image: parity/rust-centos:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- export CXX="g++"
|
|
- export CC="gcc"
|
|
- export PLATFORM=x86_64-unknown-centos-gnu
|
|
- cargo build -j $(nproc) --release --features final $CARGOFLAGS
|
|
- strip target/release/parity
|
|
- md5sum target/release/parity > parity.md5
|
|
- export SHA3=$(target/release/parity tools hash target/release/parity)
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/x86_64-unknown-centos-gnu
|
|
- aws s3api put-object --bucket builds-parity --key $CI_BUILD_REF_NAME/x86_64-unknown-centos-gnu/parity --body target/release/parity
|
|
- aws s3api put-object --bucket builds-parity --key $CI_BUILD_REF_NAME/x86_64-unknown-centos-gnu/parity.md5 --body parity.md5
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- rust
|
|
- rust-centos
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity
|
|
name: "x86_64-unknown-centos-gnu_parity"
|
|
linux-i686:
|
|
stage: build
|
|
image: parity/rust-i686:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- export HOST_CC=gcc
|
|
- export HOST_CXX=g++
|
|
- export COMMIT=$(git rev-parse HEAD)
|
|
- export PLATFORM=i686-unknown-linux-gnu
|
|
- cargo build -j $(nproc) --target i686-unknown-linux-gnu --features final --release $CARGOFLAGS
|
|
- strip target/$PLATFORM/release/parity
|
|
- md5sum target/$PLATFORM/release/parity > parity.md5
|
|
- export SHA3=$(target/$PLATFORM/release/parity tools hash target/$PLATFORM/release/parity)
|
|
- sh scripts/deb-build.sh i386
|
|
- cp target/$PLATFORM/release/parity deb/usr/bin/parity
|
|
- export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
- dpkg-deb -b deb "parity_"$VER"_i386.deb"
|
|
- md5sum "parity_"$VER"_i386.deb" > "parity_"$VER"_i386.deb.md5"
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity --body target/$PLATFORM/release/parity
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity.md5 --body parity.md5
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_i386.deb" --body "parity_"$VER"_i386.deb"
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_i386.deb.md5" --body "parity_"$VER"_i386.deb.md5"
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- rust
|
|
- rust-i686
|
|
artifacts:
|
|
paths:
|
|
- target/i686-unknown-linux-gnu/release/parity
|
|
name: "i686-unknown-linux-gnu"
|
|
allow_failure: true
|
|
linux-armv7:
|
|
stage: build
|
|
image: parity/rust-armv7:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- export CC=arm-linux-gnueabihf-gcc
|
|
- export CXX=arm-linux-gnueabihf-g++
|
|
- export HOST_CC=gcc
|
|
- export HOST_CXX=g++
|
|
- export PLATFORM=armv7-unknown-linux-gnueabihf
|
|
- rm -rf .cargo
|
|
- mkdir -p .cargo
|
|
- echo "[target.$PLATFORM]" >> .cargo/config
|
|
- echo "linker= \"arm-linux-gnueabihf-gcc\"" >> .cargo/config
|
|
- cat .cargo/config
|
|
- cargo build -j $(nproc) --target $PLATFORM --features final --release $CARGOFLAGS
|
|
- arm-linux-gnueabihf-strip target/$PLATFORM/release/parity
|
|
- export SHA3=$(rhash --sha3-256 target/$PLATFORM/release/parity -p %h)
|
|
- md5sum target/$PLATFORM/release/parity > parity.md5
|
|
- sh scripts/deb-build.sh armhf
|
|
- cp target/$PLATFORM/release/parity deb/usr/bin/parity
|
|
- export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
- dpkg-deb -b deb "parity_"$VER"_armhf.deb"
|
|
- md5sum "parity_"$VER"_armhf.deb" > "parity_"$VER"_armhf.deb.md5"
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity --body target/$PLATFORM/release/parity
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity.md5 --body parity.md5
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_armhf.deb" --body "parity_"$VER"_armhf.deb"
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_armhf.deb.md5" --body "parity_"$VER"_armhf.deb.md5"
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- rust
|
|
- rust-arm
|
|
artifacts:
|
|
paths:
|
|
- target/armv7-unknown-linux-gnueabihf/release/parity
|
|
name: "armv7_unknown_linux_gnueabihf_parity"
|
|
allow_failure: true
|
|
linux-arm:
|
|
stage: build
|
|
image: parity/rust-arm:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- export CC=arm-linux-gnueabihf-gcc
|
|
- export CXX=arm-linux-gnueabihf-g++
|
|
- export HOST_CC=gcc
|
|
- export HOST_CXX=g++
|
|
- export PLATFORM=arm-unknown-linux-gnueabihf
|
|
- rm -rf .cargo
|
|
- mkdir -p .cargo
|
|
- echo "[target.$PLATFORM]" >> .cargo/config
|
|
- echo "linker= \"arm-linux-gnueabihf-gcc\"" >> .cargo/config
|
|
- cat .cargo/config
|
|
- cargo build -j $(nproc) --target $PLATFORM --features final --release $CARGOFLAGS
|
|
- arm-linux-gnueabihf-strip target/$PLATFORM/release/parity
|
|
- export SHA3=$(rhash --sha3-256 target/$PLATFORM/release/parity -p %h)
|
|
- md5sum target/$PLATFORM/release/parity > parity.md5
|
|
- sh scripts/deb-build.sh armhf
|
|
- cp target/$PLATFORM/release/parity deb/usr/bin/parity
|
|
- export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
- dpkg-deb -b deb "parity_"$VER"_armhf.deb"
|
|
- md5sum "parity_"$VER"_armhf.deb" > "parity_"$VER"_armhf.deb.md5"
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity --body target/$PLATFORM/release/parity
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity.md5 --body parity.md5
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_armhf.deb" --body "parity_"$VER"_armhf.deb"
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_armhf.deb.md5" --body "parity_"$VER"_armhf.deb.md5"
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- rust
|
|
- rust-arm
|
|
artifacts:
|
|
paths:
|
|
- target/arm-unknown-linux-gnueabihf/release/parity
|
|
name: "arm-unknown-linux-gnueabihf_parity"
|
|
allow_failure: true
|
|
linux-armv6:
|
|
stage: build
|
|
image: ethcore/rust-armv6:latest
|
|
only:
|
|
- beta
|
|
# - tags
|
|
# - stable
|
|
# - triggers
|
|
script:
|
|
- export CC=arm-linux-gnueabi-gcc
|
|
- export CXX=arm-linux-gnueabi-g++
|
|
- export HOST_CC=gcc
|
|
- export HOST_CXX=g++
|
|
- export PLATFORM=arm-unknown-linux-gnueabi
|
|
- rm -rf .cargo
|
|
- mkdir -p .cargo
|
|
- echo "[target.$PLATFORM]" >> .cargo/config
|
|
- echo "linker= \"arm-linux-gnueabi-gcc\"" >> .cargo/config
|
|
- cat .cargo/config
|
|
- cargo build -j $(nproc) --target $PLATFORM --features final --release $CARGOFLAGS
|
|
- arm-linux-gnueabi-strip target/$PLATFORM/release/parity
|
|
- export SHA3=$(rhash --sha3-256 target/$PLATFORM/release/parity -p %h)
|
|
- md5sum target/$PLATFORM/release/parity > parity.md5
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity --body target/$PLATFORM/release/parity
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity.md5 --body parity.md5
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- rust
|
|
- rust-arm
|
|
artifacts:
|
|
paths:
|
|
- target/arm-unknown-linux-gnueabi/release/parity
|
|
name: "arm-unknown-linux-gnueabi_parity"
|
|
allow_failure: true
|
|
linux-aarch64:
|
|
stage: build
|
|
image: parity/rust-arm64:gitlab-ci
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- export CC=aarch64-linux-gnu-gcc
|
|
- export CXX=aarch64-linux-gnu-g++
|
|
- export HOST_CC=gcc
|
|
- export HOST_CXX=g++
|
|
- export PLATFORM=aarch64-unknown-linux-gnu
|
|
- rm -rf .cargo
|
|
- mkdir -p .cargo
|
|
- echo "[target.$PLATFORM]" >> .cargo/config
|
|
- echo "linker= \"aarch64-linux-gnu-gcc\"" >> .cargo/config
|
|
- cat .cargo/config
|
|
- cargo build -j $(nproc) --target $PLATFORM --features final --release $CARGOFLAGS
|
|
- aarch64-linux-gnu-strip target/$PLATFORM/release/parity
|
|
- export SHA3=$(rhash --sha3-256 target/$PLATFORM/release/parity -p %h)
|
|
- md5sum target/$PLATFORM/release/parity > parity.md5
|
|
- sh scripts/deb-build.sh arm64
|
|
- cp target/$PLATFORM/release/parity deb/usr/bin/parity
|
|
- export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
- dpkg-deb -b deb "parity_"$VER"_arm64.deb"
|
|
- md5sum "parity_"$VER"_arm64.deb" > "parity_"$VER"_arm64.deb.md5"
|
|
- aws configure set aws_access_key_id $s3_key
|
|
- aws configure set aws_secret_access_key $s3_secret
|
|
- if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
- aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity.md5 --body parity.md5
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_arm64.deb" --body "parity_"$VER"_arm64.deb"
|
|
- aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity_"$VER"_arm64.deb.md5" --body "parity_"$VER"_arm64.deb.md5"
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
- curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- rust
|
|
- rust-arm
|
|
artifacts:
|
|
paths:
|
|
- target/aarch64-unknown-linux-gnu/release/parity
|
|
name: "aarch64-unknown-linux-gnu_parity"
|
|
allow_failure: true
|
|
darwin:
|
|
stage: build
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script: |
|
|
export COMMIT=$(git rev-parse HEAD)
|
|
export PLATFORM=x86_64-apple-darwin
|
|
cargo build -j 8 --features final --release #$CARGOFLAGS
|
|
cargo build -j 8 --features final --release -p ethstore #$CARGOFLAGS
|
|
rm -rf parity.md5
|
|
md5sum target/release/parity > parity.md5
|
|
export SHA3=$(target/release/parity tools hash target/release/parity)
|
|
cd mac
|
|
xcodebuild -configuration Release
|
|
cd ..
|
|
packagesbuild -v mac/Parity.pkgproj
|
|
productsign --sign 'Developer ID Installer: PARITY TECHNOLOGIES LIMITED (P2PX3JU8FT)' target/release/Parity\ Ethereum.pkg target/release/Parity\ Ethereum-signed.pkg
|
|
export VER=$(grep -m 1 version Cargo.toml | awk '{print $3}' | tr -d '"' | tr -d "\n")
|
|
mv target/release/Parity\ Ethereum-signed.pkg "parity-"$VER"-macos-installer.pkg"
|
|
md5sum "parity-"$VER"-macos-installer.pkg" >> "parity-"$VER"-macos-installer.pkg.md5"
|
|
aws configure set aws_access_key_id $s3_key
|
|
aws configure set aws_secret_access_key $s3_secret
|
|
if [[ $CI_BUILD_REF_NAME =~ ^(master|beta|stable|nightly)$ ]]; then export S3_BUCKET=builds-parity-published; else export S3_BUCKET=builds-parity; fi
|
|
aws s3 rm --recursive s3://$S3_BUCKET/$CI_BUILD_REF_NAME/$PLATFORM
|
|
aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity --body target/release/parity
|
|
aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/parity.md5 --body parity.md5
|
|
aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity-"$VER"-macos-installer.pkg" --body "parity-"$VER"-macos-installer.pkg"
|
|
aws s3api put-object --bucket $S3_BUCKET --key $CI_BUILD_REF_NAME/$PLATFORM/"parity-"$VER"-macos-installer.pkg.md5" --body "parity-"$VER"-macos-installer.pkg.md5"
|
|
curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1337/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
curl --data "commit=$CI_BUILD_REF&sha3=$SHA3&filename=parity&secret=$RELEASES_SECRET" http://update.parity.io:1338/push-build/$CI_BUILD_REF_NAME/$PLATFORM
|
|
tags:
|
|
- osx
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity
|
|
name: "x86_64-apple-darwin_parity"
|
|
windows:
|
|
cache:
|
|
key: "%CI_BUILD_STAGE%/%CI_BUILD_REF_NAME%"
|
|
untracked: true
|
|
stage: build
|
|
only:
|
|
- beta
|
|
- tags
|
|
- stable
|
|
- triggers
|
|
script:
|
|
- set PLATFORM=x86_64-pc-windows-msvc
|
|
- set INCLUDE=C:\Program Files (x86)\Microsoft SDKs\Windows\v7.1A\Include;C:\vs2015\VC\include;C:\Program Files (x86)\Windows Kits\10\Include\10.0.10240.0\ucrt
|
|
- set LIB=C:\vs2015\VC\lib;C:\Program Files (x86)\Windows Kits\10\Lib\10.0.10240.0\ucrt\x64
|
|
- set RUST_BACKTRACE=1
|
|
- set RUSTFLAGS=%RUSTFLAGS%
|
|
- rustup default stable-x86_64-pc-windows-msvc
|
|
- cargo build --features final --release #%CARGOFLAGS%
|
|
- signtool sign /f %keyfile% /p %certpass% target\release\parity.exe
|
|
- target\release\parity.exe tools hash target\release\parity.exe > parity.sha3
|
|
- set /P SHA3=<parity.sha3
|
|
- curl -sL --url "https://github.com/paritytech/win-build/raw/master/SimpleFC.dll" -o nsis\SimpleFC.dll
|
|
- curl -sL --url "https://github.com/paritytech/win-build/raw/master/vc_redist.x64.exe" -o nsis\vc_redist.x64.exe
|
|
- msbuild windows\ptray\ptray.vcxproj /p:Platform=x64 /p:Configuration=Release
|
|
- signtool sign /f %keyfile% /p %certpass% windows\ptray\x64\release\ptray.exe
|
|
- cd nsis
|
|
- makensis.exe installer.nsi
|
|
- copy installer.exe InstallParity.exe
|
|
- signtool sign /f %keyfile% /p %certpass% InstallParity.exe
|
|
- md5sums InstallParity.exe > InstallParity.exe.md5
|
|
- zip win-installer.zip InstallParity.exe InstallParity.exe.md5
|
|
- md5sums win-installer.zip > win-installer.zip.md5
|
|
- cd ..\target\release\
|
|
- md5sums parity.exe > parity.exe.md5
|
|
- zip parity.zip parity.exe parity.md5
|
|
- md5sums parity.zip > parity.zip.md5
|
|
- cd ..\..
|
|
- aws configure set aws_access_key_id %s3_key%
|
|
- aws configure set aws_secret_access_key %s3_secret%
|
|
- echo %CI_BUILD_REF_NAME%
|
|
- echo %CI_BUILD_REF_NAME% | findstr /R "master" >nul 2>&1 && set S3_BUCKET=builds-parity-published|| set S3_BUCKET=builds-parity
|
|
- echo %CI_BUILD_REF_NAME% | findstr /R "beta" >nul 2>&1 && set S3_BUCKET=builds-parity-published|| set S3_BUCKET=builds-parity
|
|
- echo %CI_BUILD_REF_NAME% | findstr /R "stable" >nul 2>&1 && set S3_BUCKET=builds-parity-published|| set S3_BUCKET=builds-parity
|
|
- echo %CI_BUILD_REF_NAME% | findstr /R "nightly" >nul 2>&1 && set S3_BUCKET=builds-parity-published|| set S3_BUCKET=builds-parity
|
|
- echo %S3_BUCKET%
|
|
- aws s3 rm --recursive s3://%S3_BUCKET%/%CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/parity.exe --body target\release\parity.exe
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/parity.exe.md5 --body target\release\parity.exe.md5
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/parity.zip --body target\release\parity.zip
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/parity.zip.md5 --body target\release\parity.zip.md5
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/InstallParity.exe --body nsis\InstallParity.exe
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/InstallParity.exe.md5 --body nsis\InstallParity.exe.md5
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/win-installer.zip --body nsis\win-installer.zip
|
|
- aws s3api put-object --bucket %S3_BUCKET% --key %CI_BUILD_REF_NAME%/x86_64-pc-windows-msvc/win-installer.zip.md5 --body nsis\win-installer.zip.md5
|
|
- curl --data "commit=%CI_BUILD_REF%&sha3=%SHA3%&filename=parity.exe&secret=%RELEASES_SECRET%" http://update.parity.io:1337/push-build/%CI_BUILD_REF_NAME%/%PLATFORM%
|
|
- curl --data "commit=%CI_BUILD_REF%&sha3=%SHA3%&filename=parity.exe&secret=%RELEASES_SECRET%" http://update.parity.io:1338/push-build/%CI_BUILD_REF_NAME%/%PLATFORM%
|
|
tags:
|
|
- rust-windows
|
|
artifacts:
|
|
paths:
|
|
- target/release/parity.exe
|
|
- target/release/parity.pdb
|
|
- nsis/InstallParity.exe
|
|
name: "x86_64-pc-windows-msvc_parity"
|
|
docker-build:
|
|
stage: build
|
|
only:
|
|
- tags
|
|
- triggers
|
|
before_script:
|
|
- docker info
|
|
script:
|
|
- if [ "$CI_BUILD_REF_NAME" == "beta-release" ]; then DOCKER_TAG="latest"; else DOCKER_TAG=$CI_BUILD_REF_NAME; fi
|
|
- docker login -u $Docker_Hub_User -p $Docker_Hub_Pass
|
|
- sh scripts/docker-build.sh $DOCKER_TAG ethcore
|
|
- docker logout
|
|
- docker login -u $Docker_Hub_User_Parity -p $Docker_Hub_Pass_Parity
|
|
- sh scripts/docker-build.sh $DOCKER_TAG parity
|
|
- docker logout
|
|
tags:
|
|
- docker
|
|
test-coverage:
|
|
stage: test
|
|
only:
|
|
- master
|
|
script:
|
|
- git submodule update --init --recursive
|
|
- rm -rf target/*
|
|
- rm -rf js/.coverage
|
|
- scripts/cov.sh
|
|
# - COVERAGE=$(grep -Po 'covered":.*?[^\\]"' target/cov/index.json | grep "[0-9]*\.[0-9]" -o)
|
|
# - echo "Coverage:" $COVERAGE
|
|
tags:
|
|
- kcov
|
|
allow_failure: true
|
|
test-darwin:
|
|
stage: test
|
|
only:
|
|
- triggers
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
- export RUST_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep -v -e "^js/" -e ^\\. -e ^LICENSE -e ^README.md -e ^appveyor.yml -e ^test.sh -e ^windows/ -e ^scripts/ -e^mac/ -e ^nsis/ | wc -l)
|
|
script:
|
|
- export RUST_BACKTRACE=1
|
|
- if [ $RUST_FILES_MODIFIED -eq 0 ]; then echo "Skipping Rust tests since no Rust files modified."; else ./test.sh $CARGOFLAGS; fi
|
|
tags:
|
|
- osx
|
|
allow_failure: true
|
|
test-windows:
|
|
stage: test
|
|
only:
|
|
- triggers
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
script:
|
|
- set RUST_BACKTRACE=1
|
|
- echo cargo test --features json-tests -p rlp -p ethash -p ethcore -p ethcore-bigint -p parity-dapps -p parity-rpc -p ethcore-util -p ethcore-network -p ethcore-io -p ethkey -p ethstore -p ethsync -p ethcore-ipc -p ethcore-ipc-tests -p ethcore-ipc-nano -p parity-rpc-client -p parity %CARGOFLAGS% --verbose --release
|
|
tags:
|
|
- rust-windows
|
|
allow_failure: true
|
|
test-rust-stable:
|
|
stage: test
|
|
image: parity/rust:gitlab-ci
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
- export RUST_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep -v -e ^js -e ^\\. -e ^LICENSE -e ^README.md -e ^appveyor.yml -e ^test.sh -e ^windows/ -e ^scripts/ -e^mac/ -e ^nsis/ | wc -l)
|
|
script:
|
|
- rustup show
|
|
- export RUST_BACKTRACE=1
|
|
- if [ $RUST_FILES_MODIFIED -eq 0 ]; then echo "Skipping Rust tests since no Rust files modified."; else ./test.sh $CARGOFLAGS; fi
|
|
tags:
|
|
- rust
|
|
- rust-stable
|
|
js-test:
|
|
stage: test
|
|
image: parity/rust:gitlab-ci
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
- export JS_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep ^js/ | wc -l)
|
|
- if [ $JS_FILES_MODIFIED -eq 0 ]; then echo "Skipping JS deps install since no JS files modified."; else ./js/scripts/install-deps.sh;fi
|
|
script:
|
|
- if [ $JS_FILES_MODIFIED -eq 0 ]; then echo "Skipping JS lint since no JS files modified."; else ./js/scripts/lint.sh && ./js/scripts/test.sh && ./js/scripts/build.sh; fi
|
|
tags:
|
|
- rust
|
|
- rust-stable
|
|
js-test-node_8:
|
|
stage: test
|
|
image: parity/rust-debian-node_8:gitlab-ci
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
- export JS_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep ^js/ | wc -l)
|
|
- if [ $JS_FILES_MODIFIED -eq 0 ]; then echo "Skipping JS deps install since no JS files modified."; else ./js/scripts/install-deps.sh;fi
|
|
script:
|
|
- if [ $JS_FILES_MODIFIED -eq 0 ]; then echo "Skipping JS lint since no JS files modified."; else ./js/scripts/lint.sh && ./js/scripts/test.sh && ./js/scripts/build.sh; fi
|
|
tags:
|
|
- rust
|
|
- rust-stable
|
|
allow_failure: true
|
|
test-rust-beta:
|
|
stage: test
|
|
only:
|
|
- triggers
|
|
- master
|
|
image: parity/rust:gitlab-ci
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
- export RUST_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep -v -e ^js -e ^\\. -e ^LICENSE -e ^README.md -e ^appveyor.yml -e ^test.sh -e ^windows/ -e ^scripts/ -e^mac/ -e ^nsis/ | wc -l)
|
|
script:
|
|
- rustup default beta
|
|
- export RUST_BACKTRACE=1
|
|
- if [ $RUST_FILES_MODIFIED -eq 0 ]; then echo "Skipping Rust tests since no Rust files modified."; else ./test.sh $CARGOFLAGS; fi
|
|
tags:
|
|
- rust
|
|
- rust-beta
|
|
allow_failure: true
|
|
test-rust-nightly:
|
|
stage: test
|
|
only:
|
|
- triggers
|
|
- master
|
|
image: parity/rust:gitlab-ci
|
|
before_script:
|
|
- git submodule update --init --recursive
|
|
- export RUST_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep -v -e ^js -e ^\\. -e ^LICENSE -e ^README.md -e ^appveyor.yml -e ^test.sh -e ^windows/ -e ^scripts/ -e^mac/ -e ^nsis/ | wc -l)
|
|
script:
|
|
- rustup default nightly
|
|
- export RUST_BACKTRACE=1
|
|
- if [ $RUST_FILES_MODIFIED -eq 0 ]; then echo "Skipping Rust tests since no Rust files modified."; else ./test.sh $CARGOFLAGS; fi
|
|
tags:
|
|
- rust
|
|
- rust-nightly
|
|
allow_failure: true
|
|
js-release:
|
|
stage: js-build
|
|
only:
|
|
- master
|
|
- beta
|
|
- stable
|
|
- tags
|
|
- triggers
|
|
image: parity/rust:gitlab-ci
|
|
before_script:
|
|
- export JS_FILES_MODIFIED=$(git --no-pager diff --name-only $CI_BUILD_REF^ $CI_BUILD_REF | grep ^js/ | wc -l)
|
|
- echo $JS_FILES_MODIFIED
|
|
- if [ $JS_FILES_MODIFIED -eq 0 ]; then echo "Skipping JS deps install since no JS files modified."; else ./js/scripts/install-deps.sh;fi
|
|
script:
|
|
- rustup default stable
|
|
- echo $JS_FILES_MODIFIED
|
|
- if [ $JS_FILES_MODIFIED -eq 0 ]; then echo "Skipping JS rebuild since no JS files modified."; else ./js/scripts/build.sh && ./js/scripts/release.sh; fi
|
|
tags:
|
|
- javascript
|
|
push-release:
|
|
stage: push-release
|
|
only:
|
|
- tags
|
|
- triggers
|
|
image: parity/rust:gitlab-ci
|
|
script:
|
|
- rustup default stable
|
|
- curl --data "secret=$RELEASES_SECRET" http://update.parity.io:1337/push-release/$CI_BUILD_REF_NAME/$CI_BUILD_REF
|
|
- curl --data "secret=$RELEASES_SECRET" http://update.parity.io:1338/push-release/$CI_BUILD_REF_NAME/$CI_BUILD_REF
|
|
tags:
|
|
- curl
|