Skip to main content

The python library for CI/CD of ESP-IDF projects

Project description

idf-ci

Documentation Status Python 3.7+

A tool designed to streamline the CI/CD of ESP-IDF projects, with support for both GitLab CI/CD and GitHub Actions.

Installation

pip install -U idf-ci

Key Features

  • Sensible Defaults

    Easy setup with default settings for idf-build-apps and pytest-embedded

  • Build Management

    Build ESP-IDF apps for multiple targets (ESP32, ESP32-S2, ESP32-C3, etc.) with parallel builds and smart filtering based on changed files or test needs.

  • Test Management

    Run pytest with ESP-IDF configs, including target-specific test discovery and marker filtering.

  • GitLab CI/CD Integration

    Full pipeline support with artifacts, S3 uploads, and auto-generated jobs for builds and tests.

  • GitHub Actions Integration

    Generate test matrix from project settings.

Basic Usage

Initialize Configuration Files

# Create .idf_ci.toml with default idf-ci settings
idf-ci init

# Create .idf_build_apps.toml with default build settings
idf-ci build init

# Create pytest.ini with default test settings
idf-ci test init

Build Apps

# Build all apps
idf-ci build run

# Build apps for specific target
idf-ci build run -t esp32

# Build only test-related apps
idf-ci build run --only-test-related

# Preview what would be built (dry run)
idf-ci build run --dry-run

Run Tests

We implement a pytest plugin to run tests with sensible defaults with another plugin pytest-embedded

# Only collect tests that would run
pytest --collect-only

# Run tests with target esp32
pytest --target esp32

Documentation

For detailed usage and configuration options, please refer to the documentation.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

idf_ci-1.0.0b2.tar.gz (65.1 kB view details)

Uploaded Source

Built Distribution

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

idf_ci-1.0.0b2-py3-none-any.whl (60.7 kB view details)

Uploaded Python 3

File details

Details for the file idf_ci-1.0.0b2.tar.gz.

File metadata

  • Download URL: idf_ci-1.0.0b2.tar.gz
  • Upload date:
  • Size: 65.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for idf_ci-1.0.0b2.tar.gz
Algorithm Hash digest
SHA256 a29308f8ea7b8fe79c2615ab4c156f54e2b408964c92f96e99819cde3ee0ebc5
MD5 9424c473f6a7b6b44e9b9ce6546b6d4d
BLAKE2b-256 c1f00a4c8c47730e32fe16488c08221c71bda17e6b5a31a3b864e267cf16d9dd

See more details on using hashes here.

Provenance

The following attestation bundles were made for idf_ci-1.0.0b2.tar.gz:

Publisher: publish-to-pypi.yml on espressif/idf-ci

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

File details

Details for the file idf_ci-1.0.0b2-py3-none-any.whl.

File metadata

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

File hashes

Hashes for idf_ci-1.0.0b2-py3-none-any.whl
Algorithm Hash digest
SHA256 187c3f12a4b58c0c30716f8aea2f6936347bd9990a542c0a51c5424abe16c66d
MD5 f6c3dc8df5a75478a2ee6b44461d1f49
BLAKE2b-256 6354838f00a0f8257960698b1aefc8c1baf6e7e102ed504c9e1d334520e7ff19

See more details on using hashes here.

Provenance

The following attestation bundles were made for idf_ci-1.0.0b2-py3-none-any.whl:

Publisher: publish-to-pypi.yml on espressif/idf-ci

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