Skip to content

Commit

Permalink
handles ints+longs
Browse files Browse the repository at this point in the history
  • Loading branch information
edgao committed Jul 1, 2022
1 parent a856992 commit 9e4f3be
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
is_datetime_with_timezone,
is_datetime_without_timezone,
is_integer,
is_long,
is_number,
is_object,
is_simple_property,
Expand Down Expand Up @@ -513,6 +514,8 @@ def cast_property_type(self, property_name: str, column_name: str, jinja_column:
cast_operation = jinja_call(f"cast_to_boolean({jinja_column})")
return f"{cast_operation} as {column_name}"
elif is_integer(definition):
sql_type = jinja_call("dbt_utils.type_int()")
elif is_long(definition):
sql_type = jinja_call("dbt_utils.type_bigint()")
elif is_number(definition["type"]):
sql_type = jinja_call("dbt_utils.type_float()")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,12 @@ def is_number(property_type) -> bool:


def is_integer(definition: dict) -> bool:
if "airbyte_type" in definition and definition["airbyte_type"] == "integer":
# By default, {type: integer} will be treated as a long (see is_long)
return "airbyte_type" in definition and definition["airbyte_type"] == "integer"


def is_long(definition: dict) -> bool:
if "airbyte_type" in definition and definition["airbyte_type"] == "long":
return True
property_type = definition["type"]
if is_string(property_type) or is_number(property_type):
Expand All @@ -71,7 +76,7 @@ def is_integer(definition: dict) -> bool:

def is_boolean(definition: dict) -> bool:
property_type = definition["type"]
if is_string(property_type) or is_number(property_type) or is_integer(definition):
if is_string(property_type) or is_number(property_type) or is_integer(definition) or is_long(definition):
# Handle union type, give priority to wider scope types
return False
return property_type == "boolean" or "boolean" in property_type
Expand All @@ -94,7 +99,7 @@ def is_simple_property(definition: dict) -> bool:
property_type = "object"
else:
property_type = definition["type"]
return is_string(property_type) or is_integer(definition) or is_number(property_type) or is_boolean(definition)
return is_string(property_type) or is_integer(definition) or is_long(definition) or is_number(property_type) or is_boolean(definition)


def is_combining_node(properties: dict) -> Set[str]:
Expand Down

0 comments on commit 9e4f3be

Please sign in to comment.