mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
CI cleanup
- switching more to rules syntax - clean up some templates - EITHER optional builds or build builds - ordering
This commit is contained in:
parent
c22f9530e4
commit
b9344ffeb7
@ -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
|
||||||
|
@ -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
|
@ -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
|
@ -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
|
|
@ -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
|
||||||
|
@ -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}"
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user