This repository was archived by the owner on Apr 1, 2026. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 67
Expand file tree
/
Copy pathtest_table.py
More file actions
95 lines (78 loc) · 4 KB
/
test_table.py
File metadata and controls
95 lines (78 loc) · 4 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# Copyright 2026 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License"");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from unittest import mock
import pytest
import bigframes.bigquery.table
import bigframes.core.sql.table
import bigframes.session
@pytest.fixture
def mock_session():
return mock.create_autospec(spec=bigframes.session.Session)
def test_create_external_table_ddl():
sql = bigframes.core.sql.table.create_external_table_ddl(
"my-project.my_dataset.my_table",
columns={"col1": "INT64", "col2": "STRING"},
options={"format": "CSV", "uris": ["gs://bucket/path*"]},
)
expected = "CREATE EXTERNAL TABLE my-project.my_dataset.my_table (col1 INT64, col2 STRING) OPTIONS (format = 'CSV', uris = ['gs://bucket/path*'])"
assert sql == expected
def test_create_external_table_ddl_replace():
sql = bigframes.core.sql.table.create_external_table_ddl(
"my-project.my_dataset.my_table",
replace=True,
columns={"col1": "INT64", "col2": "STRING"},
options={"format": "CSV", "uris": ["gs://bucket/path*"]},
)
expected = "CREATE OR REPLACE EXTERNAL TABLE my-project.my_dataset.my_table (col1 INT64, col2 STRING) OPTIONS (format = 'CSV', uris = ['gs://bucket/path*'])"
assert sql == expected
def test_create_external_table_ddl_if_not_exists():
sql = bigframes.core.sql.table.create_external_table_ddl(
"my-project.my_dataset.my_table",
if_not_exists=True,
columns={"col1": "INT64", "col2": "STRING"},
options={"format": "CSV", "uris": ["gs://bucket/path*"]},
)
expected = "CREATE EXTERNAL TABLE IF NOT EXISTS my-project.my_dataset.my_table (col1 INT64, col2 STRING) OPTIONS (format = 'CSV', uris = ['gs://bucket/path*'])"
assert sql == expected
def test_create_external_table_ddl_partition_columns():
sql = bigframes.core.sql.table.create_external_table_ddl(
"my-project.my_dataset.my_table",
columns={"col1": "INT64", "col2": "STRING"},
partition_columns={"part1": "DATE", "part2": "STRING"},
options={"format": "CSV", "uris": ["gs://bucket/path*"]},
)
expected = "CREATE EXTERNAL TABLE my-project.my_dataset.my_table (col1 INT64, col2 STRING) WITH PARTITION COLUMNS (part1 DATE, part2 STRING) OPTIONS (format = 'CSV', uris = ['gs://bucket/path*'])"
assert sql == expected
def test_create_external_table_ddl_connection():
sql = bigframes.core.sql.table.create_external_table_ddl(
"my-project.my_dataset.my_table",
columns={"col1": "INT64", "col2": "STRING"},
connection_name="my-connection",
options={"format": "CSV", "uris": ["gs://bucket/path*"]},
)
expected = "CREATE EXTERNAL TABLE my-project.my_dataset.my_table (col1 INT64, col2 STRING) WITH CONNECTION `my-connection` OPTIONS (format = 'CSV', uris = ['gs://bucket/path*'])"
assert sql == expected
@mock.patch("bigframes.bigquery.table._get_table_metadata")
def test_create_external_table(get_table_metadata_mock, mock_session):
bigframes.bigquery.table.create_external_table(
"my-project.my_dataset.my_table",
columns={"col1": "INT64", "col2": "STRING"},
options={"format": "CSV", "uris": ["gs://bucket/path*"]},
session=mock_session,
)
mock_session.read_gbq_query.assert_called_once()
generated_sql = mock_session.read_gbq_query.call_args[0][0]
expected = "CREATE EXTERNAL TABLE my-project.my_dataset.my_table (col1 INT64, col2 STRING) OPTIONS (format = 'CSV', uris = ['gs://bucket/path*'])"
assert generated_sql == expected
get_table_metadata_mock.assert_called_once()