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_io.py
More file actions
40 lines (33 loc) · 1.5 KB
/
test_io.py
File metadata and controls
40 lines (33 loc) · 1.5 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
# 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._operations.io
import bigframes.session
@pytest.fixture
def mock_session():
return mock.create_autospec(spec=bigframes.session.Session)
@mock.patch("bigframes.bigquery._operations.io._get_table_metadata")
def test_load_data(get_table_metadata_mock, mock_session):
bigframes.bigquery._operations.io.load_data(
"my-project.my_dataset.my_table",
columns={"col1": "INT64", "col2": "STRING"},
from_files_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 = "LOAD DATA INTO `my-project.my_dataset.my_table` (\n `col1` INT64,\n `col2` STRING\n) FROM FILES (format='CSV', uris=['gs://bucket/path*'])"
assert generated_sql == expected
get_table_metadata_mock.assert_called_once()