Skip to main content

Flatcar Container Linux Release Management Tool

Project description

Yardmaster

Yardmaster is a release management tool for Flatcar Container Linux. It automates release orchestration across multiple channels (Alpha, Beta, Stable, LTS) and provides commands to prepare, validate, and tag releases.

Requirements

  • Python 3.10+
  • uv for environment and dependency management

Setup

# Install dependencies
make dev-install

# Copy and edit the config file
cp .yardmaster.yaml.sample .yardmaster.yaml
# Edit .yardmaster.yaml with your values

Required environment variables

The config template references these env vars:

  • JENKINS_USER and JENKINS_TOKEN for Jenkins
  • GPG_KEY_ID if GPG signing is enabled

Export them before running release commands.

Release workflow

# 1. Initialize release state from a GitHub issue
yardmaster release init https://github.com/flatcar/Flatcar/issues/1234

# 2. Check status
yardmaster status

# 3. Run pre-release steps (tagging, branching, Jenkins builds)
yardmaster release run --pre

# 4. Run post-release steps
yardmaster release run --post

# 5. Mark release as done
yardmaster release complete

Use --dry-run on any step to preview without making changes.

Useful options:

  • --dry-run: show actions without executing them
  • --skip-jenkins: skip triggering Jenkins builds
  • --skip-issue-check: skip GitHub issue title verification
  • --force: force tag creation if it already exists
  • -v: verbose logging

Retag

Retag a channel mid-release:

yardmaster retag alpha

Status

View configured channels, planned releases, and release state:

yardmaster status
yardmaster status --show-sdk
yardmaster status --json

SDK

Determine SDK versions for upcoming releases:

yardmaster sdk determine alpha:3800.0.0

Jenkins

Trigger a Jenkins PR build:

yardmaster jenkins pr-build --dry-run flatcar scripts 1234

Development

make dev-install   # install dev dependencies
make test          # run tests
make lint          # lint
make format        # auto-format
make type-check    # mypy
make check         # all of the above
make fix           # auto-fix formatting + lint
make all           # fix + check + build
make clean         # remove build artifacts
make help          # list all targets

Notes

  • Default config path: .yardmaster.yaml
  • Sample config: .yardmaster.yaml.sample
  • Workspace default: ~/.yardmaster/workspace
  • Logs default: ~/.yardmaster/yardmaster.log

Troubleshooting

If you see Config file not found, copy the sample config:

cp .yardmaster.yaml.sample .yardmaster.yaml

Then edit it with your values.

Configuration

Yardmaster looks for .yardmaster.yaml in the current directory by default. You can override this with:

  • YARDMASTER_CONFIG environment variable:

    export YARDMASTER_CONFIG=~/my-project/.yardmaster.yaml
    yardmaster status
    
  • -c flag (takes precedence over the env var):

    yardmaster -c /path/to/config.yaml status
    

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

yardmaster-0.1.2.tar.gz (150.6 kB view details)

Uploaded Source

Built Distribution

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

yardmaster-0.1.2-py3-none-any.whl (33.3 kB view details)

Uploaded Python 3

File details

Details for the file yardmaster-0.1.2.tar.gz.

File metadata

  • Download URL: yardmaster-0.1.2.tar.gz
  • Upload date:
  • Size: 150.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Fedora Linux","version":"43","id":"","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for yardmaster-0.1.2.tar.gz
Algorithm Hash digest
SHA256 97d5282fefc59283034e7a0b503991339f093087be89ba7dc80f0292ca2f5233
MD5 e71c514efe68dcecb87cdb5d51165c74
BLAKE2b-256 9c891c6928e43a42f055ee5d16cb0805e94657965349ca1d4dbf2415d8d14f50

See more details on using hashes here.

File details

Details for the file yardmaster-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: yardmaster-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 33.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Fedora Linux","version":"43","id":"","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for yardmaster-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 47ff7420ccaf84cc5fec37b1327c3b4df1b51d80870fc35f13c26defd1cdd6d4
MD5 c12274e9ec32c08cb87bc9ccb8e927f0
BLAKE2b-256 363dcff54bfd0dba412df24c7f68c8e4708840bf1fe510907ddcb9c7119365b0

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