Skip to main content

Reusable changelog management toolkit for Tenzir repositories.

Project description

🚀 tenzir-ship

tenzir-ship helps you ship faster with automated release engineering. Manage changelogs, generate release notes, and publish GitHub releases.

✨ Highlights

  • 📝 Changelog management: Capture entries via an interactive assistant that pulls metadata from Git and GitHub, pre-filling authors and PR references.
  • 📦 Release notes: Generate release notes from structured entries, ready for documentation pipelines or direct publishing.
  • 🚀 GitHub releases: Publish releases directly to GitHub with generated notes and assets.
  • 🔖 Opinionated versioning: Release manifests and package files use bare semantic versions such as 1.2.3, while Git and GitHub releases are tagged as v1.2.3.
  • 🔧 CLI and Python API: Use the command line for interactive workflows or the Python API for automation.

📦 Installation

tenzir-ship ships on PyPI. Use uvx to fetch and execute the latest compatible version on demand (requires Python 3.12+):

uvx tenzir-ship --help

uvx downloads the newest release, runs it in an isolated environment, and caches the result for snappy subsequent invocations.

🤖 Agent Skill

Install the skill via Vercel Skills:

npx skills add tenzir/ship

🛠️ Reusable GitHub Actions workflow

This repository ships a reusable release workflow at .github/workflows/release.yaml. External repositories can call it directly. Pin the workflow to a released tag or full commit SHA instead of a moving branch name.

jobs:
  release:
    uses: tenzir/ship/.github/workflows/release.yaml@<pinned-ref>
    permissions:
      contents: write
    with:
      intro: This release improves parser coverage and fixes packaging.
      bump: auto

The workflow supports GitHub App tokens, static push tokens, GPG signing, pre/post hooks, and several release-control options. See the reference for the full list of inputs, secrets, and auth modes.

📚 Documentation

Consult our user guide for an end-to-end walkthrough of maintaining changelogs.

We also provide a dense reference that explains concepts, abstractions, and CLI details.

🐶 Dogfooded Project

The repository ships with changelog/, the real changelog project maintained by the Tenzir team. Explore it to see how config.yaml, unreleased/, and Markdown release manifests fit together end-to-end.

🤝 Contributing

Want to contribute? We're all-in on agentic coding with Claude Code! The repo comes pre-configured with our custom plugins—just clone and start hacking.

📄 License

tenzir-ship is released under the Apache License, Version 2.0. Consult LICENSE for the full text.

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

tenzir_ship-1.7.3.tar.gz (138.6 kB view details)

Uploaded Source

Built Distribution

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

tenzir_ship-1.7.3-py3-none-any.whl (86.6 kB view details)

Uploaded Python 3

File details

Details for the file tenzir_ship-1.7.3.tar.gz.

File metadata

  • Download URL: tenzir_ship-1.7.3.tar.gz
  • Upload date:
  • Size: 138.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tenzir_ship-1.7.3.tar.gz
Algorithm Hash digest
SHA256 18b2de98239f0441148c51e015bba3a5283e54444f489de6046e1fbe2f4b9ec4
MD5 baea07b1dad182cd27d119bb14abf62a
BLAKE2b-256 c0b194de4109a446fac5f941dbdd3af7e2d9e9008fdfd11926f64c8aba5c552b

See more details on using hashes here.

Provenance

The following attestation bundles were made for tenzir_ship-1.7.3.tar.gz:

Publisher: publish.yaml on tenzir/ship

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tenzir_ship-1.7.3-py3-none-any.whl.

File metadata

  • Download URL: tenzir_ship-1.7.3-py3-none-any.whl
  • Upload date:
  • Size: 86.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tenzir_ship-1.7.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5d014e72748cc7ad7e8f2f4774c9ed6ad4210769175b4d70979d01f355a7e0ea
MD5 757f9677503705b46258fdf6b83f9219
BLAKE2b-256 7efb02c2d5c994afc07a4b14c9198ec83061243c5ae9c7db686a51a6a17d62b4

See more details on using hashes here.

Provenance

The following attestation bundles were made for tenzir_ship-1.7.3-py3-none-any.whl:

Publisher: publish.yaml on tenzir/ship

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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