Skip to content

Commit

Permalink
Add include_data_types flag to generate_source macro (#76)
Browse files Browse the repository at this point in the history
* Add include_data_types flag to generate_source macro

* Add test for include_data_types

* Fix test_generate_source_all_args for Redshift

* Fix test_generate_source_all_args for Snowflake

* Fix int types test_generate_source_all_args for Snowflake

* Fix test_generate_source_all_args for BigQuery

* Fix typo

* Fix typo

* trying to avoid db-specific type defenitions

* Dummy fix

* Dummy fix

* Dummy fix

* Dummy fix

* Revert to initial schema

I've tried several approaches to generate the exact text, but it's not
working. So returninig tests to
3a1267b
state.

* Example of generating data types for columns

* Update changelog

* Remove comment [skip ci]

Co-authored-by: Doug Beatty <doug.beatty@dbtlabs.com>
  • Loading branch information
GSokol and dbeatty10 authored Dec 21, 2022
1 parent 39cbe0f commit c77d28e
Show file tree
Hide file tree
Showing 6 changed files with 45 additions and 2 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,15 @@
## New features
- Addition of the [create_base_models](macros/create_base_models.sql)
This macro generates a series of terminal commands (appended w) bash script which creates a new file in your dbt project based off the results of the [generate_base_model](macros/generate_base_model.sql) macro. Therefore, instead of outputting in the terminal, it will create the file for you.
- Add `include_data_types` flag to `generate_source` macro ([#76](https://github.com/dbt-labs/dbt-codegen/pull/76))

## Quality of life
- Addition of the [base_model_creation](bash_scripts/base_model_creation.sh) bash script which allows users to input multiple tables as a list and generate a terminal command that will combine **all** [create_base_models](macros/create_base_models.sql) commands. This way, you can generate base models for all your sources at once.
- Instructions for contributing ([#99](https://github.com/dbt-labs/dbt-codegen/issues/99), [#104](https://github.com/dbt-labs/dbt-codegen/pull/104))

## Contributors:
- [@fivetran-joemarkiewicz](https://github.com/fivetran-joemarkiewicz) (#83)
- [@GSokol](https://github.com/GSokol) (#76)

# dbt-codegen v0.9.0

Expand Down
10 changes: 9 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,9 @@ source data is in.
column names to your source definition.
* `include_descriptions` (optional, default=False): Whether you want to add
description placeholders to your source definition.
* `table_pattern` (optional, default='%'): A table prefix / postfix that you
* `include_data_types` (optional, default=False): Whether you want to add data
types to your source columns definitions.
* `table_pattern` (optional, default='%'): A table prefix / postfix that you
want to subselect from all available tables within a given schema.
* `exclude` (optional, default=''): A string you want to exclude from the selection criteria
* `name` (optional, default=schema_name): The name of your source
Expand All @@ -75,6 +77,12 @@ or
$ dbt run-operation generate_source --args '{"schema_name": "jaffle_shop", "database_name": "raw", "table_names":["table_1", "table_2"]}'
```
Including data types:
```
$ dbt run-operation generate_source --args '{"schema_name": "jaffle_shop", "generate_columns": "true", "include_data_types": "true"}'
```
2. The YAML for the source will be logged to the command line
```
Expand Down
9 changes: 9 additions & 0 deletions integration_tests/macros/integer_type_value.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{%- macro integer_type_value() -%}
{%- if target.type == "snowflake" -%}
NUMBER(38,0)
{%- elif target.type == "bigquery" -%}
INT64
{%- else -%}
INTEGER
{%- endif -%}
{%- endmacro -%}
11 changes: 11 additions & 0 deletions integration_tests/macros/text_type_value.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{%- macro text_type_value(text_length) -%}
{%- if target.type == "redshift" -%}
CHARACTER VARYING({{ text_length }})
{%- elif target.type == "snowflake" -%}
CHARACTER VARYING(16777216)
{%- elif target.type == "bigquery" -%}
STRING
{%- else -%}
TEXT
{%- endif -%}
{%- endmacro -%}
10 changes: 10 additions & 0 deletions integration_tests/tests/test_generate_source_all_args.sql
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
database_name=target.database,
generate_columns=True,
include_descriptions=True,
include_data_types=True,
name=raw_schema
) %}

Expand All @@ -24,30 +25,39 @@ sources:
description: ""
columns:
- name: col_a
data_type: {{ integer_type_value() }}
description: ""
- name: col_b
data_type: {{ text_type_value(1) }}
description: ""

- name: data__b_relation
description: ""
columns:
- name: col_a
data_type: {{ integer_type_value() }}
description: ""
- name: col_b
data_type: {{ text_type_value(1) }}
description: ""

- name: data__campaign_analytics
description: ""
columns:
- name: source
data_type: {{ text_type_value(8) }}
description: ""
- name: medium
data_type: {{ text_type_value(8) }}
description: ""
- name: source_medium
data_type: {{ text_type_value(2) }}
description: ""
- name: analytics
data_type: {{ integer_type_value() }}
description: ""
- name: col_x
data_type: {{ text_type_value(1) }}
description: ""

{% endset %}
Expand Down
5 changes: 4 additions & 1 deletion macros/generate_source.sql
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@


---
{% macro generate_source(schema_name, database_name=target.database, generate_columns=False, include_descriptions=False, table_pattern='%', exclude='', name=schema_name, table_names=None) %}
{% macro generate_source(schema_name, database_name=target.database, generate_columns=False, include_descriptions=False, include_data_types=False, table_pattern='%', exclude='', name=schema_name, table_names=None) %}

{% set sources_yaml=[] %}
{% do sources_yaml.append('version: 2') %}
Expand Down Expand Up @@ -61,6 +61,9 @@

{% for column in columns %}
{% do sources_yaml.append(' - name: ' ~ column.name | lower ) %}
{% if include_data_types %}
{% do sources_yaml.append(' data_type: ' ~ (column.data_type | upper ) ) %}
{% endif %}
{% if include_descriptions %}
{% do sources_yaml.append(' description: ""' ) %}
{% endif %}
Expand Down

0 comments on commit c77d28e

Please sign in to comment.