Skip to content

Commit

Permalink
Updating datastore HTTP wrapper. (googleapis#4388)
Browse files Browse the repository at this point in the history
- Making the method arguments (both in position and name) match the
  arguments for `google.cloud.datastore_v1.gapic.datastore_client.DatastoreClient`
- Passing positional as positional and keyword as keyword when using
  the low-level API client in `Client.get()` (was previously using all
  keyword arguments to `.lookup()`, which caused this issue)
- Updating mock call assertions to match the change in calling behavior.

Fixes googleapis#4387.
  • Loading branch information
dhermes authored and aw committed Nov 15, 2017
1 parent 9605da8 commit a31375f
Show file tree
Hide file tree
Showing 4 changed files with 77 additions and 72 deletions.
96 changes: 49 additions & 47 deletions datastore/google/cloud/datastore/_http.py
Original file line number Diff line number Diff line change
Expand Up @@ -148,48 +148,47 @@ class HTTPDatastoreAPI(object):
def __init__(self, client):
self.client = client

def lookup(self, project, read_options, key_pbs):
def lookup(self, project_id, keys, read_options=None):
"""Perform a ``lookup`` request.
:type project: str
:param project: The project to connect to. This is
usually your project name in the cloud console.
:type project_id: str
:param project_id: The project to connect to. This is
usually your project name in the cloud console.
:type keys: List[.entity_pb2.Key]
:param keys: The keys to retrieve from the datastore.
:type read_options: :class:`.datastore_pb2.ReadOptions`
:param read_options: The options for this lookup. Contains a
:param read_options: (Optional) The options for this lookup. Contains
either the transaction for the read or
``STRONG`` or ``EVENTUAL`` read consistency.
:type key_pbs: list of
:class:`.entity_pb2.Key`
:param key_pbs: The keys to retrieve from the datastore.
:rtype: :class:`.datastore_pb2.LookupResponse`
:returns: The returned protobuf response object.
"""
request_pb = _datastore_pb2.LookupRequest(
project_id=project,
project_id=project_id,
read_options=read_options,
keys=key_pbs,
keys=keys,
)
return _rpc(self.client._http, project, 'lookup',
return _rpc(self.client._http, project_id, 'lookup',
self.client._base_url,
request_pb, _datastore_pb2.LookupResponse)

def run_query(self, project, partition_id, read_options,
def run_query(self, project_id, partition_id, read_options=None,
query=None, gql_query=None):
"""Perform a ``runQuery`` request.
:type project: str
:param project: The project to connect to. This is
usually your project name in the cloud console.
:type project_id: str
:param project_id: The project to connect to. This is
usually your project name in the cloud console.
:type partition_id: :class:`.entity_pb2.PartitionId`
:param partition_id: Partition ID corresponding to an optional
namespace and project ID.
:type read_options: :class:`.datastore_pb2.ReadOptions`
:param read_options: The options for this query. Contains a
:param read_options: (Optional) The options for this query. Contains
either the transaction for the read or
``STRONG`` or ``EVENTUAL`` read consistency.
Expand All @@ -205,37 +204,40 @@ def run_query(self, project, partition_id, read_options,
:returns: The returned protobuf response object.
"""
request_pb = _datastore_pb2.RunQueryRequest(
project_id=project,
project_id=project_id,
partition_id=partition_id,
read_options=read_options,
query=query,
gql_query=gql_query,
)
return _rpc(self.client._http, project, 'runQuery',
return _rpc(self.client._http, project_id, 'runQuery',
self.client._base_url,
request_pb, _datastore_pb2.RunQueryResponse)

def begin_transaction(self, project):
def begin_transaction(self, project_id, transaction_options=None):
"""Perform a ``beginTransaction`` request.
:type project: str
:param project: The project to connect to. This is
usually your project name in the cloud console.
:type project_id: str
:param project_id: The project to connect to. This is
usually your project name in the cloud console.
:type transaction_options: ~.datastore_v1.types.TransactionOptions
:param transaction_options: (Optional) Options for a new transaction.
:rtype: :class:`.datastore_pb2.BeginTransactionResponse`
:returns: The returned protobuf response object.
"""
request_pb = _datastore_pb2.BeginTransactionRequest()
return _rpc(self.client._http, project, 'beginTransaction',
return _rpc(self.client._http, project_id, 'beginTransaction',
self.client._base_url,
request_pb, _datastore_pb2.BeginTransactionResponse)

def commit(self, project, mode, mutations, transaction=None):
def commit(self, project_id, mode, mutations, transaction=None):
"""Perform a ``commit`` request.
:type project: str
:param project: The project to connect to. This is
usually your project name in the cloud console.
:type project_id: str
:param project_id: The project to connect to. This is
usually your project name in the cloud console.
:type mode: :class:`.gapic.datastore.v1.enums.CommitRequest.Mode`
:param mode: The type of commit to perform. Expected to be one of
Expand All @@ -254,51 +256,51 @@ def commit(self, project, mode, mutations, transaction=None):
:returns: The returned protobuf response object.
"""
request_pb = _datastore_pb2.CommitRequest(
project_id=project,
project_id=project_id,
mode=mode,
transaction=transaction,
mutations=mutations,
)
return _rpc(self.client._http, project, 'commit',
return _rpc(self.client._http, project_id, 'commit',
self.client._base_url,
request_pb, _datastore_pb2.CommitResponse)

def rollback(self, project, transaction_id):
def rollback(self, project_id, transaction):
"""Perform a ``rollback`` request.
:type project: str
:param project: The project to connect to. This is
usually your project name in the cloud console.
:type project_id: str
:param project_id: The project to connect to. This is
usually your project name in the cloud console.
:type transaction_id: bytes
:param transaction_id: The transaction ID to rollback.
:type transaction: bytes
:param transaction: The transaction ID to rollback.
:rtype: :class:`.datastore_pb2.RollbackResponse`
:returns: The returned protobuf response object.
"""
request_pb = _datastore_pb2.RollbackRequest(
project_id=project,
transaction=transaction_id,
project_id=project_id,
transaction=transaction,
)
# Response is empty (i.e. no fields) but we return it anyway.
return _rpc(self.client._http, project, 'rollback',
return _rpc(self.client._http, project_id, 'rollback',
self.client._base_url,
request_pb, _datastore_pb2.RollbackResponse)

def allocate_ids(self, project, key_pbs):
def allocate_ids(self, project_id, keys):
"""Perform an ``allocateIds`` request.
:type project: str
:param project: The project to connect to. This is
usually your project name in the cloud console.
:type project_id: str
:param project_id: The project to connect to. This is
usually your project name in the cloud console.
:type key_pbs: list of :class:`.entity_pb2.Key`
:param key_pbs: The keys for which the backend should allocate IDs.
:type keys: List[.entity_pb2.Key]
:param keys: The keys for which the backend should allocate IDs.
:rtype: :class:`.datastore_pb2.AllocateIdsResponse`
:returns: The returned protobuf response object.
"""
request_pb = _datastore_pb2.AllocateIdsRequest(keys=key_pbs)
return _rpc(self.client._http, project, 'allocateIds',
request_pb = _datastore_pb2.AllocateIdsRequest(keys=keys)
return _rpc(self.client._http, project_id, 'allocateIds',
self.client._base_url,
request_pb, _datastore_pb2.AllocateIdsResponse)
4 changes: 2 additions & 2 deletions datastore/google/cloud/datastore/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -133,9 +133,9 @@ def _extended_lookup(datastore_api, project, key_pbs,
while loop_num < _MAX_LOOPS: # loop against possible deferred.
loop_num += 1
lookup_response = datastore_api.lookup(
project_id=project,
project,
key_pbs,
read_options=read_options,
keys=key_pbs,
)

# Accumulate the new results.
Expand Down
17 changes: 10 additions & 7 deletions datastore/tests/unit/test__http.py
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@ def test_lookup_single_key_empty_response(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb])
response = ds_api.lookup(project, [key_pb], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down Expand Up @@ -186,7 +186,7 @@ def test_lookup_single_key_empty_response_w_eventual(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb])
response = ds_api.lookup(project, [key_pb], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down Expand Up @@ -217,7 +217,7 @@ def test_lookup_single_key_empty_response_w_transaction(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb])
response = ds_api.lookup(project, [key_pb], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down Expand Up @@ -251,7 +251,7 @@ def test_lookup_single_key_nonempty_response(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb])
response = ds_api.lookup(project, [key_pb], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down Expand Up @@ -285,7 +285,8 @@ def test_lookup_multiple_keys_empty_response(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb1, key_pb2])
response = ds_api.lookup(
project, [key_pb1, key_pb2], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down Expand Up @@ -320,7 +321,8 @@ def test_lookup_multiple_keys_w_missing(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb1, key_pb2])
response = ds_api.lookup(
project, [key_pb1, key_pb2], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down Expand Up @@ -354,7 +356,8 @@ def test_lookup_multiple_keys_w_deferred(self):

# Make request.
ds_api = self._make_one(client)
response = ds_api.lookup(project, read_options, [key_pb1, key_pb2])
response = ds_api.lookup(
project, [key_pb1, key_pb2], read_options=read_options)

# Check the result and verify the callers.
self.assertEqual(response, rsp_pb)
Expand Down
32 changes: 16 additions & 16 deletions datastore/tests/unit/test_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -352,9 +352,9 @@ def test_get_multi_miss(self):

read_options = datastore_pb2.ReadOptions()
ds_api.lookup.assert_called_once_with(
project_id=self.PROJECT,
self.PROJECT,
[key.to_protobuf()],
read_options=read_options,
keys=[key.to_protobuf()],
)

def test_get_multi_miss_w_missing(self):
Expand Down Expand Up @@ -389,9 +389,9 @@ def test_get_multi_miss_w_missing(self):

read_options = datastore_pb2.ReadOptions()
ds_api.lookup.assert_called_once_with(
project_id=self.PROJECT,
self.PROJECT,
[key_pb],
read_options=read_options,
keys=[key_pb],
)

def test_get_multi_w_missing_non_empty(self):
Expand Down Expand Up @@ -438,9 +438,9 @@ def test_get_multi_miss_w_deferred(self):

read_options = datastore_pb2.ReadOptions()
ds_api.lookup.assert_called_once_with(
project_id=self.PROJECT,
self.PROJECT,
[key_pb],
read_options=read_options,
keys=[key_pb],
)

def test_get_multi_w_deferred_from_backend_but_not_passed(self):
Expand Down Expand Up @@ -488,14 +488,14 @@ def test_get_multi_w_deferred_from_backend_but_not_passed(self):
self.assertEqual(ds_api.lookup.call_count, 2)
read_options = datastore_pb2.ReadOptions()
ds_api.lookup.assert_any_call(
project_id=self.PROJECT,
self.PROJECT,
[key2_pb],
read_options=read_options,
keys=[key2_pb],
)
ds_api.lookup.assert_any_call(
project_id=self.PROJECT,
self.PROJECT,
[key1_pb, key2_pb],
read_options=read_options,
keys=[key1_pb, key2_pb],
)

def test_get_multi_hit(self):
Expand Down Expand Up @@ -529,8 +529,8 @@ def test_get_multi_hit(self):

read_options = datastore_pb2.ReadOptions()
ds_api.lookup.assert_called_once_with(
keys=[key.to_protobuf()],
project_id=self.PROJECT,
self.PROJECT,
[key.to_protobuf()],
read_options=read_options,
)

Expand Down Expand Up @@ -568,8 +568,8 @@ def test_get_multi_hit_w_transaction(self):

read_options = datastore_pb2.ReadOptions(transaction=txn_id)
ds_api.lookup.assert_called_once_with(
project_id=self.PROJECT,
keys=[key.to_protobuf()],
self.PROJECT,
[key.to_protobuf()],
read_options=read_options,
)

Expand Down Expand Up @@ -605,9 +605,9 @@ def test_get_multi_hit_multiple_keys_same_project(self):

read_options = datastore_pb2.ReadOptions()
ds_api.lookup.assert_called_once_with(
project_id=self.PROJECT,
self.PROJECT,
[key1.to_protobuf(), key2.to_protobuf()],
read_options=read_options,
keys=[key1.to_protobuf(), key2.to_protobuf()],
)

def test_get_multi_hit_multiple_keys_different_project(self):
Expand Down

0 comments on commit a31375f

Please sign in to comment.