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.0.tar.gz (26.0 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.0-py3-none-any.whl (31.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: yardmaster-0.1.0.tar.gz
  • Upload date:
  • Size: 26.0 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.0.tar.gz
Algorithm Hash digest
SHA256 319b79087c0c48386933c3519f4ab65d00adfbe11bb4c24c1c7ae3a76b030fd7
MD5 1cf0f3f9a97e649ac6f89ab12d3b8d7a
BLAKE2b-256 62ab5e07840dcb8c118aead181cafda40103dd4457d06ab471a4f56212c6d131

See more details on using hashes here.

File details

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

File metadata

  • Download URL: yardmaster-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 31.5 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 85bd3ea4dedd949ec565449a087c10f881d3c8d0f16e7ccfcf08b4b16b6ec175
MD5 90a693aa0341064b0fdeafd7a126fb41
BLAKE2b-256 eb10e2900021b6243aa3258954d64d13d7ab640a551191149baeb524503fc4aa

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