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.2.0.tar.gz (3.6 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.2.0-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ci_starter-0.2.0.tar.gz
  • Upload date:
  • Size: 3.6 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.2.0.tar.gz
Algorithm Hash digest
SHA256 188217da8f0806f62b0523f507626047aab5b1106d1902eeb94e792051b86ffe
MD5 222cf99323d71987fcae901a2ea60771
BLAKE2b-256 f70f48e292cafc3857c785542ebc05c7533060006a2b1927dc20b66ceee442d5

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: ci_starter-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 5.5 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6cc5b8297ebf862fd34c0fa36852d147c29a420230b21387758f1f5606b8afab
MD5 1fce6e88051d5d4eb13757b8f0b63b4f
BLAKE2b-256 aad6fde80a4cb9d1f85536459aa6fe1be34bf11b6050ebaf6ac5d3756062e702

See more details on using hashes here.

Provenance

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