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
mainbranch - 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-onfield 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_regexblock as shown in the configuration below
- Defaults to checking the pattern
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-branchconcourse-check-timeoutconcourse-check-pr-statusesconcourse-check-pr-contextsgithub-check-timeoutgithub-check-runs-ongithub-check-workflow-callsgithub-check-action-callsgithub-check-output-wiringgithub-check-needs-wiringgithub-check-input-wiringgithub-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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file bagcheck-0.2.8.tar.gz.
File metadata
- Download URL: bagcheck-0.2.8.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
90eecc1e7fb52a84fe9e1e58c708a9f610e0e64dc981fdfd7ec77c078ce92605
|
|
| MD5 |
90d494a9f03ece3211376e2ceb7022cb
|
|
| BLAKE2b-256 |
2c7f3892ca8725fac077413cb4d0f3100bc1ca4c96fdd9b150dbd5bee3fdd2c7
|
File details
Details for the file bagcheck-0.2.8-py3-none-any.whl.
File metadata
- Download URL: bagcheck-0.2.8-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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f31959808319335b8371ed8dda837edd617dda12926fc926a7c86b5e90113428
|
|
| MD5 |
2d052b9f394768616c0861ed235eba20
|
|
| BLAKE2b-256 |
92c3583f40537cf4ef0e22814db5e392129d8b47e2a5ae5404263a21fa6c28f7
|