Skip to content

Commit

Permalink
bigquery: generate row IDs in create_rows (#4173)
Browse files Browse the repository at this point in the history
If the user doesn't provide row IDs, create unique IDs for them.
  • Loading branch information
jba authored and tswast committed Oct 12, 2017
1 parent a06b84b commit d7ad25e
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 13 deletions.
6 changes: 4 additions & 2 deletions bigquery/google/cloud/bigquery/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -860,7 +860,7 @@ def create_rows(self, table, rows, row_ids=None, selected_fields=None,
:type row_ids: list of string
:param row_ids: (Optional) Unique ids, one per row being inserted.
If not passed, no de-duplication occurs.
If omitted, unique IDs are created.
:type selected_fields: list of :class:`SchemaField`
:param selected_fields:
Expand Down Expand Up @@ -923,7 +923,8 @@ def create_rows(self, table, rows, row_ids=None, selected_fields=None,
info = {'json': row_info}
if row_ids is not None:
info['insertId'] = row_ids[index]

else:
info['insertId'] = str(uuid.uuid4())
rows_info.append(info)

if skip_invalid_rows is not None:
Expand All @@ -935,6 +936,7 @@ def create_rows(self, table, rows, row_ids=None, selected_fields=None,
if template_suffix is not None:
data['templateSuffix'] = template_suffix

# TODO(jba): use self._call_api here after #4148 is merged.
response = self._connection.api_request(
method='POST',
path='%s/insertAll' % table.path,
Expand Down
42 changes: 31 additions & 11 deletions bigquery/tests/unit/test_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -1889,10 +1889,14 @@ def _row_data(row):
'joined': joined}

SENT = {
'rows': [{'json': _row_data(row)} for row in ROWS],
'rows': [{
'json': _row_data(row),
'insertId': str(i),
} for i, row in enumerate(ROWS)],
}

errors = client.create_rows(table, ROWS)
with mock.patch('uuid.uuid4', side_effect=map(str, range(len(ROWS)))):
errors = client.create_rows(table, ROWS)

self.assertEqual(len(errors), 0)
self.assertEqual(len(conn._requested), 1)
Expand Down Expand Up @@ -1950,10 +1954,14 @@ def _row_data(row):
return row

SENT = {
'rows': [{'json': _row_data(row)} for row in ROWS],
'rows': [{
'json': _row_data(row),
'insertId': str(i),
} for i, row in enumerate(ROWS)],
}

errors = client.create_rows(table, ROWS)
with mock.patch('uuid.uuid4', side_effect=map(str, range(len(ROWS)))):
errors = client.create_rows(table, ROWS)

self.assertEqual(len(errors), 0)
self.assertEqual(len(conn._requested), 1)
Expand Down Expand Up @@ -1990,10 +1998,14 @@ def _row_data(row):
return {'full_name': row[0], 'age': str(row[1])}

SENT = {
'rows': [{'json': _row_data(row)} for row in ROWS],
'rows': [{
'json': _row_data(row),
'insertId': str(i),
} for i, row in enumerate(ROWS)],
}

errors = client.create_rows(table, ROWS)
with mock.patch('uuid.uuid4', side_effect=map(str, range(len(ROWS)))):
errors = client.create_rows(table, ROWS)

self.assertEqual(len(errors), 0)
self.assertEqual(len(conn._requested), 1)
Expand Down Expand Up @@ -2095,10 +2107,14 @@ def _row_data(row):
'struct': row[1]}

SENT = {
'rows': [{'json': _row_data(row)} for row in ROWS],
'rows': [{
'json': _row_data(row),
'insertId': str(i),
} for i, row in enumerate(ROWS)],
}

errors = client.create_rows(table, ROWS)
with mock.patch('uuid.uuid4', side_effect=map(str, range(len(ROWS)))):
errors = client.create_rows(table, ROWS)

self.assertEqual(len(errors), 0)
self.assertEqual(len(conn._requested), 1)
Expand Down Expand Up @@ -2138,11 +2154,15 @@ def _row_data(row):
'phone': row[1]}

SENT = {
'rows': [{'json': _row_data(row)} for row in ROWS],
'rows': [{
'json': _row_data(row),
'insertId': str(i),
} for i, row in enumerate(ROWS)],
}

errors = client.create_rows(self.TABLE_REF, ROWS,
selected_fields=[full_name, phone])
with mock.patch('uuid.uuid4', side_effect=map(str, range(len(ROWS)))):
errors = client.create_rows(self.TABLE_REF, ROWS,
selected_fields=[full_name, phone])

self.assertEqual(len(errors), 0)
self.assertEqual(len(conn._requested), 1)
Expand Down

0 comments on commit d7ad25e

Please sign in to comment.