Skip to content

Latest commit

 

History

History
167 lines (124 loc) · 6 KB

CI.md

File metadata and controls

167 lines (124 loc) · 6 KB

Motoko CI and CD setup

This file gives a comprehensive overview of our CI and CD setup. Target audience are developers working on Motoko (to know what services and behaviours they can expect), and engineers who support the setup.

This document distinguishes use-cases (requirements, goals) from implementations, to allow evaluating alternative implementations.

The implementation is currently a careful choreography between Github, Github Actions, Hydra, the cachix nix cache, the internal nix cache and mergify.

This file describes both the pre-open-source setup (internal) which will gradually be updated or removed as we move away from the internal CI setup towards the open setup (external).

Knowing if it is broken

Use-case: Everything is built and tested upon every push to a branch of the repository, and the resulting status is visible (at derivation granularity) to developers.

Implementation (external): All pushes to any branch are built by a Github Action job, on Linux and Darwin.

Implementation (internal): All pushes to master, as well as to all branches with open PRs cause hydra to build the jobs described in ci.nix resp. ci-pr.nix.

The build status is visible via the Github status (coarsly: only evaluation, all-systems-go and all-jobs) and via hydra directly (full per-job detail including logs).

This includes linux and darwin builds.

Preventing master from breaking

Use-case: A PR that breaks requires jobs (all-systems-go) cannot be merged into master.

Implementation (external): Github branch protection is enabled for master, and requires the Github Action jobs (Linux and Darwin) to succeed.

Require a second pair of eyeballs

Use-case: A PR needs to be approved by any other developer in order to be merged (with the exceptions listed below).

Implementation: Github branch protection requires a review.

Warm cache

Use-case: Developers can rely on all build artifacts (espcially, but not exclusively, the dependencies of the nix shell) being present in a nix cache.

Implementation (external): Github Actions pushes all builds to the public cachix.org-based nix cache.

Implementation (internal): Hydra pushes all builds to the internal nix cache.

Push releases

Use-case: Tagged versions cause a tarball with a Motoko release to be pushed to https://github.com/dfinity/motoko/releases

Implementation (external): A github action creates Github releases and includes the build artifacts there.

Automatically merge when ready

Use-case: Developers can indicate that a PR should be merged as soon as all requirements pass, using the PR description as the commit message.

This can be done before approvals are in and/or CI has turned green, and will reliably be acted on once requirements are fulfilled.

Implementation: Mergify reacts to the automerge-squash label. Once approved and CI passes, it merges master into the branch (using normal merge, which is important for stashed PRs) and then squash-merges the PR.

Render and provide various reports

Use-case: Various build artifacts are most useful when available directly in the browser, namely:

  • The motoko user guide
  • The “overview slides”
  • The documentation for motoko-base, in the version pinned by motoko
  • Flamegraphs for the programs in tests/perf
  • A coverage report

A stable link to these should exist for master, and an easy-to-find link for each PR.

Implementation (internal): Hydra hosts the build products of the relevant jobs, and can be found via the Hydra job status page, and the there is a stable link for the latest build of master and of each PR.

Implementation (external): The latest master version of the file is availble at https://dfinity.github.io/motoko/. The reports are calculated in PRs (so failures would be caught), but are not hosted anywhere.

Performance changes are known

Use-case: For every PR, the developer is told about performance changes relative to the merge point, via an continuously updated comment on the PR.

Implementation (external):

  • Steps in the Github Action calculates the correct merge base using git-merge-base (not the latest version of the target branch) and passes the correct git revisions to the ./perf-delta.nix nix derivation.
  • Building that derivations compares metrics and generates a report.
  • A Github Action updates the comment upon every new push to the PR.

Implementation (internal):

  • Hydra calculates the correct merge base using git-merge-base (not the latest version of the target branch) and passes a checkout of that revision as src.mergeBase to ci-pr.nix.
  • The job perf-delta compares metrics and generates a report.
  • The hydra Github commenter plugin updates the comment upon every new push to the PR.

Dependencies are updated automatically

Use-case: Several dependencies, as pinned by nix/souces.json, should be updated without human intervention. Some dependencies are updated daily, others weekly. For some dependency, it should only be tested if it builds, but not merged.

Implementation:

  • Multiple files (with different settings) in .github/workflows/ use niv-updater-action to create pull requests with the version bumps, as dfinity-bot, setting automerge-squash or autoclose.
  • Mergify automatically approves PRs from dfinity-bot.
  • Once CI passes, mergify merges or closes PRs, as per label.

Updates to the Changelog require no review

Use-case: To make releasing releases frictionless (see section in Building.md), PRs that only update Changelog.md do not require a human approver.

Implementation: Mergify approves PRs that only change the Changelog.md file.