CI cleanup

- switching more to rules syntax
  - clean up some templates
  - EITHER optional builds or build builds
  - ordering
This commit is contained in:
Marcel Märtens 2020-06-12 13:09:56 +02:00
parent c22f9530e4
commit b9344ffeb7
7 changed files with 91 additions and 112 deletions

View File

@ -1,7 +1,6 @@
stages: stages:
- optional-builds - check
- check-compile - build
- build-post
- publish - publish
variables: variables:
@ -44,7 +43,6 @@ workflow:
include: include:
- local: .gitlab/CI/recompile.yml - local: .gitlab/CI/recompile.yml
- local: .gitlab/CI/release.yml - local: .gitlab/CI/release.yml
- local: .gitlab/CI/optional-builds.gitlab-ci.yml - local: .gitlab/CI/check.gitlab-ci.yml
- local: .gitlab/CI/check-compile.gitlab-ci.yml - local: .gitlab/CI/build.gitlab-ci.yml
- local: .gitlab/CI/build-post.gitlab-ci.yml
- local: .gitlab/CI/publish.gitlab-ci.yml - local: .gitlab/CI/publish.gitlab-ci.yml

View File

@ -1,32 +1,15 @@
.tests: &tests
extends: .recompile-branch
stage: build-post
tags:
- veloren-docker
unittests: unittests:
<<: *tests extends: .recompile-branch
stage: build
script: script:
- ln -s /dockercache/cache-all target - ln -s /dockercache/cache-all target
- cargo test - cargo test
retry: retry:
max: 2 max: 2
coverage:
# Run on master and branches
extends: .recompile
allow_failure: true
stage: build-post
tags:
- veloren-docker
script:
- ln -s /dockercache/cache-tarpaulin target
- cargo tarpaulin -v
retry:
max: 2
benchmarks: benchmarks:
<<: *tests extends: .recompile-branch
stage: build
script: script:
- unset DISABLE_GIT_LFS_CHECK - unset DISABLE_GIT_LFS_CHECK
- ln -s /dockercache/cache-all target - ln -s /dockercache/cache-all target
@ -35,23 +18,27 @@ benchmarks:
max: 2 max: 2
localization-status: localization-status:
<<: *tests extends: .recompile-branch
stage: build
variables: variables:
GIT_DEPTH: 0 GIT_DEPTH: 0
allow_failure: true allow_failure: true
script: script:
- ln -s /dockercache/cache-all target - ln -s /dockercache/cache-all target
- cargo test -q test_all_localizations -- --nocapture --ignored - cargo test test_all_localizations -- --nocapture --ignored
# Artifacts # Coverage is needed on master for the README.md badge to work
.artifact: &artifact coverage:
extends: .release extends: .recompile
stage: build-post stage: build
tags: script:
- veloren-docker - ln -s /dockercache/cache-tarpaulin target
- cargo tarpaulin -v
retry:
max: 2
linux: #linux, windows, macos builds here as template
<<: *artifact .tlinux:
script: script:
- ln -s /dockercache/cache-release-linux target - ln -s /dockercache/cache-release-linux target
- cargo build --release - cargo build --release
@ -67,8 +54,7 @@ linux:
- LICENSE - LICENSE
expire_in: 1 week expire_in: 1 week
windows: .twindows:
<<: *artifact
script: script:
- ln -s /dockercache/cache-release-windows target - ln -s /dockercache/cache-release-windows target
- cargo build --target=x86_64-pc-windows-gnu --release - cargo build --target=x86_64-pc-windows-gnu --release
@ -82,8 +68,7 @@ windows:
- LICENSE - LICENSE
expire_in: 1 week expire_in: 1 week
macos: .tmacos:
<<: *artifact
script: script:
- ln -s /dockercache/cache-release-macos target - ln -s /dockercache/cache-release-macos target
- PATH="/dockercache/osxcross/target/bin:$PATH" COREAUDIO_SDK_PATH=/dockercache/osxcross/target/SDK/MacOSX10.13.sdk CC=o64-clang CXX=o64-clang++ cargo build --target x86_64-apple-darwin --release - PATH="/dockercache/osxcross/target/bin:$PATH" COREAUDIO_SDK_PATH=/dockercache/osxcross/target/SDK/MacOSX10.13.sdk CC=o64-clang CXX=o64-clang++ cargo build --target x86_64-apple-darwin --release
@ -96,4 +81,35 @@ macos:
- assets/ - assets/
- LICENSE - LICENSE
expire_in: 1 week expire_in: 1 week
allow_failure: true
# build on release or master
linux:
extends:
- .tlinux
- .release
windows:
extends:
- .twindows
- .release
macos:
extends:
- .tmacos
- .release
# if NOT release or master, allow optional builds
opt-linux:
extends:
- .tlinux
- .optional-release
opt-windows:
extends:
- .twindows
- .optional-release
opt-macos:
extends:
- .tmacos
- .optional-release

View File

@ -1,17 +1,13 @@
check: check:
extends: .recompile-branch extends: .recompile-branch
stage: check-compile stage: check
tags:
- veloren-docker
script: script:
- ln -s /dockercache/cache-all target - ln -s /dockercache/cache-all target
- RUSTFLAGS="-D warnings" cargo check --locked - RUSTFLAGS="-D warnings" cargo check --locked
code-quality: code-quality:
extends: .recompile-branch extends: .recompile-branch
stage: check-compile stage: check
tags:
- veloren-docker
script: script:
- ln -s /dockercache/cache-all target - ln -s /dockercache/cache-all target
- cargo clippy -- -D warnings - cargo clippy -- -D warnings
@ -19,10 +15,8 @@ code-quality:
security: security:
extends: .recompile-branch extends: .recompile-branch
stage: check-compile stage: check
allow_failure: true allow_failure: true
tags:
- veloren-docker
script: script:
- ln -s /dockercache/cache-all target - ln -s /dockercache/cache-all target
- cargo audit - cargo audit

View File

@ -1,54 +0,0 @@
.optional-release: &optional-release
stage: optional-builds
tags:
- veloren-docker
except:
- schedules
when: manual
optional-release:linux:
<<: *optional-release
script:
- ln -s /dockercache/cache-release-linux target
- cargo build --verbose --release
- cp target/release/veloren-server-cli $CI_PROJECT_DIR
- cp target/release/veloren-voxygen $CI_PROJECT_DIR
- strip --strip-all veloren-server-cli
- strip --strip-all veloren-voxygen
artifacts:
paths:
- veloren-server-cli
- veloren-voxygen
- assets/
- LICENSE
expire_in: 1 week
optional-release:windows:
<<: *optional-release
script:
- ln -s /dockercache/cache-release-windows target
- cargo build --verbose --target=x86_64-pc-windows-gnu --release
- cp target/x86_64-pc-windows-gnu/release/veloren-server-cli.exe $CI_PROJECT_DIR
- cp target/x86_64-pc-windows-gnu/release/veloren-voxygen.exe $CI_PROJECT_DIR
artifacts:
paths:
- veloren-server-cli.exe
- veloren-voxygen.exe
- assets/
- LICENSE
expire_in: 1 week
optional-release:macos:
<<: *optional-release
script:
- ln -s /dockercache/cache-release-macos target
- PATH="/dockercache/osxcross/target/bin:$PATH" COREAUDIO_SDK_PATH=/dockercache/osxcross/target/SDK/MacOSX10.13.sdk CC=o64-clang CXX=o64-clang++ cargo build --target x86_64-apple-darwin --release
- cp -r target/x86_64-apple-darwin/release/veloren-server-cli $CI_PROJECT_DIR
- cp -r target/x86_64-apple-darwin/release/veloren-voxygen $CI_PROJECT_DIR
artifacts:
paths:
- veloren-server-cli
- veloren-voxygen
- assets/
- LICENSE
expire_in: 1 week

View File

@ -1,8 +1,16 @@
# Publishes veloren-server-cli to the gitlab container registry # Publishes veloren-server-cli to the gitlab container registry
# https://gitlab.com/veloren/veloren/container_registry # https://gitlab.com/veloren/veloren/container_registry
docker: .publish:
stage: publish stage: publish
extends: .release tags:
- veloren-docker
rules:
- when: never
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
when: always
docker:
extends: .publish
image: image:
name: gcr.io/kaniko-project/executor:debug name: gcr.io/kaniko-project/executor:debug
entrypoint: [""] entrypoint: [""]
@ -10,15 +18,12 @@ docker:
- linux - linux
before_script: before_script:
- ls "$CI_PROJECT_DIR/server-cli/" - ls "$CI_PROJECT_DIR/server-cli/"
tags:
- veloren-docker
script: script:
- echo "{\"auths\":{\"$CI_REGISTRY\":{\"username\":\"$CI_REGISTRY_USER\",\"password\":\"$CI_REGISTRY_PASSWORD\"}}}" > /kaniko/.docker/config.json - echo "{\"auths\":{\"$CI_REGISTRY\":{\"username\":\"$CI_REGISTRY_USER\",\"password\":\"$CI_REGISTRY_PASSWORD\"}}}" > /kaniko/.docker/config.json
- /kaniko/executor --context $CI_PROJECT_DIR --dockerfile $CI_PROJECT_DIR/server-cli/Dockerfile --destination "${CI_REGISTRY_IMAGE}:${CI_COMMIT_REF_NAME}-server" - /kaniko/executor --context $CI_PROJECT_DIR --dockerfile $CI_PROJECT_DIR/server-cli/Dockerfile --destination "${CI_REGISTRY_IMAGE}:${CI_COMMIT_REF_NAME}-server"
pages: pages:
extends: .release extends: .publish
stage: publish
artifacts: artifacts:
paths: paths:
- public - public

View File

@ -1,5 +1,7 @@
# Template to only run if actual changes has been made to the code and not just documentation # Template to only run if actual changes has been made to the code and not just documentation
.recompile-branch: .recompile-branch:
tags:
- veloren-docker
rules: rules:
- if: $CI_COMMIT_REF_NAME !~ /^master$/ - if: $CI_COMMIT_REF_NAME !~ /^master$/
# No '-' here is *very* important: https://docs.gitlab.com/ee/ci/yaml/#complex-rule-clauses # No '-' here is *very* important: https://docs.gitlab.com/ee/ci/yaml/#complex-rule-clauses
@ -11,6 +13,8 @@
# like .recompile-branch but will run on master too # like .recompile-branch but will run on master too
.recompile: .recompile:
tags:
- veloren-docker
rules: rules:
- changes: - changes:
- "**/*.{rs,ron,toml,vox,png,wav}" - "**/*.{rs,ron,toml,vox,png,wav}"

View File

@ -1,4 +1,20 @@
# allow_failure: true makes these pipelines manual and "non-blocking" which changed with except -> rule syntax
.optional-release:
stage: build
tags:
- veloren-docker
rules:
- when: manual
allow_failure: true
- if: $CI_COMMIT_REF_NAME =~ /^master$/ || $CI_COMMIT_TAG =~ /^v[0-9]+\.[0-9]+\.[0-9]+/ || $CI_COMMIT_REF_NAME =~ /^r[0-9]+\.[0-9]+/ || $CI_PIPELINE_SOURCE == "schedule"
when: never
# Template to only run if pushes to master or a tag happened # Template to only run if pushes to master or a tag happened
.release: .release:
stage: build
tags:
- veloren-docker
rules: rules:
- if: $CI_COMMIT_REF_NAME =~ /^master$/ || $CI_COMMIT_TAG =~ /^v[0-9]+\.[0-9]+\.[0-9]+/ || $CI_COMMIT_REF_NAME =~ /^r[0-9]+\.[0-9]+/ - if: $CI_COMMIT_REF_NAME =~ /^master$/ || $CI_COMMIT_TAG =~ /^v[0-9]+\.[0-9]+\.[0-9]+/ || $CI_COMMIT_REF_NAME =~ /^r[0-9]+\.[0-9]+/
when: always
- when: never