Skip to content

Using Scarb in CI

To use Scarb in your CI workflow, you need to download the Scarb binary, unpack the archive, and add the directory containing Scarb binary to your PATH variable.

GitHub Actions

The officially supported software-mansion/setup-scarb GitHub action installs Scarb on the job runner and prepares environment for optimal use with dependency caching out of the box. You can find an example of the Scarb setup in the following workflow file:

yaml
name: CI
on:
  push:
  merge_group:
  pull_request:
jobs:
  check:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v3
      - uses: software-mansion/setup-scarb@v1
        with:
          scarb-version: "2.10.0-rc.1"
      - run: scarb fmt --check
      - run: scarb test

You can use scarb-version to specify which Scarb version will be used. When it is not present, the action will resolve the version from .tool-versions file that's created when using asdf. In case there is no such file, the latest Scarb version will be installed. You can find more information in action's repository.

Go to setup-scarb repository on GitHub

GitLab CI

You can find an example of the Scarb setup in the following GitLab CI configuration.

yaml
variables:
  SCARB_VERSION: "2.10.0-rc.1"

stages:
  - check

scarb:
  stage: check
  image: ubuntu:jammy
  script:
    - apt-get update && apt-get install -y curl
    - export PATH="$HOME/.local/bin:$PATH" && curl --proto '=https' --tlsv1.2 -sSf https://docs.swmansion.com/scarb/install.sh | bash -s -- -v $SCARB_VERSION
    - scarb fmt --check
    - scarb build

CircleCI

You can find an example of the Scarb setup in the following workflow file.

yaml
version: 2.1

parameters:
  scarb_version:
    type: string
    default: "2.10.0-rc.1"

jobs:
  check:
    docker:
      - image: cimg/base:2023.03
    steps:
      - checkout
      - run:
          name: Setup Scarb
          command: |
            echo 'export PATH="$HOME/.local/bin:$PATH"' >> "$BASH_ENV"
            source "$BASH_ENV"
            curl --proto '=https' --tlsv1.2 -sSf https://docs.swmansion.com/scarb/install.sh | bash -s -- -v << pipeline.parameters.scarb_version >>
      - run: scarb fmt --check
      - run: scarb build

workflows:
  ci:
    jobs:
      - check