From 5daca49893adbd0f7b207478d6f609b26d29ec7e Mon Sep 17 00:00:00 2001 From: Geoff Brown Date: Tue, 23 Jul 2024 16:01:01 -0600 Subject: [PATCH] add num_retries to every execute() call --- mozapkpublisher/common/store.py | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/mozapkpublisher/common/store.py b/mozapkpublisher/common/store.py index 490a632..237dd91 100644 --- a/mozapkpublisher/common/store.py +++ b/mozapkpublisher/common/store.py @@ -15,6 +15,8 @@ logger = logging.getLogger(__name__) +NUM_RETRIES = 3 + def add_general_google_play_arguments(parser): parser.add_argument('--credentials', dest='google_play_credentials_filename', @@ -32,7 +34,7 @@ class _ExecuteDummy: def __init__(self, return_value): self._return_value = return_value - def execute(self): + def execute(self, **kwargs): return self._return_value @@ -70,7 +72,7 @@ def get_track_status(self, track): editId=self._edit_id, track=track, packageName=self._package_name - ).execute() + ).execute(num_retries=NUM_RETRIES) logger.debug('Track "{}" has status: {}'.format(track, response)) return response @@ -84,7 +86,7 @@ def upload_apk(self, apk): media_body=apk_path, # Seems like mime type need not be specified for apk files: # media_mime_type='application/octet-stream', - ).execute() + ).execute(num_retries=NUM_RETRIES) logger.info('"{}" uploaded'.format(apk_path)) logger.debug('Upload response: {}'.format(response)) except HttpError as e: @@ -116,7 +118,7 @@ def upload_aab(self, aab): packageName=self._package_name, media_body=aab_path, media_mime_type='application/octet-stream', - ).execute() + ).execute(num_retries=NUM_RETRIES) logger.info('"{}" uploaded'.format(aab_path)) logger.debug('Upload response: {}'.format(response)) except Exception: @@ -158,7 +160,7 @@ def _update_track(self, track, version_codes, rollout_percentage=None): response = self._edit_resource.tracks().update( editId=self._edit_id, track=track, packageName=self._package_name, body=body - ).execute() + ).execute(num_retries=NUM_RETRIES) logger.info('Track "{}" updated with: {}'.format(track, body)) logger.debug('Track update response: {}'.format(response)) @@ -170,7 +172,7 @@ def update_listings(self, language, title, full_description, short_description): } response = self._edit_resource.listings().update( editId=self._edit_id, packageName=self._package_name, language=language, body=body - ).execute() + ).execute(num_retries=NUM_RETRIES) logger.info(u'Listing for language "{}" has been updated with: {}'.format(language, body)) logger.debug(u'Listing response: {}'.format(response)) @@ -178,7 +180,7 @@ def update_whats_new(self, language, apk_version_code, whats_new): response = self._edit_resource.apklistings().update( editId=self._edit_id, packageName=self._package_name, language=language, apkVersionCode=apk_version_code, body={'recentChanges': whats_new} - ).execute() + ).execute(num_retries=NUM_RETRIES) logger.info(u'What\'s new listing for ("{}", "{}") has been updated to: "{}"'.format( language, apk_version_code, whats_new )) @@ -188,11 +190,11 @@ def update_whats_new(self, language, apk_version_code, whats_new): @contextmanager def transaction(credentials_file_name, package_name, *, contact_server, dry_run): edit_resource = _create_google_edit_resource(contact_server, credentials_file_name) - edit_id = edit_resource.insert(body={}, packageName=package_name).execute()['id'] + edit_id = edit_resource.insert(body={}, packageName=package_name).execute(num_retries=NUM_RETRIES)['id'] google_play = GooglePlayEdit(edit_resource, edit_id, package_name) yield google_play if not dry_run: - edit_resource.commit(editId=edit_id, packageName=package_name).execute() + edit_resource.commit(editId=edit_id, packageName=package_name).execute(num_retries=NUM_RETRIES) logger.info('Changes committed') logger.debug('edit_id "{}" for "{}" has been committed'.format(edit_id, package_name)) else: @@ -210,7 +212,7 @@ def _create_google_edit_resource(contact_google_play, credentials_file_name): service = build(serviceName='androidpublisher', version='v3', credentials=credentials, cache_discovery=False, - num_retries=3) + num_retries=NUM_RETRIES) return service.edits() else: