-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test(dbt): add jaffle shop project to test Dagster metadata
- Loading branch information
1 parent
f7ac058
commit ab98bc0
Showing
16 changed files
with
693 additions
and
0 deletions.
There are no files selected for viewing
11 changes: 11 additions & 0 deletions
11
...les/libraries/dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/.gitignore
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
|
||
target/ | ||
dbt_packages/ | ||
dbt_modules/ | ||
logs/ | ||
**/.DS_Store | ||
.user.yml | ||
venv/ | ||
env/ | ||
**/*.duckdb | ||
**/*.duckdb.wal |
26 changes: 26 additions & 0 deletions
26
...ibraries/dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/dbt_project.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
name: "test_dagster_metadata" | ||
|
||
config-version: 2 | ||
version: "0.1" | ||
|
||
profile: "jaffle_shop" | ||
|
||
model-paths: ["models"] | ||
seed-paths: ["seeds"] | ||
test-paths: ["tests"] | ||
analysis-paths: ["analysis"] | ||
macro-paths: ["macros"] | ||
|
||
target-path: "target" | ||
clean-targets: | ||
- "target" | ||
- "dbt_modules" | ||
- "logs" | ||
|
||
require-dbt-version: [">=1.0.0", "<2.0.0"] | ||
|
||
models: | ||
test_dagster_metadata: | ||
materialized: table | ||
staging: | ||
materialized: view |
69 changes: 69 additions & 0 deletions
69
...ies/dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/customers.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
with customers as ( | ||
|
||
select * from {{ ref('stg_customers') }} | ||
|
||
), | ||
|
||
orders as ( | ||
|
||
select * from {{ ref('stg_orders') }} | ||
|
||
), | ||
|
||
payments as ( | ||
|
||
select * from {{ ref('stg_payments') }} | ||
|
||
), | ||
|
||
customer_orders as ( | ||
|
||
select | ||
customer_id, | ||
|
||
min(order_date) as first_order, | ||
max(order_date) as most_recent_order, | ||
count(order_id) as number_of_orders | ||
from orders | ||
|
||
group by customer_id | ||
|
||
), | ||
|
||
customer_payments as ( | ||
|
||
select | ||
orders.customer_id, | ||
sum(amount) as total_amount | ||
|
||
from payments | ||
|
||
left join orders on | ||
payments.order_id = orders.order_id | ||
|
||
group by orders.customer_id | ||
|
||
), | ||
|
||
final as ( | ||
|
||
select | ||
customers.customer_id, | ||
customers.first_name, | ||
customers.last_name, | ||
customer_orders.first_order, | ||
customer_orders.most_recent_order, | ||
customer_orders.number_of_orders, | ||
customer_payments.total_amount as customer_lifetime_value | ||
|
||
from customers | ||
|
||
left join customer_orders | ||
on customers.customer_id = customer_orders.customer_id | ||
|
||
left join customer_payments | ||
on customers.customer_id = customer_payments.customer_id | ||
|
||
) | ||
|
||
select * from final |
13 changes: 13 additions & 0 deletions
13
...dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/docs.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
{% docs orders_status %} | ||
|
||
Orders can be one of the following statuses: | ||
|
||
| status | description | | ||
| -------------- | ---------------------------------------------------------------------------------------------------------------------- | | ||
| placed | The order has been placed but has not yet left the warehouse | | ||
| shipped | The order has ben shipped to the customer and is currently in transit | | ||
| completed | The order has been received by the customer | | ||
| return_pending | The customer has indicated that they would like to return the order, but it has not yet been received at the warehouse | | ||
| returned | The order has been returned by the customer and received at the warehouse | | ||
|
||
{% enddocs %} |
56 changes: 56 additions & 0 deletions
56
...raries/dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/orders.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
{% set payment_methods = ['credit_card', 'coupon', 'bank_transfer', 'gift_card'] %} | ||
|
||
with orders as ( | ||
|
||
select * from {{ ref('stg_orders') }} | ||
|
||
), | ||
|
||
payments as ( | ||
|
||
select * from {{ ref('stg_payments') }} | ||
|
||
), | ||
|
||
order_payments as ( | ||
|
||
select | ||
order_id, | ||
|
||
{% for payment_method in payment_methods -%} | ||
sum(case when payment_method = '{{ payment_method }}' then amount else 0 end) as {{ payment_method }}_amount, | ||
{% endfor -%} | ||
|
||
sum(amount) as total_amount | ||
|
||
from payments | ||
|
||
group by order_id | ||
|
||
), | ||
|
||
final as ( | ||
|
||
select | ||
orders.order_id, | ||
orders.customer_id, | ||
orders.order_date, | ||
orders.status, | ||
|
||
{% for payment_method in payment_methods -%} | ||
|
||
order_payments.{{ payment_method }}_amount, | ||
|
||
{% endfor -%} | ||
|
||
order_payments.total_amount as amount | ||
|
||
from orders | ||
|
||
|
||
left join order_payments | ||
on orders.order_id = order_payments.order_id | ||
|
||
) | ||
|
||
select * from final |
11 changes: 11 additions & 0 deletions
11
...ter-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/overview.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
{% docs __overview__ %} | ||
|
||
## Data Documentation for Jaffle Shop | ||
|
||
`jaffle_shop` is a fictional ecommerce store. | ||
|
||
This [dbt](https://www.getdbt.com/) project is for testing out code. | ||
|
||
The source code can be found [here](https://github.com/clrcrl/jaffle_shop). | ||
|
||
{% enddocs %} |
83 changes: 83 additions & 0 deletions
83
...raries/dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/schema.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
version: 2 | ||
|
||
models: | ||
- name: customers | ||
description: This table has basic information about a customer, as well as some derived facts based on a customer's orders | ||
|
||
columns: | ||
- name: customer_id | ||
description: This is a unique identifier for a customer | ||
tests: | ||
- unique | ||
- not_null | ||
|
||
- name: first_name | ||
description: Customer's first name. PII. | ||
|
||
- name: last_name | ||
description: Customer's last name. PII. | ||
|
||
- name: first_order | ||
description: Date (UTC) of a customer's first order | ||
|
||
- name: most_recent_order | ||
description: Date (UTC) of a customer's most recent order | ||
|
||
- name: number_of_orders | ||
description: Count of the number of orders a customer has placed | ||
|
||
- name: total_order_amount | ||
description: Total value (AUD) of a customer's orders | ||
|
||
- name: orders | ||
description: This table has basic information about orders, as well as some derived facts based on payments | ||
|
||
columns: | ||
- name: order_id | ||
tests: | ||
- unique | ||
- not_null | ||
description: This is a unique identifier for an order | ||
|
||
- name: customer_id | ||
description: Foreign key to the customers table | ||
tests: | ||
- not_null | ||
- relationships: | ||
to: ref('customers') | ||
field: customer_id | ||
|
||
- name: order_date | ||
description: Date (UTC) that the order was placed | ||
|
||
- name: status | ||
description: '{{ doc("orders_status") }}' | ||
tests: | ||
- accepted_values: | ||
values: | ||
["placed", "shipped", "completed", "return_pending", "returned"] | ||
|
||
- name: amount | ||
description: Total amount (AUD) of the order | ||
tests: | ||
- not_null | ||
|
||
- name: credit_card_amount | ||
description: Amount of the order (AUD) paid for by credit card | ||
tests: | ||
- not_null | ||
|
||
- name: coupon_amount | ||
description: Amount of the order (AUD) paid for by coupon | ||
tests: | ||
- not_null | ||
|
||
- name: bank_transfer_amount | ||
description: Amount of the order (AUD) paid for by bank transfer | ||
tests: | ||
- not_null | ||
|
||
- name: gift_card_amount | ||
description: Amount of the order (AUD) paid for by gift card | ||
tests: | ||
- not_null |
32 changes: 32 additions & 0 deletions
32
...agster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/staging/schema.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
version: 2 | ||
|
||
models: | ||
- name: stg_customers | ||
columns: | ||
- name: customer_id | ||
tests: | ||
- unique | ||
- not_null | ||
|
||
- name: stg_orders | ||
columns: | ||
- name: order_id | ||
tests: | ||
- unique | ||
- not_null | ||
- name: status | ||
tests: | ||
- accepted_values: | ||
values: | ||
["placed", "shipped", "completed", "return_pending", "returned"] | ||
|
||
- name: stg_payments | ||
columns: | ||
- name: payment_id | ||
tests: | ||
- unique | ||
- not_null | ||
- name: payment_method | ||
tests: | ||
- accepted_values: | ||
values: ["credit_card", "coupon", "bank_transfer", "gift_card"] |
22 changes: 22 additions & 0 deletions
22
...dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/staging/stg_customers.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
with source as ( | ||
|
||
{#- | ||
Normally we would select from the table here, but we are using seeds to load | ||
our data in this project | ||
#} | ||
select * from {{ ref('raw_customers') }} | ||
|
||
), | ||
|
||
renamed as ( | ||
|
||
select | ||
id as customer_id, | ||
first_name, | ||
last_name | ||
|
||
from source | ||
|
||
) | ||
|
||
select * from renamed |
23 changes: 23 additions & 0 deletions
23
...er-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/staging/stg_orders.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
with source as ( | ||
|
||
{#- | ||
Normally we would select from the table here, but we are using seeds to load | ||
our data in this project | ||
#} | ||
select * from {{ ref('raw_orders') }} | ||
|
||
), | ||
|
||
renamed as ( | ||
|
||
select | ||
id as order_id, | ||
user_id as customer_id, | ||
order_date, | ||
status | ||
|
||
from source | ||
|
||
) | ||
|
||
select * from renamed |
25 changes: 25 additions & 0 deletions
25
...-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/models/staging/stg_payments.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
with source as ( | ||
|
||
{#- | ||
Normally we would select from the table here, but we are using seeds to load | ||
our data in this project | ||
#} | ||
select * from {{ ref('raw_payments') }} | ||
|
||
), | ||
|
||
renamed as ( | ||
|
||
select | ||
id as payment_id, | ||
order_id, | ||
payment_method, | ||
|
||
-- `amount` is currently stored in cents, so we convert it to dollars | ||
amount / 100 as amount | ||
|
||
from source | ||
|
||
) | ||
|
||
select * from renamed |
7 changes: 7 additions & 0 deletions
7
...s/libraries/dagster-dbt/dagster_dbt_tests/dbt_projects/test_dagster_metadata/profiles.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
jaffle_shop: | ||
target: dev | ||
outputs: | ||
dev: | ||
type: duckdb | ||
path: "jaffle_shop.duckdb" | ||
threads: 24 |
Empty file.
Oops, something went wrong.