Overview of GitHub Actions CI#

Squareone uses GitHub Actions to drive both continuous integration (CI) and continuous delivery (CD) workflows. This page gives an overview of the CI workflows and how they work together.

For an overview of the tooling that GitHub Actions runs for testing and releases, see Overview of the monorepo architecture.

Testing branches and pull requests — ci.yaml#

The ci.yaml workflow tests each pull request and pushes to main. This CI workflow builds each package and application, and runs tests and linters with Turborepo pipelines.

For the applications, the CI workflow builds the Docker images and pushes them to the Squareone Docker registry. These images are tagged with the branch name. For example, the pull request for the tickets/DM-40262` branch will build and push the ghcr.io/lsst-sqre/squareone:tickets-DM-40262` image. You can use these images to test your application in Phalanx development environments without making a full release.

Note

Each application has its own build job in ci.yaml. Remember to add a new job when you add an application to Squareone.

Lastly, the CI workflow builds the Sphinx-based documentation site (docs/ in the repository) and pushes it https://squareone.lsst.io. The default branch is deployed to https://squareone.lsst.io/ and other branches are deployed to https://squareone.lsst.io/v/.

Preparing and making releases — release.yaml#

The release machine is driven by the release.yaml workflow, which runs the Changesets action, changesets/action. This workflow is triggered on pushes to main and operates in two modes.

Preparing releases#

First, when the changesets action detects a merge with changeset fragments in the .changeset/ directory, it creates or updates the changeset-release and associated Version packages pull request. In this pull request, the changesets action runs the changeset version command (via the ci:version script in package.json) to update the version numbers in package.json of all packages that have changed. Changesets also deletes the individual changeset fragments in .changeset/ and updates the changelogs of the affected packages.

Making releases#

When a maintainer merges the changeset-release pull request, the changesets action runs again from the main branch. This time, it creates the package releases for each package and application that has changed.

For each package/application, changesets creates a GitHub Release containing the changelog update and tags the main branch with the new version number. For example, if the Squareone application is updated, the tag is squareone@1.2.3. If the rubin-style-dictionary package is updated, the tag is @lsst-sqre/rubin-style-dictionary@1.2.3.

For public npm packages, changesets publishes the new version to the npm registry. Squareone uses GitHub Packages for its npm registry.

This workflow does not handle Docker images; see docker-release.yaml for that. However, release.yaml does effectively trigger the Docker release workflows by creating a new GitHub release.

Note

The changesets action in release.yaml uses a GitHub App, Squareone CI to issue a GitHub token rather than the default GitHub Actions token, GITHUB_TOKEN. This is because Git commits made via that default token don’t trigger further GitHub Actions workflows.

Releasing docker images — docker-release.yaml#

The docker-release.yaml workflow is triggered by a new GitHub release being published. Effectively, docker-release.yaml is triggered automatically by the release.yaml workflow when it runs the second phase of making a release.

This workflow builds and pushes the Docker images for each application, tagged according to their package.json version number. For example, if the Squareone application is updated, the full image name ghcr.io/lsst-sqre/squareone:1.2.3.