Skip to main content

Linter for Databricks DLT pipelines

Project description

dltlint

Lint Databricks Lakeflow (DLT) pipeline YAML/JSON files.

Installation

pip install dltlint

Usage CLI

# Lint current repo recursively
dltlint 

# JSON output for tooling
dltlint --format json .

# Fail build on warnings or worse
dltlint --fail-on warning .

# Print a success message when clean (otherwise silent on success)
dltlint --ok .

Exit codes

  • 0 → clean OR no matching files
  • 1 → findings at/above threshold (--fail-on)
  • 2 → fatal error (e.g., unreadable file)

dltlint discovers:

  • *.pipeline.yml,
  • *.pipeline.yaml
  • *.pipeline.yml.resources,
  • *.pipeline.yaml.resources

Pre-commit

A) Use the repo’s published hook Add to your repo’s .pre-commit-config.yaml: repos:

  • repo: https://github.com/dan1elt0m/dltlint rev: v0.0.1 # tag or commit hooks:
    • id: dltlint

      By default the hook runs from repo root and scans recursively.

      If you prefer to pass staged files only, uncomment:

      pass_filenames: true

      args: ["--fail-on", "error"]

Config (pyproject.toml)

[tool.dltlint]
fail_on = "warning"                       # default: "error"
ignore = ["DLT010", "DLT400"]             # suppress specific rules
require = ["catalog", "schema"]           # fields that must be present
inline_disable_token = "dltlint: disable" # comment token (see below)

[tool.dltlint.severity_overrides]
DLT400 = "info"

Inline suppressions

Add a comment anywhere in a file to suppress rules for that file:

# dltlint: disable=DLT010,DLT400
resources:
  pipelines:
    my_pipe:
      name: n
      catalog: c
      schema: s

Line-scoped suppressions require YAML line tracking and are not supported yet.

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

dltlint-0.0.3.tar.gz (10.8 kB view details)

Uploaded Source

Built Distribution

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

dltlint-0.0.3-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file dltlint-0.0.3.tar.gz.

File metadata

  • Download URL: dltlint-0.0.3.tar.gz
  • Upload date:
  • Size: 10.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dltlint-0.0.3.tar.gz
Algorithm Hash digest
SHA256 f594eda0351f86f555ddf03a58794012b745ddac621b452238b5378e755b8f87
MD5 38a77db4c4282d0d7c417108da470c33
BLAKE2b-256 bb9c4a31ee9a979289c6b6c4681b4c59f9676ecd583bf992e632ec6ecbb67856

See more details on using hashes here.

Provenance

The following attestation bundles were made for dltlint-0.0.3.tar.gz:

Publisher: build-and-publish.yml on dan1elt0m/dltlint

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

File details

Details for the file dltlint-0.0.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for dltlint-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 11abe26f40389e107fc5e8c24298655ba7945c1a1d92bf16eac59fcbebfef27c
MD5 3432c4f1a29447a3b4647bdf10f6e933
BLAKE2b-256 e4a8679ed1c0d9d0f7c06cc4436f9995832b309526d15f8fe899315d16698136

See more details on using hashes here.

Provenance

The following attestation bundles were made for dltlint-0.0.3-py3-none-any.whl:

Publisher: build-and-publish.yml on dan1elt0m/dltlint

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