dbt-cloud-migrate
Audits dbt Core projects for migration blockers and generates actionable guidance for migrating to dbt Cloud, including auto-fixing deprecated syntax.
README
dbt-cloud-migrate
A CLI tool and MCP server that audits dbt Core projects and generates actionable guidance for migrating to dbt Cloud. Designed to work alongside the official dbt MCP server.
How it fits with the dbt MCP server
| Tool | Role |
|---|---|
dbt MCP server (uvx dbt-mcp) |
Runs dbt commands (compile, build, test, show), queries the Semantic Layer, Discovery API, and Admin API |
| dbt-cloud-migrate (this tool) | Audits your project for migration blockers: profiles config, structure issues, deprecated syntax |
The typical workflow is:
- Run
check_projectorcheck_deprecationsto find migration issues - Run
fix_deprecationsto auto-fix safe changes - Use the dbt MCP server's
compileorbuildtools to confirm the project still works
What it checks
- Profiles migration — analyzes
profiles.yml, maps adapter types to dbt Cloud connection types, flags hardcoded credentials, and generates recommendedDBT_ENV_SECRET_environment variable mappings - Project structure — checks model layer organization (staging/intermediate/marts), naming conventions (
stg_,int_,fct_,dim_), source YAML definitions, documentation coverage, primary key test coverage, and.gitignoresettings - Deprecated syntax — detects renamed
dbt_project.ymlkeys, legacytests:YAML keys, deprecateddbt_utilsmacros,env_var()calls without defaults, hardcodedtarget.namereferences, hardcoded 3-part database references, and unpinned packages
Each issue includes a severity level (ERROR, WARNING, INFO) and a concrete fix recommendation.
Installation
Requires Python 3.10+.
git clone <repo>
cd dbt-refactoring-tool
python3 -m venv .venv
.venv/bin/pip install -e .
MCP Server Setup
Prerequisites
Install uv for the dbt MCP server:
curl -LsSf https://astral.sh/uv/install.sh | sh
Claude Code — add both servers
# Official dbt MCP server
claude mcp add dbt -s user -- uvx dbt-mcp
# Migration audit server (this tool)
claude mcp add dbt-cloud-migrate -s user -- dbt-cloud-migrate-mcp
Set your project path for the dbt MCP server — edit ~/.claude.json and add env vars:
{
"mcpServers": {
"dbt": {
"type": "stdio",
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/your/dbt/project",
"DBT_PATH": "/path/to/dbt"
}
},
"dbt-cloud-migrate": {
"type": "stdio",
"command": "dbt-cloud-migrate-mcp"
}
}
}
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/your/dbt/project",
"DBT_PATH": "/path/to/dbt"
}
},
"dbt-cloud-migrate": {
"command": "dbt-cloud-migrate-mcp"
}
}
}
Available MCP tools
dbt-cloud-migrate tools (this server):
| Tool | Description |
|---|---|
check_project |
Run all migration checks and return a full JSON report |
check_profiles |
Analyze profiles.yml and generate Cloud connection guidance |
check_structure |
Audit model organization, naming, sources, docs, and tests |
check_deprecations |
Scan for deprecated syntax and configuration |
fix_deprecations |
Auto-fix deprecated keys and tests: → data_tests:. Supports dry_run: true |
dbt MCP server tools (complement these with):
| Tool | Description |
|---|---|
dbt_compile |
Compile models to validate SQL after fixes |
dbt_build |
Run and test models end-to-end |
dbt_show |
Preview model output |
list_metrics |
Query the Semantic Layer |
CLI Usage
Run all checks
dbt-cloud-migrate check /path/to/your/dbt/project
Run from your project root:
cd ~/projects/my_dbt_project
dbt-cloud-migrate check .
Output formats
# Rich terminal output (default)
dbt-cloud-migrate check . --output rich
# JSON — useful for CI or piping to other tools
dbt-cloud-migrate check . --output json
# Compact summary table
dbt-cloud-migrate check . --output summary
Run specific checks only
dbt-cloud-migrate check . --only profiles
dbt-cloud-migrate check . --only deprecations
dbt-cloud-migrate check . --only profiles,deprecations
Available check names: profiles, structure, deprecations
Profiles-only command
dbt-cloud-migrate profiles /path/to/project
Auto-fix deprecated syntax
Fix renamed dbt_project.yml keys and tests: → data_tests: in schema YAML files:
# Preview changes without modifying files
dbt-cloud-migrate fix . --dry-run
# Apply fixes
dbt-cloud-migrate fix .
After fixing, validate with the dbt MCP server or CLI:
dbt compile
Version
dbt-cloud-migrate version
Checks reference
Profiles migration
- Adapter → dbt Cloud connection type mapping (Snowflake, BigQuery, Databricks, Redshift, Postgres, and more)
- Hardcoded sensitive fields (
password,token,private_key, etc.) that should useenv_var() - Recommended
DBT_ENV_SECRET_variable names per adapter - Multiple targets → separate dbt Cloud Environments guidance
profiles.ymlcommitted to the project directory (security risk)
Project structure
profiles.ymlinside the project repo- Missing or incomplete
.gitignore(target/,dbt_packages/,profiles.yml,logs/) - Missing
dbt_project.ymlor required keys (name,version,profile) - SQL models in the root
models/directory (not organized into layers) - Missing standard layer folders (
staging/,intermediate/,marts/) - Naming convention violations (
stg_in staging,int_in intermediate,fct_/dim_in marts) - No source YAML files in
models/staging/ - Models with no schema YAML entry or empty
description - Primary key columns (
id,*_id,*_key,*_pk) missingunique+not_nulltests
Deprecated syntax
- Renamed
dbt_project.ymlkeys:source-paths→model-paths,data-paths→seed-paths,modules-path→packages-install-path config-version: 2no longer required (dbt 1.5+)- Legacy
tests:key in schema YAML (should bedata_tests:in dbt 1.8+) version: 2in schema YAML files (no longer required in dbt 1.5+)- Unpinned Hub packages (no
version) and unpinned Git packages (norevision) - Deprecated
dbt_utilsmacros moved to dbt core (dbt_utils.surrogate_key,dbt_utils.current_timestamp, type macros, date macros) env_var()calls without a default value (will fail in Cloud if variable is unset){{ target.name }}usage (recommend environment variable approach in Cloud)- Hardcoded 3-part
database.schema.tablereferences in SQL (should useref()orsource())
Exit codes
0— all checks passed1— one or more ERROR or WARNING issues found
This makes dbt-cloud-migrate check suitable for use in CI pipelines.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.