Skip to main content

A pipeline validation tool for Concourse and GitHub Actions

Project description

BagCheck

About

bagcheck is a relatively simply command line utility developed to make validating Concourse pipelines simpler. To accomplish this, bagcheck has the following functionality:

Checking a pipeline

Concourse

To check your pipeline, simply run:

bagcheck check -f /path/to/your/concourse/pipeline.yaml

at which point bagcheck will proceed to check for the following conditions:

  • All git resources are pointed at the main branch
  • All PR resource puts in the same job have the same context
  • All PR statuses are accounted for in a job (success, failure, error, pending)
  • All jobs have a timeout set

GitHub Actions

To check your pipeline, run:

bagcheck check -f /path/to/your/github/workflow-or-action.yaml

at which point bagcheck will proceed to check for the following conditions:

  • All jobs have timeouts set
  • All jobs have the required runs-on field set
  • All workflow calls pass the required inputs
  • All action calls pass the required inputs
  • All output references reference an output that actually exists
  • All input references reference an input that actually exists
  • All needs.<job>... references reference a job that is:
    • Present in the needs block of the job referencing it
    • Actually outputs the output specified
  • All external action/workflow references use the allowed ref format
    • Defaults to checking the pattern v[0-9](\.[0-9]){0,2}"
    • To change the regex pattern, configure the config.ref_regex block as shown in the configuration below

Configuring Bagcheck

Sometimes you want to skip a check across the board (e.g. you don't want timeouts in a specific pipeline) or you only want to disable a check for a specific job/resource. To do this, you'll use a .bagcheck file.

An example file looks something like this:

config:
  ref_regex: v[0-9](\.[0-9]){0,2}
disable:
  global:
    - concourse-check-main-branch
    - ...
  local:
    - path: '$.jobs[?(@.name = "job-name-1")]'
      tests:
        - concourse-check-pr-statuses
        - ...
    - path: '$.jobs[?(@.name = "job-name-2")]'
      tests:
        - concourse-check-timeout
        - ...
    - ...
warn:
  global:
    - github-check-ref
    - ...
  local:
    - path: '$.jobs[?(@.name = "job-name-1")]'
      tests:
        - github-check-action-calls
        - ...
    - ...

with any check listed under the disable.global key being completely disabled and the tests under each path being disabled when the job meets that JSONPath criteria (the ellipsis denote that you can include as many as you want in each section).

Additionally, adding any check to warn.global will result in all errors being ignored for that check and warning statements being printed instead of errors. Additionally, you can configure the same thing locally in the same manner as the local disables

Currently the following tests are run and as a consequence can be disabled:

  • concourse-check-main-branch
  • concourse-check-timeout
  • concourse-check-pr-statuses
  • concourse-check-pr-contexts
  • github-check-timeout
  • github-check-runs-on
  • github-check-workflow-calls
  • github-check-action-calls
  • github-check-output-wiring
  • github-check-needs-wiring
  • github-check-input-wiring
  • github-check-ref

One thing to note is that bagcheck will first attempt to read a file located at ~/.bagcheck and then will attempt to read one at the current working directory, combining the values with whatever is located in your ~/.bagcheck file.

Summarizing a pipeline

Having to read through a 1000+ line YAML file can make it hard to understand what the pipeline is doing on a conceptual level as well as how everything ties together. To help with this, you can run:

bagcheck summary -f /path/to/your/pipeline.yaml

at which point bagcheck will print out a summarized version of your pipeline

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bagcheck-0.2.9.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bagcheck-0.2.9-py3-none-any.whl (21.5 kB view details)

Uploaded Python 3

File details

Details for the file bagcheck-0.2.9.tar.gz.

File metadata

  • Download URL: bagcheck-0.2.9.tar.gz
  • Upload date:
  • Size: 17.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.11.1 Linux/6.6.87.2-microsoft-standard-WSL2

File hashes

Hashes for bagcheck-0.2.9.tar.gz
Algorithm Hash digest
SHA256 a78ba3e0b00a6cc364d570e444a482d3b19eb5cb6ef8191b3a1b331b232710ae
MD5 1b48928ec6713c79a9274f0ba2d9a279
BLAKE2b-256 56df10a1b227667ddd8c5639d4321f6cf278bb8fd31b7218dc009f32fa743a1b

See more details on using hashes here.

File details

Details for the file bagcheck-0.2.9-py3-none-any.whl.

File metadata

  • Download URL: bagcheck-0.2.9-py3-none-any.whl
  • Upload date:
  • Size: 21.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.5 CPython/3.11.1 Linux/6.6.87.2-microsoft-standard-WSL2

File hashes

Hashes for bagcheck-0.2.9-py3-none-any.whl
Algorithm Hash digest
SHA256 ed199d8999b9ad3381a936cf08de76fa5db033da3cb37cd3f719cf8ccb14d9b3
MD5 fc3681f1ce36043f6c4cf2a8787b487e
BLAKE2b-256 74b0766e5a27c05f2b6aa01fe540d7a8e52f7658c800991b58314b142b344dc0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page