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.2.tar.gz (8.4 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.2-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ci_starter-0.3.2.tar.gz
  • Upload date:
  • Size: 8.4 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.2.tar.gz
Algorithm Hash digest
SHA256 9524d22cdc3ce172571e8d6d19feba4faee09759b13f3be33cceba9bde795108
MD5 78d573e3040d351a0050bf629e356a36
BLAKE2b-256 b3098dbe9823c61adb64c72256b013b66ea356864fc024b9d9ae5e27d938520a

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: ci_starter-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 14.3 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 787fef3638280f11c83595a6550ac32e4f7259d685570ff7aaee1cb3cc001182
MD5 21b66da4a55d17e780a9a1d7e1580f97
BLAKE2b-256 2ddb9d4b6974a52a76bb68ca7220298b481bdd964fba6541d3872903a6eded09

See more details on using hashes here.

Provenance

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