Skip to main content

Package for running Soda Core data quality scans in Dagster.

Project description

dagster-soda

PyPI version

dagster-soda integrates Soda Core data quality checks with Dagster. It provides the SodaScanComponent, a Dagster component that runs Soda Core scans and maps SodaCL check results to Dagster asset checks.

Installation

pip install dagster-soda

Note: dagster-soda requires soda-core 3.x (the soda.scan API). It pins soda-core>=3.0,<4 by default.

Usage

Component: SodaScanComponent

Configure a SodaScanComponent in your Dagster project to:

  • Point at SodaCL YAML check files and a Soda configuration.yml
  • Map Soda dataset names to Dagster asset keys
  • Run scans and report pass/fail as Dagster asset check results

Scaffolding with the CLI

Use the Dagster CLI to scaffold a new Soda scan component in your project (requires dagster-dg-cli):

dg scaffold defs dagster_soda.SodaScanComponent <path>

Example (scaffold into a folder named soda_checks under your defs directory):

dg scaffold defs dagster_soda.SodaScanComponent soda_checks

This generates:

  • A defs.yaml with default attributes (checks_paths, configuration_path, data_source_name, asset_key_map)
  • A checks.yml template with example SodaCL (e.g. checks for my_table: - row_count > 0)

Edit the generated files to match your data source and checks, then load your definitions as usual.

Minimal defs.yaml example

type: dagster_soda.SodaScanComponent
attributes:
  checks_paths:
    - checks.yml
  configuration_path: configuration.yml
  data_source_name: my_datasource
  asset_key_map:
    my_table: my_table

Documentation

The docs for dagster-soda can be found here.

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

dagster_soda-0.29.7.tar.gz (201.5 kB view details)

Uploaded Source

Built Distribution

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

dagster_soda-0.29.7-py3-none-any.whl (12.1 kB view details)

Uploaded Python 3

File details

Details for the file dagster_soda-0.29.7.tar.gz.

File metadata

  • Download URL: dagster_soda-0.29.7.tar.gz
  • Upload date:
  • Size: 201.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for dagster_soda-0.29.7.tar.gz
Algorithm Hash digest
SHA256 2b8e3343ba3a388b5f28dcbc676c395db3a32a339de21e4f827c4af8261bf49b
MD5 89b74b5e8f4e34694bc5b8df24e9e189
BLAKE2b-256 166dd38461701894ffa2b9fd05a6935542cd5e449bf1692066fb21ccee67bd92

See more details on using hashes here.

File details

Details for the file dagster_soda-0.29.7-py3-none-any.whl.

File metadata

  • Download URL: dagster_soda-0.29.7-py3-none-any.whl
  • Upload date:
  • Size: 12.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for dagster_soda-0.29.7-py3-none-any.whl
Algorithm Hash digest
SHA256 f3ab0e8a7cb1373cbedc2dd5d0705720342f696c59f301b63ee4f165ef7186cb
MD5 3834217387bcd286fb4ed9b6602431c0
BLAKE2b-256 6ebbcc97de2bf11a9c4ab1c2e909ea597496f0c9527b8ef41d36458a9a4edcf2

See more details on using hashes here.

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