Linter for dbt metadata.
Project description
dbt-score
A comprehensive linter for dbt metadata that helps maintain high-quality data models at scale.
dbt-score lint
🥉 orders (score: 2.7)
WARN (medium) dbt_score.rules.generic.columns_have_description: Columns lack a description: customer_id, customer_name.
WARN (high) dbt_score.rules.generic.has_description: Model lacks a description.
WARN (medium) dbt_score.rules.generic.has_owner: Model lacks an owner.
WARN (medium) dbt_score.rules.generic.sql_has_reasonable_number_of_lines: SQL query too long: 238 lines (> 200).
WARN (medium) dbt_score_rules.custom_rules.has_test: Model lacks a test.
What is dbt-score?
dbt-score is a powerful linting tool designed to evaluate and score dbt
(Data Build Tool) models based on metadata quality. It helps data teams maintain
consistent standards across dbt projects by programmatically enforcing best
practices for documentation, testing, naming conventions, and more.
Key Features
- 🔍 Comprehensive Linting: Evaluates dbt entities against configurable rules for documentation, tests, naming, and structure
- 📊 Scoring System: Provides numerical scores (0-10) for individual models and overall project health
- 🎯 Flexible Configuration: Customizable rules, severity levels, and
scoring thresholds via
pyproject.toml - 🚀 CI/CD Integration: Fail builds when quality standards aren't met
- 📈 Progress Tracking: Visual badges and scoring to track data quality improvements over time
- 🔧 Extensible: Create custom rules tailored to organization-specific needs
Quick Start
Installation
pip install dbt-score
Note: Install
dbt-scorein the same environment asdbt-core.
Basic Usage
Run dbt-score from your dbt project root:
# Basic linting
dbt-score lint
# Also show passing tests
dbt-score lint --show all
# Lint specific models
dbt-score lint --select +my_model+
# Auto-generate manifest (via `dbt parse`) and lint
dbt-score lint --run-dbt-parse
Example Output
dbt-score lint --show all
🥉 orders (score: 2.7)
WARN (medium) dbt_score.rules.generic.columns_have_description: Columns lack a description: customer_id, customer_name.
WARN (high) dbt_score.rules.generic.has_description: Model lacks a description.
WARN (medium) dbt_score.rules.generic.has_owner: Model lacks an owner.
WARN (medium) dbt_score.rules.generic.sql_has_reasonable_number_of_lines: SQL query too long: 238 lines (> 200).
WARN (medium) dbt_score_rules.custom_rules.has_test: Model lacks a test.
🥇 customers (score: 10.0)
OK dbt_score.rules.generic.columns_have_description
OK dbt_score.rules.generic.has_description
OK dbt_score.rules.generic.has_owner
OK dbt_score.rules.generic.sql_has_reasonable_number_of_lines
OK dbt_score_rules.custom_rules.has_test
Project score: 6.3 🥈
Configuration
Configure dbt-score via pyproject.toml in the dbt project root:
[tool.dbt-score]
# Fail CI if project score falls below threshold
fail_project_under = 7.5
fail_any_item_under = 8.0
# Disable specific rules
disabled_rules = ["dbt_score.rules.generic.columns_have_description"]
# Configure badges
[tool.dbt-score.badges]
first.threshold = 10.0
first.icon = "🥇"
second.threshold = 8.0
second.icon = "🥈"
third.threshold = 6.0
third.icon = "🥉"
wip.icon = "🏗️"
# Customize rule severity and parameters
[tool.dbt-score.rules."dbt_score.rules.generic.sql_has_reasonable_number_of_lines"]
severity = 1
max_lines = 300
Why Use dbt-score?
As dbt projects grow to hundreds or thousands of models, maintaining consistent metadata becomes increasingly challenging:
- Inconsistent Documentation: Some models are well-documented, others lack basic descriptions
- Missing Tests: Critical models without proper data quality tests
- Naming Inconsistencies: Models that don't follow established conventions
- Technical Debt: Long, complex SQL queries that are hard to maintain
- Compliance Issues: Missing ownership or governance metadata
dbt-score addresses these challenges by:
- Automated Quality Checks: Continuously evaluate dbt projects against best practices
- Objective Scoring: Get clear, numerical feedback on model quality
- Team Alignment: Establish shared standards across data teams
- CI/CD Integration: Prevent quality regressions in production
Built-in Rules
dbt-score comes with a small set of rules covering needs applicable to most
dbt projects.
Advanced Usage
Custom Rules
Create organization-specific rules by writing simple Python functions:
from dbt_score import Model, rule, RuleViolation
@rule
def model_has_business_owner(model: Model) -> RuleViolation:
if model.meta.get("business_owner") is None:
return RuleViolation("Model lacks a business owner.")
CI/CD Integration
Add dbt-score to CI pipelines:
- name: Run dbt-score
run: |
dbt-score lint --run-dbt-parse
or equivalent in your favourite CI platform. dbt-score exits with 0 or 1 to
signal success or failure, making integrations a breeze!
Selective Linting
Use dbt's selection syntax to lint specific parts of projects:
# Lint only staging models
dbt-score lint --select staging.*
# Lint a model and its dependencies
dbt-score lint --select +my_important_model
# Lint recently changed models
dbt-score lint --select state:modified
Documentation
For comprehensive documentation, including detailed rule descriptions,
configuration options, and advanced usage patterns, visit the dbt-score
documentation website.
Contributing
Contributions are welcome! This includes:
- Reporting bugs or requesting features
- Improving documentation
- Adding new rules or formatters
- Fixing issues
Check out the contributing guide to get started. 🚀
Requirements
- Python 3.10+
- dbt-core 1.5+
License
This project is licensed under the MIT License - see the LICENSE.txt file for details.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dbt_score-0.15.0.tar.gz.
File metadata
- Download URL: dbt_score-0.15.0.tar.gz
- Upload date:
- Size: 144.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.10 {"installer":{"name":"uv","version":"0.9.10"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4f367806135091f9de5909532a7cda27cde7adb8ed10591ac19f4e9f098ec90b
|
|
| MD5 |
96752dc2f0c7c13fccce177f5313f53e
|
|
| BLAKE2b-256 |
556fd0f187a4edea4337058c06c508f24fbd4ffbc454c3af918c54d3507e1178
|
File details
Details for the file dbt_score-0.15.0-py3-none-any.whl.
File metadata
- Download URL: dbt_score-0.15.0-py3-none-any.whl
- Upload date:
- Size: 35.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.10 {"installer":{"name":"uv","version":"0.9.10"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6671399c557e228cf4d541d691a640277a3399da74e5673e2533aee6f77542c8
|
|
| MD5 |
2d97b46b99889193393e5e9703c056e5
|
|
| BLAKE2b-256 |
3051415845851fcc720419bbcd49c11b7c824e127dccd7d5bea3eb126cbe08de
|