Skip to content

Commit

Permalink
(#2336) Fix for non-json-serializable values in BigQuery nested columns
Browse files Browse the repository at this point in the history
  • Loading branch information
drewbanin committed Apr 21, 2020
1 parent c05b45b commit 5719a24
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 7 deletions.
3 changes: 2 additions & 1 deletion core/dbt/clients/agate_helper.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import datetime
import isodate
import json
import dbt.utils
from typing import Iterable, List, Dict, Union, Optional, Any

from dbt.exceptions import RuntimeException
Expand Down Expand Up @@ -92,7 +93,7 @@ def table_from_data_flat(data, column_names: Iterable[str]) -> agate.Table:
row = []
for value in list(_row.values()):
if isinstance(value, (dict, list, tuple)):
row.append(json.dumps(value))
row.append(json.dumps(value, cls=dbt.utils.JSONEncoder))
else:
row.append(value)
rows.append(row)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ def test__bigquery_fetch_nested_records(self):
cast('Stonebreaker' as string) as lname
) as user,
[
struct(1 as val_1, 2 as val_2),
struct(3 as val_1, 4 as val_2)
struct(1 as val_1, cast(2.12 as numeric) as val_2),
struct(3 as val_1, cast(4.83 as numeric) as val_2)
] as val
union all
Expand All @@ -38,8 +38,8 @@ def test__bigquery_fetch_nested_records(self):
cast('Brickmaker' as string) as lname
) as user,
[
struct(7 as val_1, 8 as val_2),
struct(9 as val_1, 0 as val_2)
struct(7 as val_1, cast(8 as numeric) as val_2),
struct(9 as val_1, cast(null as numeric) as val_2)
] as val
"""

Expand All @@ -54,8 +54,8 @@ def test__bigquery_fetch_nested_records(self):
'{"fname": "Johnny", "lname": "Brickmaker"}'
],
"val": [
'[{"val_1": 1, "val_2": 2}, {"val_1": 3, "val_2": 4}]',
'[{"val_1": 7, "val_2": 8}, {"val_1": 9, "val_2": 0}]'
'[{"val_1": 1, "val_2": 2.12}, {"val_1": 3, "val_2": 4.83}]',
'[{"val_1": 7, "val_2": 8}, {"val_1": 9, "val_2": null}]'
]
}

Expand Down

0 comments on commit 5719a24

Please sign in to comment.