Skip to content

Commit

Permalink
DCV-2190 cast Integers to Strings to avoid Typescript extensions trun…
Browse files Browse the repository at this point in the history
…cating large numbers
  • Loading branch information
BAntonellini committed Jan 17, 2024
1 parent d56e000 commit 16e6603
Showing 1 changed file with 33 additions and 3 deletions.
36 changes: 33 additions & 3 deletions src/dbt_core_interface/project.py
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@

if TYPE_CHECKING:
# These imports are only used for type checking
from agate import Table # type: ignore # No stubs for agate
from agate import Table # type: ignore # No stubs for agate
from dbt.adapters.base import BaseAdapter, BaseRelation # type: ignore
from dbt.contracts.connection import AdapterResponse
from dbt.contracts.results import ExecutionResult, RunExecutionResult
Expand All @@ -124,6 +124,12 @@
dci_state = None
lint_command = None

from agate import Table, Number, Text, Column

try:
from dbt.clients.agate_helper import Integer
except ImportError:
from dbt.clients.agate_helper import Number as Integer
# dbt-core-interface is designed for non-standard use. There is no
# reason to track usage of this package.
disable_tracking()
Expand Down Expand Up @@ -5870,16 +5876,40 @@ def run_sql(runners: DbtProjectContainer) -> Union[ServerRunResult, ServerErrorC
compiled_query = re.search(
r"select \* from \(([\w\W]+)\) as __server_query", result.compiled_code
).groups()[0]

new_columns = []
for column in result.table.columns:
if isinstance(column.data_type, Integer):
# Convert the column to text if it contains integer values
converted_column = Column(
column._index,
column._name,
Text(),
[convert_int_to_str(value) for value in column._rows],
column._keys,
)
else:
converted_column = column
new_columns.append(converted_column)
new_table = Table(
rows=new_columns[0]._rows, # Assuming all columns have the same number of rows
column_names=[column._name for column in new_columns],
column_types=[column._data_type for column in new_columns],
row_names=new_columns[0]._keys,
)
return asdict(
ServerRunResult(
rows=[list(row) for row in result.table.rows],
column_names=result.table.column_names,
rows=[list(row) for row in new_table.rows],
column_names=new_table.column_names,
executed_code=compiled_query.strip(),
raw_code=query,
)
)


def convert_int_to_str(value):
return str(value) if isinstance(value, int) else value

@route("/compile", method="POST")
def compile_sql(
runners: DbtProjectContainer,
Expand Down

0 comments on commit 16e6603

Please sign in to comment.