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.1.tar.gz (150.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.1-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: yardmaster-0.1.1.tar.gz
  • Upload date:
  • Size: 150.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.1.tar.gz
Algorithm Hash digest
SHA256 9198e8653d327f44353d816b89a73c78dd7cf36928703997c38d6d38a9cbde6e
MD5 70e4ee9d5d000bf1d5d790bb3e414b7e
BLAKE2b-256 1f7472b4d003aee5ef7f8677e46ec57fce4f3070726e90d5b9d0e603407be45a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: yardmaster-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 32.1 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 37099dc89b61fd78cd91c208b2df28c3baafdd395bf5bd60bd38bdb33c4da784
MD5 13bdcaf270d73f2b5ed663d1ffa86755
BLAKE2b-256 18c5af34c9c25d7b40810e94495ca66f9ae2359bf33249fcdf9555b05c364857

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