Skip to main content

Kick-starts the semantic release pipeline for your Python project

Project description

ci-starter

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

Usage

Prerequisites

  • 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
      • 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

  • run ci-start (not ci-starter) in the project directory:
ci-start \
    --module-name my_app \
    --package-name my-app \
    --workflow-file continuous_delivery.yml \
    --test-group test`
    --test-command "uv run -- pytest -v"
    .

That should create you a configuration file (semantic-release.toml) and some workflow files (.github/workflows/*.yml) to start with.

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.3.1.tar.gz (8.3 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.3.1-py3-none-any.whl (13.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for ci_starter-0.3.1.tar.gz
Algorithm Hash digest
SHA256 087807c25920bc88059e9a29fb12f6b11bc1fd109515fc6bfaba62de54f2ba35
MD5 9994638501e6447a03938abad15a1318
BLAKE2b-256 6a3ec5f5cac7376a1e1c7eb12f2038ba2c98229061a563deb873b08045ef5532

See more details on using hashes here.

Provenance

The following attestation bundles were made for ci_starter-0.3.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.3.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for ci_starter-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bcb31837139ffef997e88a9eed71cc68208eba7d6cb20b8e9aa0e145da8cbfca
MD5 15263da011826d0befec2c545a96cd71
BLAKE2b-256 08661c78d42f7a61474a8763305fb9e5307313af6865dc83ae1cf07ec8e1c455

See more details on using hashes here.

Provenance

The following attestation bundles were made for ci_starter-0.3.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