Skip to content

Commit

Permalink
Merge pull request #4 from kgmcquate/develop
Browse files Browse the repository at this point in the history
Added more tests, test generation functionality, and docs
  • Loading branch information
kgmcquate authored Jan 2, 2024
2 parents 9760299 + 2741c6d commit f8eea52
Show file tree
Hide file tree
Showing 20 changed files with 238 additions and 139 deletions.
31 changes: 16 additions & 15 deletions .github/workflows/dbt_test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,16 @@ jobs:
test-duckdb:
name: Test on DuckDB
runs-on: ubuntu-latest
#environment: production
container:
image: python:3.11
strategy:
matrix:
python-version: ["3.9", "3.10", "3.11"]

steps:
- name: Checkout
uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}

- name: pip install
run: pip install dbt-core duckdb dbt-duckdb
Expand All @@ -32,29 +35,30 @@ jobs:
- name: load test data
run: dbt seed --target duckdb

- name: Create seed tests
run: bash tests/create_seeds_tests_yml.sh

- name: dbt test
run: dbt test --target duckdb

test-postgres:
name: Test on Postgres
runs-on: ubuntu-latest
#environment: production
container:
image: python:3.11

# Service containers to run with `container-job`
services:
# Label used to access the service container
postgres:
# Docker Hub image
image: postgres
# Provide the password for postgres
env:
POSTGRES_PASSWORD: postgres

steps:
- name: Checkout
uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}

- name: pip install
run: pip install dbt-core duckdb dbt-postgres
Expand All @@ -67,6 +71,3 @@ jobs:

- name: dbt test
run: dbt test --target postgres



32 changes: 26 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,33 @@ dbt-testgen autogenerates dbt test yaml based on real data.

Inspired by [dbt-codegen]() and [deequ Constraint Suggestion](https://github.com/awslabs/deequ/blob/master/src/main/scala/com/amazon/deequ/examples/constraint_suggestion_example.md)

## Usage
The DBT config YAML is generated by a Jinja macro, `get_test_suggestions`, which you can run like this:
```powershell
dbt compile -q --inline "{{ testgen.get_test_suggestions(ref('mymodel')) }}"
```
Output:
```yaml
models:
- name: mymodel
columns:
- name: user_id
tests:
- unique
- not_null
- dbt_utils.accepted_range:
min_value: 1
max_value: 30
```
## Test types
- uniqueness
- not_null
- string length
- range
- accepted_values
- freshness
dbt-testgen can generate these types of tests:
- [uniqueness](#uniqueness)
- [not_null](#not-null)
- [string length](#string-length)
- [range](#range)
- [accepted_values](#accepted-values)
- [freshness](#freshness)
### Uniqueness
Expand Down
5 changes: 2 additions & 3 deletions integration_tests/dbt_project.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@ config-version: 2

profile: 'integration_tests'

model-paths: ["models"]
analysis-paths: ["analyses"]
test-paths: ["tests"]
seed-paths: ["seeds"]
macro-paths: ["macros"]
Expand All @@ -17,4 +15,5 @@ clean-targets:

seeds:
+schema: integration_test_data
+quote_columns: true
+quote_columns: true

4 changes: 3 additions & 1 deletion integration_tests/packages.yml
Original file line number Diff line number Diff line change
@@ -1,2 +1,4 @@
packages:
- local: ../
- local: ../
- package: dbt-labs/dbt_utils
version: 1.1.1
7 changes: 7 additions & 0 deletions integration_tests/tests/create_seeds_tests_yml.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
dbt compile -q \
--inline "{{ testgen.get_test_suggestions(ref('users'), resource_type='seeds') }}" \
> seeds/users_test_suggestions.yml

dbt compile -q \
--inline "{{ testgen.get_test_suggestions(ref('colnames_with_spaces'), resource_type='seeds', column_config={'quote': true}) }}" \
> seeds/colnames_with_spaces_test_suggestions.yml
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@


{% set actual_yaml = toyaml(fromjson(tojson(
{% set actual_yaml = testgen.to_yaml(
testgen.get_accepted_values_test_suggestions(
ref('colnames_with_spaces')
)
)))
)
%}

{% set expected_yaml %}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@


{% set actual_yaml = toyaml(fromjson(tojson(
{% set actual_yaml = testgen.to_yaml(
testgen.get_accepted_values_test_suggestions(
ref('users')
)
)))
)
%}

{% set expected_yaml %}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@


{% set actual_yaml = toyaml(fromjson(tojson(
{% set actual_yaml = testgen.to_yaml(
testgen.get_range_test_suggestions(
ref('colnames_with_spaces')
)
)))
)
%}

{% set expected_yaml %}
Expand Down
4 changes: 2 additions & 2 deletions integration_tests/tests/generate_range_tests/range_users.sql
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@


{% set actual_yaml = toyaml(fromjson(tojson(
{% set actual_yaml = testgen.to_yaml(
testgen.get_range_test_suggestions(
ref('users')
)
)))
)
%}

{% set expected_yaml %}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@


{% set actual_yaml = testgen.to_yaml(
testgen.get_uniqueness_test_suggestions(
ref('colnames_with_spaces'),
composite_key_length = 1,
column_config={'quote': true}
)
)
%}

{% set expected_yaml %}
models:
- name: colnames_with_spaces
columns:
- name: First Name
description: Uniqueness test generated by dbt-testgen
tests:
- unique
- not_null
quote: true
- name: Age (Years)
description: Uniqueness test generated by dbt-testgen
tests:
- unique
- not_null
quote: true
- name: Current City
description: Uniqueness test generated by dbt-testgen
tests:
- unique
- not_null
quote: true
{% endset %}

{{ assert_equal (actual_yaml | trim, expected_yaml | trim) }}
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@


{% set actual_yaml = toyaml(fromjson(tojson(
{% set actual_yaml = testgen.to_yaml(
testgen.get_uniqueness_test_suggestions(
ref('users'),
compound_key_length = 1
composite_key_length = 1
)
)))
)
%}

{% set expected_yaml %}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ models:
- name: users
columns:
- name: user_id
description: Uniqueness test generated by dbt-testgen
tests:
- unique:
tags:
Expand All @@ -52,6 +53,7 @@ models:
tags:
- uniqueness
- name: email
description: Uniqueness test generated by dbt-testgen
tests:
- unique:
tags:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ models:
- name: users
columns:
- name: user_id
description: Uniqueness test generated by dbt-testgen
tests:
- unique:
tags:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,38 +1,44 @@


{% set actual_yaml = toyaml(fromjson(tojson(
{% set actual_yaml = testgen.to_yaml(
testgen.get_test_suggestions(
ref('users')
ref('users'),
return_object=true
)
)))
)
%}

{% set expected_yaml %}
models:
- name: users
columns:
- name: user_id
description: Numeric range test generated by dbt-testgen
tests:
- unique
- not_null
- dbt_utils.accepted_range:
min_value: 1
max_value: 30
- name: username
description: Uniqueness test generated by dbt-testgen
tests:
- unique
- not_null
- name: email
description: Uniqueness test generated by dbt-testgen
tests:
- unique
- not_null
- name: user_status
description: Accepted values test generated by dbt-testgen
tests:
- accepted_values:
values:
- active
- inactive
- name: age
description: Numeric range test generated by dbt-testgen
tests:
- dbt_utils.accepted_range:
min_value: 22
Expand Down
3 changes: 3 additions & 0 deletions macros/helpers/to_yaml.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{% macro to_yaml(the_obj) %}
{{ return(toyaml(fromjson(tojson(the_obj)))) }}
{% endmacro %}
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,15 @@
table_relation,
sample = false,
limit = None,
is_source = false,
resource_type = "models",
column_config = {},
exclude_types = [],
exclude_cols = [],
tags = [],
tests = ["uniqueness", "accepted_values", "range"],
dbt_config = None
composite_key_length = 1,
dbt_config = None,
return_object = false
) %}
{# Run macro for the specific target DB #}
{% if execute %}
Expand All @@ -17,10 +20,12 @@
table_relation=table_relation,
sample=sample,
limit=limit,
is_source=is_source,
resource_type=resource_type,
column_config=column_config,
exclude_types=exclude_types,
exclude_cols=exclude_cols,
tags=tags,
composite_key_length=composite_key_length,
dbt_config=dbt_config
) %}
{% endif %}
Expand All @@ -30,7 +35,8 @@
table_relation=table_relation,
sample=sample,
limit=limit,
is_source=is_source,
resource_type=resource_type,
column_config=column_config,
exclude_types=exclude_types,
exclude_cols=exclude_cols,
tags=tags,
Expand All @@ -43,15 +49,19 @@
table_relation=table_relation,
sample=sample,
limit=limit,
is_source=is_source,
resource_type=resource_type,
column_config=column_config,
exclude_types=exclude_types,
exclude_cols=exclude_cols,
tags=tags,
dbt_config=dbt_config
) %}
{% endif %}

{{ return(dbt_config) }}

{% if return_object %}
{{ return(dbt_config) }}
{% else %}
{{ print(testgen.to_yaml(dbt_config)) }}
{% endif %}
{% endif %}
{%- endmacro %}
Loading

0 comments on commit f8eea52

Please sign in to comment.