From 686b2d049c6e8181723e9051539a952813dea5bc Mon Sep 17 00:00:00 2001 From: Casey Ransom Date: Thu, 4 Apr 2024 15:09:42 -0400 Subject: [PATCH] fixup! fixup! fixup! Test bucket content caching to skip uploads. --- src/zinc/storages/aws.py | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/zinc/storages/aws.py b/src/zinc/storages/aws.py index a400d85..258fdb6 100644 --- a/src/zinc/storages/aws.py +++ b/src/zinc/storages/aws.py @@ -3,6 +3,7 @@ from copy import copy from urllib.parse import urlparse import logging +import sys import boto3 @@ -10,6 +11,14 @@ log = logging.getLogger(__name__) +log.setLevel(logging.DEBUG) +handler = logging.StreamHandler(sys.stdout) +handler.setLevel(logging.DEBUG) +formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') +handler.setFormatter(formatter) +log.addHandler(handler) + + class S3StorageBackend(StorageBackend): @@ -35,6 +44,7 @@ def __cache_contents(self): content = self._bucket.objects.filter(Prefix=self._prefix) for item in content: bucket_contents.append(item.key) + log.debug(f"Adding to cache: {item.key}") return bucket_contents @@ -64,6 +74,7 @@ def bind_to_catalog(self, id=None): cpy = copy(self) cpy._prefix = id # TODO gate this. + log.debug(f"Binding to catalog {id}") cpy._bucket_contents = cpy.__cache_contents() return cpy @@ -106,9 +117,9 @@ def put(self, subpath, fileobj, max_age=None, **kwargs): # Skip cache for index/catalog, and any cached file. if keyname in self._bucket_contents and not any(keyname in x for x in ["index.json", "catalog.json"]): - print(f"Would skip upload for {keyname}") + log.debug(f"Would skip upload for {keyname}") else: - print(f"Uploading {keyname}") + log.debug(f"Uploading {keyname}") self._bucket.upload_fileobj(fileobj, keyname, ExtraArgs=extra_args)