Skip to main content

Kickstarts the semantic release pipeline for your Python project

Project description

ci-starter

Kickstarts the semantic release pipeline for your Python project on GitHub. It creates a configuration file semantic-release.toml for python-semantic-release and a pipeline with reusable workflows in .github/workflows.

Usage

Prerequisites

You will have to do the flollowing things yourself:

  • Create your project:
    • Use uv to initialize your project (must be a package)
      • Fill it with some minimally meaningful content, I recommend:
        • set version to 0.0.0
        • project urls
        • keywords
        • classifiers
        • license
      • Add a dependency group for running tests (group shall contain at least your test runner, e.g. pytest)
    • Create tests (CI/CD pipeline would fail if no tests are found)
    • Format and check everything with ruff
    • Set up a trusted publisher for your project on pypi.org:
      • Workflow: continuous-delivery.yml (default workflow name)
      • Environment name: pypi
    • Set up a trusted publisher for your project on test.pypi.org:
      • Workflow: continuous-delivery.yml
      • Environment name: testpypi
    • Create a GitHub repository for your project
    • Add remote origin and its ssh address at your local clone

Create CI/CD Pipeline With ci-starter

Run these commands:

$ ci-starter psr-config
$ ci-starter workflows
$ ci-starter update-actions

The psr-config command creates the semantic-release.toml, the second one creates the workflow files (.github/workflows/*.yml), the third one fetches the current versions of the GitHub Actions used in the workflow files and updates the workflow files accordingly.

It is your responsibility to check whether it is safe to use the suggested current versions of the GitHub Actions (beware of supply chain attacks).

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

ci_starter-0.11.1.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

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

ci_starter-0.11.1-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file ci_starter-0.11.1.tar.gz.

File metadata

  • Download URL: ci_starter-0.11.1.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for ci_starter-0.11.1.tar.gz
Algorithm Hash digest
SHA256 d29a8c3a63e3786b5762a6aa7c278704e23af112d7669287aa478fef16bc6ecf
MD5 bf3343aa5c359b5356e006240236991c
BLAKE2b-256 12072e4e3c5d54a3da94b4ba9ab5bead7984edb2cde71ca8b5bdb195d235ab19

See more details on using hashes here.

Provenance

The following attestation bundles were made for ci_starter-0.11.1.tar.gz:

Publisher: continuous-delivery.yml on fleetingbytes/ci-starter

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

File details

Details for the file ci_starter-0.11.1-py3-none-any.whl.

File metadata

  • Download URL: ci_starter-0.11.1-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for ci_starter-0.11.1-py3-none-any.whl
Algorithm Hash digest
SHA256 68d138072a215db0cb1b09e4043853880937f6c16535263c4de5593904862100
MD5 3cd0f2902d68578632ceb5d78e4e85e0
BLAKE2b-256 7ad5a8c744519cc9765e19197f5132ba5dad46b0ee52dec14790b57a3d49aab0

See more details on using hashes here.

Provenance

The following attestation bundles were made for ci_starter-0.11.1-py3-none-any.whl:

Publisher: continuous-delivery.yml on fleetingbytes/ci-starter

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