Skip to main content

A dbt utility for managing YAML to make developing with dbt more delightful.

Project description

dbt-osmosis

PyPI Downloads License: Apache 2.0 Streamlit App

dbt-osmosis is a Python CLI and package for dbt development workflows.

It centers on four primary surfaces:

  • schema YAML management (yaml organize, yaml document, yaml refactor)
  • column-level documentation inheritance across dbt lineage
  • ad-hoc SQL compile/run helpers
  • an optional Streamlit workbench for interactive dbt SQL development

The repository also ships additional command families for generation, natural-language helpers, schema diffing, SQL linting, and test suggestions.

The Docusaurus site is the canonical reference for the current CLI, configuration model, support matrix, and workflow guides:

dbt-osmosis

Supported runtime

dbt-osmosis currently targets:

  • Python 3.10-3.13
  • dbt Core 1.8+ package resolution
  • a dbt adapter version compatible with the dbt Core runtime in that environment

Audited blocking support covers dbt Core 1.8.x through 1.11.x in CI. The package metadata intentionally remains dbt-core>=1.8 without an upper bound so installers can resolve newer dbt releases. Future dbt Core minors are canary-only until explicitly audited; scheduled/manual canary CI uses unpinned latest dbt-core and dbt-duckdb to make upstream breakage visible without redefining audited support. Install a dbt adapter version that is compatible with the dbt Core runtime in your environment; adapter compatibility is owned by the adapter and dbt Core pairing, not by dbt-osmosis extras.

Optional extras:

  • dbt-osmosis[workbench] for the Streamlit workbench and related UI dependencies
  • dbt-osmosis[duckdb] for the DuckDB adapter used by the demo project and local fixture workflows
  • dbt-osmosis[openai] for LLM-assisted synthesis and natural-language generation features
  • dbt-osmosis[azure] for Azure AD authentication used with Azure OpenAI
  • dbt-osmosis[proxy] only installs dependencies for the experimental opt-in SQL proxy runtime; it does not expand the supported product surface, start a proxy server, configure authentication, TLS, or listen/bind settings, or make comment middleware durable. The proxy module entrypoint is a local-only experiment with mysql-mimic defaults, not a hardened user-facing server; do not expose it to untrusted networks. The proxy comment middleware is in-memory only, and ticket:c10proxy25 owns proxy support semantics.

Install

With uv:

uv tool install --with="dbt-<adapter>" dbt-osmosis

With pip:

pip install "dbt-osmosis" "dbt-<adapter>"

Replace <adapter> with your dbt adapter package, for example duckdb, snowflake, bigquery, postgres, or redshift.

Quick start

  1. Configure YAML routing in dbt_project.yml:
models:
  your_project_name:
    +dbt-osmosis: "_{model}.yml"
  1. Optionally set per-folder behavior with +dbt-osmosis-options and a repo-level YAML formatter in dbt-osmosis.yml:
formatter: "prettier --write"
  1. Preview changes safely:
dbt-osmosis yaml refactor --dry-run --check
  1. Apply the update once the diff looks right:
dbt-osmosis yaml refactor --auto-apply

CLI surface

Top-level commands currently exposed by dbt-osmosis --help:

  • yaml — manage schema YAML files and documentation inheritance
  • sql — compile or run ad-hoc SQL in dbt context
  • workbench — launch the Streamlit workbench
  • generate — generate sources, staging models, models, and SQL
  • nl — natural-language query/model helpers
  • test — suggest dbt tests
  • test-llm — validate LLM client configuration
  • diff — report schema drift between YAML and the database
  • lint — lint SQL strings, models, or a whole project

For command-by-command flags and examples, use the docs-site CLI reference rather than relying on this landing page.

Developer tooling

Local development in this repository is built around uv, task, and Ruff.

Common workflows:

task format
task lint
task test

Notes:

  • Ruff is the active formatter, linter, and import sorter.
  • task is not just verification; the default task formats, lints, runs tests, and then ensures the dev environment is synced.
  • Repository test fixtures are DuckDB-only today; contributor examples use demo_duckdb, and targeted core tests may need uv run dbt parse --project-dir demo_duckdb --profiles-dir demo_duckdb -t test to refresh demo_duckdb/target/manifest.json.
  • Docs-site commands use the Node toolchain under docs/:
npm --prefix docs run start
npm --prefix docs run build
npm --prefix docs run serve

Workbench

The optional workbench is a Streamlit app for interactive dbt SQL development.

Install the extra and launch it with:

pip install "dbt-osmosis[workbench]" "dbt-<adapter>"
dbt-osmosis workbench

The hosted demo is linked from the badge at the top of this README.

Pre-commit hook

You can run dbt-osmosis yaml refactor -C as a pre-commit hook:

repos:
  - repo: https://github.com/z3z1ma/dbt-osmosis
    rev: v1.3.0
    hooks:
      - id: dbt-osmosis
        files: ^models/
        args: [--target=prod]
        additional_dependencies: [dbt-<adapter>]

That hook keeps schema YAML changes visible in the commit that introduced them.

Project details


Release history Release notifications | RSS feed

This version

1.4.0

Download files

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

Source Distribution

dbt_osmosis-1.4.0.tar.gz (16.7 MB view details)

Uploaded Source

Built Distribution

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

dbt_osmosis-1.4.0-py3-none-any.whl (194.3 kB view details)

Uploaded Python 3

File details

Details for the file dbt_osmosis-1.4.0.tar.gz.

File metadata

  • Download URL: dbt_osmosis-1.4.0.tar.gz
  • Upload date:
  • Size: 16.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dbt_osmosis-1.4.0.tar.gz
Algorithm Hash digest
SHA256 0feb6500ba6103dfde2ad1f456842cbb06a5294ece11b114e44420e584ee0d7c
MD5 b163adc07b055f368f6930993b663367
BLAKE2b-256 8b50d6b5014202be9d23fd56ca7811282bbb33a9b245e6b138a5d8cb00aeba00

See more details on using hashes here.

File details

Details for the file dbt_osmosis-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: dbt_osmosis-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 194.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dbt_osmosis-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ad9b79e0a0ca64baa0e9919aba2d4bbc001dcc86db2bdca9f06abb3a28ee11ec
MD5 ee6639ea41bbeb4182ba0bbbd2aead63
BLAKE2b-256 3ddd002499a8bec85036120c3239f0f9a8982ae2d7c8d479a3842367221fd114

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