From 20ed0183c6087aba8f891f16cd56e5ff5399c7bd Mon Sep 17 00:00:00 2001 From: Elizabeth Thompson Date: Mon, 6 Mar 2023 16:49:42 -0800 Subject: [PATCH 1/2] log different selenium timeout errors differently --- superset/utils/webdriver.py | 50 ++++++++++++++++++++++++++----------- 1 file changed, 35 insertions(+), 15 deletions(-) diff --git a/superset/utils/webdriver.py b/superset/utils/webdriver.py index 92a73d347c20a..fc0f5ef438926 100644 --- a/superset/utils/webdriver.py +++ b/superset/utils/webdriver.py @@ -176,22 +176,42 @@ def get_screenshot( sleep(selenium_headstart) try: - logger.debug("Wait for the presence of %s", element_name) - element = WebDriverWait(driver, self._screenshot_locate_wait).until( - EC.presence_of_element_located((By.CLASS_NAME, element_name)) - ) + try: + # page didn't load + logger.debug("Wait for the presence of %s", element_name) + element = WebDriverWait(driver, self._screenshot_locate_wait).until( + EC.presence_of_element_located((By.CLASS_NAME, element_name)) + ) + except TimeoutException as ex: + logger.exception("Selenium timed out requesting url %s", url) + raise ex - logger.debug("Wait for chart containers to draw") - WebDriverWait(driver, self._screenshot_locate_wait).until( - EC.visibility_of_all_elements_located( - (By.CLASS_NAME, "slice_container") + try: + # chart containers didn't render + logger.debug("Wait for chart containers to draw") + WebDriverWait(driver, self._screenshot_locate_wait).until( + EC.visibility_of_all_elements_located( + (By.CLASS_NAME, "slice_container") + ) ) - ) + except TimeoutException as ex: + logger.exception( + "Selenium timed out waiting for chart containers to draw at url %s", + url, + ) + raise ex - logger.debug("Wait for loading element of charts to be gone") - WebDriverWait(driver, self._screenshot_load_wait).until_not( - EC.presence_of_all_elements_located((By.CLASS_NAME, "loading")) - ) + try: + # charts took too long to load + logger.debug("Wait for loading element of charts to be gone") + WebDriverWait(driver, self._screenshot_load_wait).until_not( + EC.presence_of_all_elements_located((By.CLASS_NAME, "loading")) + ) + except TimeoutException as ex: + logger.exception( + "Selenium timed out waiting for charts to load at url %s", url + ) + raise ex selenium_animation_wait = current_app.config[ "SCREENSHOT_SELENIUM_ANIMATION_WAIT" @@ -215,9 +235,9 @@ def get_screenshot( ) img = element.screenshot_as_png - except TimeoutException: - logger.exception("Selenium timed out requesting url %s", url) + # raise again for the finally block, but handled above + pass except StaleElementReferenceException: logger.exception( "Selenium got a stale element while requesting url %s", From 2c2a18b6f65ed062914e3969068aacca370c2199 Mon Sep 17 00:00:00 2001 From: Elizabeth Thompson Date: Wed, 8 Mar 2023 17:44:48 -0800 Subject: [PATCH 2/2] add more url details to debug statements --- superset/utils/webdriver.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/superset/utils/webdriver.py b/superset/utils/webdriver.py index fc0f5ef438926..05dbee674052d 100644 --- a/superset/utils/webdriver.py +++ b/superset/utils/webdriver.py @@ -178,7 +178,9 @@ def get_screenshot( try: try: # page didn't load - logger.debug("Wait for the presence of %s", element_name) + logger.debug( + "Wait for the presence of %s at url: %s", element_name, url + ) element = WebDriverWait(driver, self._screenshot_locate_wait).until( EC.presence_of_element_located((By.CLASS_NAME, element_name)) ) @@ -188,7 +190,7 @@ def get_screenshot( try: # chart containers didn't render - logger.debug("Wait for chart containers to draw") + logger.debug("Wait for chart containers to draw at url: %s", url) WebDriverWait(driver, self._screenshot_locate_wait).until( EC.visibility_of_all_elements_located( (By.CLASS_NAME, "slice_container") @@ -203,7 +205,9 @@ def get_screenshot( try: # charts took too long to load - logger.debug("Wait for loading element of charts to be gone") + logger.debug( + "Wait for loading element of charts to be gone at url: %s", url + ) WebDriverWait(driver, self._screenshot_load_wait).until_not( EC.presence_of_all_elements_located((By.CLASS_NAME, "loading")) )