-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path.gitlab-ci.yml
48 lines (43 loc) · 1.48 KB
/
.gitlab-ci.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# Official language image. Look for the different tagged releases at:
# https://hub.docker.com/r/library/rust/tags/
image: "rust:latest"
# Optional: Pick zero or more services to be used on all builds.
# Only needed when using a docker container to run your tests in.
# Check out: https://docs.gitlab.com/ee/ci/services/index.html
# services:
# - mysql:latest
# - redis:latest
# - postgres:latest
# Optional: Install a C compiler, cmake and git into the container.
# You will often need this when you (or any of your dependencies) depends on C code.
# before_script:
# - apt-get update -yqq
# - apt-get install -yqq --no-install-recommends build-essential
default:
tags:
- linux
- k8s
# Use cargo to test the project
test:cargo:
script:
- rustup component add rustfmt
- rustc --version && cargo --version # Print version info for debugging
- cargo fmt --check
- cargo clippy --no-deps --all-targets -- -Dwarnings
- cargo check --workspace --all-targets --all-features
# Optional: Use a third party library to generate gitlab junit reports
test:junit-report:
variables:
RUSTC_BOOTSTRAP: 1
script:
# Should be specified in Cargo.toml
- cargo install junitify
- cargo test -- --format=json --report-time -Z unstable-options | junitify --out $CI_PROJECT_DIR/tests/
artifacts:
when: always
reports:
junit: $CI_PROJECT_DIR/tests/*.xml
#deploy:
# stage: deploy
# script: echo "Define your deployment script!"
# environment: production