Skip to content

Commit

Permalink
Spanner: Fix database not found error, Closes #4071
Browse files Browse the repository at this point in the history
  • Loading branch information
chemelnucfin committed Dec 20, 2017
1 parent a62931a commit a68f323
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 10 deletions.
10 changes: 2 additions & 8 deletions spanner/google/cloud/spanner_v1/database.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
import threading

import google.auth.credentials
from google.api_core import exceptions
from google.gax.errors import GaxError
from google.gax.grpc import exc_to_code
from google.cloud.spanner_v1.gapic.spanner_client import SpannerClient
Expand Down Expand Up @@ -208,14 +209,7 @@ def create(self):
options=options,
)
except GaxError as exc:
if exc_to_code(exc.cause) == StatusCode.ALREADY_EXISTS:
raise Conflict(self.name)
elif exc_to_code(exc.cause) == StatusCode.NOT_FOUND:
raise NotFound('Instance not found: {name}'.format(
name=self._instance.name,
))
raise

raise exceptions.from_grpc_error(exc.cause)
return future

def exists(self):
Expand Down
30 changes: 30 additions & 0 deletions spanner/tests/system/test_system.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@

from google.cloud._helpers import UTC
from google.cloud.exceptions import GrpcRendezvous
from google.cloud.exceptions import NotFound
from google.cloud.spanner_v1._helpers import TimestampWithNanoseconds
from google.cloud.spanner import Client
from google.cloud.spanner import KeyRange
Expand Down Expand Up @@ -282,6 +283,35 @@ def test_create_database(self):
for database in Config.INSTANCE.list_databases()]
self.assertIn(temp_db_id, database_ids)

def test_table_not_found(self):
temp_db_id = 'temp_db' + unique_resource_id('_')

correct_table = 'MyTable'
incorrect_table = 'NotMyTable'
self.assertNotEqual(table_name1, table_name2)

create_table = (
'CREATE TABLE {} (\n'
' Id STRING(36) NOT NULL,\n'
' Field1 STRING(36) NOT NULL\n'
') PRIMARY KEY (Id)').format(correct_table)
index = 'CREATE INDEX IDX ON {} (Field1)'.format(incorrect_table)

temp_db = Config.INSTANCE.database(
temp_db_id,
ddl_statements=[
create_table,
index,
],
)
try:
temp_db.create()
except NotFound as exc:
self.assertEqual(exc.args[0],
'Table not found: {0}'.format(incorrect_table))
except:
self.fail()

def test_update_database_ddl(self):
pool = BurstyPool()
temp_db_id = 'temp_db' + unique_resource_id('_')
Expand Down
4 changes: 2 additions & 2 deletions spanner/tests/unit/test_database.py
Original file line number Diff line number Diff line change
Expand Up @@ -284,7 +284,7 @@ def test___ne__(self):
self.assertNotEqual(database1, database2)

def test_create_grpc_error(self):
from google.gax.errors import GaxError
from google.api_core.exceptions import GoogleAPICallError

client = _Client()
api = client.database_admin_api = _FauxDatabaseAdminAPI(
Expand All @@ -293,7 +293,7 @@ def test_create_grpc_error(self):
pool = _Pool()
database = self._make_one(self.DATABASE_ID, instance, pool=pool)

with self.assertRaises(GaxError):
with self.assertRaises(GoogleAPICallError):
database.create()

(parent, create_statement, extra_statements,
Expand Down

0 comments on commit a68f323

Please sign in to comment.