From 8ead3e5b53fca928a94b9bc802bc571191da4f4c Mon Sep 17 00:00:00 2001 From: Dennis Chen Date: Mon, 3 Jun 2024 11:22:26 -0700 Subject: [PATCH] Check if DBs already exist instead of crashing Svaes time clearing all tables --- store/app/api/crud/base.py | 47 +++++++++++++++++++++----------------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/store/app/api/crud/base.py b/store/app/api/crud/base.py index adb89729..6743d84b 100644 --- a/store/app/api/crud/base.py +++ b/store/app/api/crud/base.py @@ -6,6 +6,7 @@ import aioboto3 from types_aiobotocore_dynamodb.service_resource import DynamoDBServiceResource +from botocore.exceptions import ClientError logger = logging.getLogger(__name__) @@ -40,7 +41,8 @@ async def _create_dynamodb_table( gsis: list[tuple[str, str, Literal["S", "N", "B"], Literal["HASH", "RANGE"]]] = [], deletion_protection: bool = False, ) -> None: - """Creates a table in the Dynamo database. + """Creates a table in the Dynamo database if a table of that name does + not already exist. Args: name: Name of the table. @@ -52,23 +54,26 @@ async def _create_dynamodb_table( deletion_protection: Whether the table is protected from being deleted. """ - logger.info("Creating %s table", name) - table = await self.db.create_table( - AttributeDefinitions=[ - {"AttributeName": n, "AttributeType": t} - for n, t in itertools.chain(((n, t) for (n, t, _) in keys), ((n, t) for _, n, t, _ in gsis)) - ], - TableName=name, - KeySchema=[{"AttributeName": n, "KeyType": t} for n, _, t in keys], - GlobalSecondaryIndexes=[ - { - "IndexName": i, - "KeySchema": [{"AttributeName": n, "KeyType": t}], - "Projection": {"ProjectionType": "ALL"}, - } - for i, n, _, t in gsis - ], - DeletionProtectionEnabled=deletion_protection, - BillingMode="PAY_PER_REQUEST", - ) - await table.wait_until_exists() + try: + await self.db.meta.client.describe_table(TableName=name) + except ClientError as e: + logger.info("Creating %s table", name) + table = await self.db.create_table( + AttributeDefinitions=[ + {"AttributeName": n, "AttributeType": t} + for n, t in itertools.chain(((n, t) for (n, t, _) in keys), ((n, t) for _, n, t, _ in gsis)) + ], + TableName=name, + KeySchema=[{"AttributeName": n, "KeyType": t} for n, _, t in keys], + GlobalSecondaryIndexes=[ + { + "IndexName": i, + "KeySchema": [{"AttributeName": n, "KeyType": t}], + "Projection": {"ProjectionType": "ALL"}, + } + for i, n, _, t in gsis + ], + DeletionProtectionEnabled=deletion_protection, + BillingMode="PAY_PER_REQUEST", + ) + await table.wait_until_exists()