From cf21e8147235d80cdb80c34ffb5b9af8aaab1ab4 Mon Sep 17 00:00:00 2001 From: Eric Charles Date: Mon, 27 Apr 2020 20:21:55 +0200 Subject: [PATCH] Nested try/except on _load_jupyter_server_extension discovery --- jupyter_server/serverapp.py | 41 ++++++++++++++++++++----------------- 1 file changed, 22 insertions(+), 19 deletions(-) diff --git a/jupyter_server/serverapp.py b/jupyter_server/serverapp.py index d8fe7b1c36..b11ccc89ff 100755 --- a/jupyter_server/serverapp.py +++ b/jupyter_server/serverapp.py @@ -1605,31 +1605,34 @@ def load_server_extensions(self): "loaded".format(extension_name=extension.extension_name) ) # Find the extension loading function. + func = None try: # This function was prefixed with an underscore in in v1.0 # because this shouldn't be a public API for most extensions. func = getattr(extension, '_load_jupyter_server_extension') - func(self) - self.log.debug(log_msg) except AttributeError: - # For backwards compatibility, we will still look for non - # underscored loading functions. - func = getattr(extension, 'load_jupyter_server_extension') + try: + # For backwards compatibility, we will still look for non + # underscored loading functions. + func = getattr(extension, 'load_jupyter_server_extension') + warn_msg = _( + "{extkey} is enabled. " + "`load_jupyter_server_extension` function " + "was found but `_load_jupyter_server_extension`" + "is preferred.".format(extkey=extkey) + ) + self.log.warning(warn_msg) + except AttributeError: + warn_msg = _( + "{extkey} is enabled but no " + "`_load_jupyter_server_extension` function " + "was found.".format(extkey=extkey) + ) + self.log.warning(warn_msg) + if func: func(self) - warn_msg = _( - "{extkey} is enabled. " - "`load_jupyter_server_extension` function " - "was found but `_load_jupyter_server_extension`" - "is preferred.".format(extkey=extkey) - ) - self.log.warning(warn_msg) - except AttributeError: - warn_msg = _( - "{extkey} is enabled but no " - "`_load_jupyter_server_extension` function " - "was found.".format(extkey=extkey) - ) - self.log.warning(warn_msg) + self.log.debug(log_msg) + def init_mime_overrides(self): # On some Windows machines, an application has registered incorrect