From 1f103eb223f12104c5ceb1aaed9bacd1f97223ef Mon Sep 17 00:00:00 2001 From: Dushyant Bhatnagar Date: Mon, 22 Jul 2024 14:22:33 -0700 Subject: [PATCH] Increase the post timeout for uploading With larger and larger amounts of data being uploaded by more modern DUTs and tester software, we are seeing runs taking even longer to upload and get responses from servers. PiperOrigin-RevId: 654894515 --- openhtf/output/callbacks/mfg_inspector.py | 29 ++++++++++++++++------- 1 file changed, 21 insertions(+), 8 deletions(-) diff --git a/openhtf/output/callbacks/mfg_inspector.py b/openhtf/output/callbacks/mfg_inspector.py index 349c97a2..896bff0a 100644 --- a/openhtf/output/callbacks/mfg_inspector.py +++ b/openhtf/output/callbacks/mfg_inspector.py @@ -18,13 +18,17 @@ import time import zlib +from google.auth import credentials as credentials_lib from google.auth.transport import requests from google.oauth2 import service_account - from openhtf.output import callbacks -from openhtf.output.proto import guzzle_pb2 from openhtf.output.proto import test_runs_converter +from openhtf.output.proto import guzzle_pb2 + + +_MFG_INSPECTOR_UPLOAD_TIMEOUT = 60 * 5 + class UploadFailedError(Exception): """Raised when an upload to mfg-inspector fails.""" @@ -34,20 +38,29 @@ class InvalidTestRunError(Exception): """Raised if test run is invalid.""" -def _send_mfg_inspector_request(envelope_data, credentials, destination_url): +def _send_mfg_inspector_request( + envelope_data: bytes, + credentials: credentials_lib.Credentials, + destination_url: str, +): """Send upload http request. Intended to be run in retry loop.""" logging.info('Uploading result...') with requests.AuthorizedSession(credentials) as authed_session: response = authed_session.request( - 'POST', destination_url, data=envelope_data) + 'POST', + destination_url, + data=envelope_data, + timeout=_MFG_INSPECTOR_UPLOAD_TIMEOUT, + ) try: result = response.json() - except Exception: - logging.warning('Upload failed with response %s: %s', response, - response.text) - raise UploadFailedError(response, response.text) + except Exception as e: + logging.exception( + 'Upload failed with response %s: %s', response, response.text + ) + raise UploadFailedError(response, response.text) from e if response.status_code == 200: return result