docs(ci): extra CI documentation

Adds some extra quick-glance docs for the CI flow.
pull/24376/head
Dom 2020-11-26 13:38:27 +00:00
parent 559df0e37c
commit e93941e487
1 changed files with 61 additions and 15 deletions

View File

@ -1,7 +1,26 @@
# CI Overview
# -----------
#
# Each night:
#
# A build image is created (ci_image) from `docker/Dockerfile.ci` and is
# pushed to `quay.io/influxdb/rust:ci`. This build image is then used to run
# the CI tasks for the day.
#
# Each CI run:
#
# Runs tests, fmt, & lints and then compiles binaries using the default cargo
# target ("dev").
#
# CI runs for git branches ending in `/perf`:
#
# Runs tests, fmt, & lints and then compiles binaries using the "release"
# cargo target and pushes a container with the binary to
# `quay.io/influxdb/fusion` (see perf_image below).
version: 2.1 version: 2.1
commands: commands:
rust_nightly: rust_nightly:
description: Install nightly Rust toolchain description: Install nightly Rust toolchain
steps: steps:
@ -41,6 +60,11 @@ jobs:
- run: - run:
name: Cargo test name: Cargo test
command: cargo test --workspace command: cargo test --workspace
# Build a dev binary.
#
# Compiles a binary with the default ("dev") cargo profile from the iox source
# using the latest ci_image.
build: build:
docker: docker:
- image: quay.io/influxdb/rust:ci - image: quay.io/influxdb/rust:ci
@ -51,19 +75,21 @@ jobs:
name: Cargo build name: Cargo build
command: cargo build --workspace command: cargo build --workspace
ci_image: # Compile a cargo "release" profile binary for branches that end in `/perf`
machine: true #
resource_class: xlarge # Uses the latest ci_image (influxdb/rust below) to build a release binary and
steps: # copies it to a minimal container image based upon `rust:slim-buster`. This
- checkout # minimal image is then pushed to `quay.io/influxdb/fusion:${BRANCH}` with '/'
- run: | # repaced by '.' - as an example:
echo "$QUAY_PASS" | docker login quay.io --username $QUAY_USER --password-stdin #
- run: | # git branch: dom/my-awesome-feature/perf
COMMIT_SHA=$(git rev-parse --short HEAD) # container: quay.io/influxdb/fusion:dom.my-awesome-feature.perf
docker build -t quay.io/influxdb/rust:$COMMIT_SHA -f docker/Dockerfile.ci . #
docker tag quay.io/influxdb/rust:$COMMIT_SHA quay.io/influxdb/rust:ci # Subsequent CI runs will overwrite the tag if you push more changes, so watch
docker push quay.io/influxdb/rust:$COMMIT_SHA # out for parallel CI runs!
docker push quay.io/influxdb/rust:ci #
# To change the contents of the build container, modify docker/Dockerfile.ci
# To change the final release container, modify docker/Dockerfile.perf
perf_image: perf_image:
docker: docker:
- image: quay.io/influxdb/rust:ci - image: quay.io/influxdb/rust:ci
@ -85,6 +111,26 @@ jobs:
docker build -t quay.io/influxdb/fusion:$BRANCH -f docker/Dockerfile.perf . docker build -t quay.io/influxdb/fusion:$BRANCH -f docker/Dockerfile.perf .
docker push quay.io/influxdb/fusion:$BRANCH docker push quay.io/influxdb/fusion:$BRANCH
# Prepare the CI image used for other tasks.
#
# A nightly job (scheduled below in the `workflows` section) to build the CI
# image (influxdb/rust) used for the rest of the checks.
#
# To modify the contents of the CI image, update docker/Dockerfile.ci
ci_image:
machine: true
resource_class: xlarge
steps:
- checkout
- run: |
echo "$QUAY_PASS" | docker login quay.io --username $QUAY_USER --password-stdin
- run: |
COMMIT_SHA=$(git rev-parse --short HEAD)
docker build -t quay.io/influxdb/rust:$COMMIT_SHA -f docker/Dockerfile.ci .
docker tag quay.io/influxdb/rust:$COMMIT_SHA quay.io/influxdb/rust:ci
docker push quay.io/influxdb/rust:$COMMIT_SHA
docker push quay.io/influxdb/rust:ci
workflows: workflows:
version: 2 version: 2
build: build: