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

Uploaded Python 3

File details

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

File metadata

  • Download URL: tenzir_ship-1.7.1.tar.gz
  • Upload date:
  • Size: 139.8 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.1.tar.gz
Algorithm Hash digest
SHA256 2aebcc00f7d2a312572059f3763273b3b0a93679e70572b076482bad123388bd
MD5 559f88d1f7af417b2d617ba9e00f1977
BLAKE2b-256 bdf0904248e884d9fcf691cc003850a0733739a2cc9f2fa4a7cebcdf888173c3

See more details on using hashes here.

Provenance

The following attestation bundles were made for tenzir_ship-1.7.1.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.1-py3-none-any.whl.

File metadata

  • Download URL: tenzir_ship-1.7.1-py3-none-any.whl
  • Upload date:
  • Size: 88.5 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9e869696e1ee54e5abfe21be247dfe5540ed24683774f9e2aa39bd70af7b0893
MD5 096d731cca1d15ac22fefbb75d82afe9
BLAKE2b-256 7a1a8a41b3192618ad8d663a87e8df3572ac0aad7809b281172b8079332e3e1d

See more details on using hashes here.

Provenance

The following attestation bundles were made for tenzir_ship-1.7.1-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