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.2.tar.gz (10.6 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.2-py3-none-any.whl (2.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: dltlint-0.0.2.tar.gz
  • Upload date:
  • Size: 10.6 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.2.tar.gz
Algorithm Hash digest
SHA256 55c30c1458ef41e821dbfe3b85f74314ce3b9b886fe2b250a70e1c99ca2752cb
MD5 b0c968b2d682281d2d2d5627e58677d4
BLAKE2b-256 f5daa82b1f6cff5e59bba59dc2f9255e8641b2f857d0a26ed2ea37bc8d5f1fb0

See more details on using hashes here.

Provenance

The following attestation bundles were made for dltlint-0.0.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: dltlint-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 2.1 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b054f8c89922c4d851893c6608659c365ed47d02cedddcfaf8e9b78cfc00cb88
MD5 598cfd33e01126b01021b2efb87cd27c
BLAKE2b-256 7369427ae9981700491c13dbfb7ae7a66eb11deb210972b4d8587356249493ee

See more details on using hashes here.

Provenance

The following attestation bundles were made for dltlint-0.0.2-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