Environment diff tool for dbt
Project description
Recce
recce
is an environment diff tool for DBT projects. It helps you to compare the results of two environments, such as development and production, and identify the differences.
Features
- Support both Web UI & CLI
- Multiple diff tools, including lineage diff, schema diff, and query diff. And more in the future.
- Use the dbt-core adapter framework to connect to your data warehouse. No additional configuration is required.
Use cases
- During development, we can verify new results by contrasting them with those from production prior to pushing the changes.
- While reviewing PR, you can grasp the extent of the changes and their impact before merging.
- For troubleshooting, you can execute ad-hoc diff queries to pinpoint the root causes.
Usage
Prerequisites
You have to have at least two environments in your dbt project. For example, one is for development and another is for production. You can prepare two targets with separate schemas in your DBT profile. Here is profiles.yml
example
jaffle_shop:
target: dev
outputs:
dev:
type: duckdb
path: jaffle_shop.duckdb
schema: dev
prod:
type: duckdb
path: jaffle_shop.duckdb
schema: main
Getting Started
5 minutes walkthrough by jaffle shop example
-
Installation
pip install recce
-
Go to your DBT project
cd your-dbt-project/
-
Prepare base artifacts: DBT generates artifacts when every invocation. You can find these files in the
target/
folder.artifacts DBT command manifest.json dbt run
,dbt build
, ..catalog.json (optional) dbt docs generate
Copy the artifacts for the base environment to
target-base/
folder. -
Run the recce server.
recce server
Recce would diff environments between
target/
andtarget-base/
Query Diff
You can run query diff in both Web UI and CLI
-
Web UI: Go to Query tab
select * from {{ ref("mymodel") }}
-
CLI:
recce diff --sql 'select * from {{ ref("mymodel") }}'
Primay key
In the query diff, primary key columns serve as the fundamental identifiers for distinguishing each record uniquely across both sides.
-
Web UI: In the query result, click the key icons in the column headers to toggle if it is in the primary key list.
-
CLI: Use the option
--primary-keys
to specify the primary keys. Use a comma to separate the columns if it is a compound key.recce diff --primary-keys event_id --sql 'select * from {{ ref("events") }} order by 1'
Q&A
Q: How recce
connect to my data warehouse? Does recce support my data warehouse?
recce
use the dbt adapter to connect to your warehouse. So it should work for your data warehouse.
Q: What credential does recce
connect to the two environments?
Recce uses the same target in the profile to connect your warehouse. If you use the default target dev
, it uses the credentials to connect to both environments. So please make sure that the credential can access both environments.
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
File details
Details for the file recce-nightly-0.1.0.20231204.tar.gz
.
File metadata
- Download URL: recce-nightly-0.1.0.20231204.tar.gz
- Upload date:
- Size: 522.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6b3df3b4b2382a93f1a3a2ec36cd6e463038081f25f6e00150d0971f1a8b67d0 |
|
MD5 | 4bfb08df2116ed3a0ec89b9f561ed3d5 |
|
BLAKE2b-256 | 5f44d33022b4c790459315bc37b124ce1dd46acd0f87c5dfa5f7f6c53df4109e |
File details
Details for the file recce_nightly-0.1.0.20231204-py3-none-any.whl
.
File metadata
- Download URL: recce_nightly-0.1.0.20231204-py3-none-any.whl
- Upload date:
- Size: 527.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 304fd0a46bd867d7ae9450aaccf088242a25b11230851c9d3ce47da094995d33 |
|
MD5 | f1ca13115a928e0c5f37bcdd032af6c7 |
|
BLAKE2b-256 | 348aca6e464409de4ce44b865fc6f4f7056029fa456c09b23c7346d1d78515a7 |