-
Notifications
You must be signed in to change notification settings - Fork 914
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
kedro-telemetry
: Improve performance by switching to after_command_run
#4014
Changes from 13 commits
1e67775
9fca028
29b627f
8e9e5d4
22977d5
3142ef8
6ee73b8
a97a012
45013cf
bbab82c
66136bd
f5fe4cc
67dd0ff
184c35d
7b592fe
c5c22eb
155a30d
de64ef7
f6f657b
b66c0fd
43054c5
a31f0d4
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,6 +5,7 @@ | |
from __future__ import annotations | ||
|
||
import importlib | ||
import logging | ||
import sys | ||
import traceback | ||
from collections import defaultdict | ||
|
@@ -38,6 +39,13 @@ | |
v{version} | ||
""" | ||
|
||
logger = logging.getLogger(__name__) | ||
logger.setLevel(logging.ERROR) | ||
handler = logging.StreamHandler(sys.stderr) | ||
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is this not formatted by There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. When I added this I had issues with the hook not being called unless this formatting was explicitly on the file, it was not using There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ok, I recalled why I did this. Since it was not using the config from |
||
handler.setFormatter(formatter) | ||
logger.addHandler(handler) | ||
|
||
|
||
@click.group(context_settings=CONTEXT_SETTINGS, name="Kedro") | ||
@click.version_option(version, "--version", "-V", help="Show version and exit") | ||
|
@@ -154,6 +162,10 @@ def main( | |
self._cli_hook_manager.hook.before_command_run( | ||
project_metadata=self._metadata, command_args=args | ||
) | ||
|
||
hook_called = False | ||
exit_code = 0 | ||
|
||
try: | ||
super().main( | ||
args=args, | ||
|
@@ -169,6 +181,8 @@ def main( | |
self._cli_hook_manager.hook.after_command_run( | ||
project_metadata=self._metadata, command_args=args, exit_code=exc.code | ||
) | ||
hook_called = True | ||
|
||
# When CLI is run outside of a project, project_groups are not registered | ||
catch_exception = "click.exceptions.UsageError: No such command" | ||
# click convert exception handles to error message | ||
|
@@ -199,6 +213,19 @@ def main( | |
click.echo(message) | ||
click.echo(hint) | ||
sys.exit(exc.code) | ||
except Exception as error: | ||
logger.error(f"An error has occurred: {error}") | ||
exit_code = 1 | ||
self._cli_hook_manager.hook.after_command_run( | ||
project_metadata=self._metadata, command_args=args, exit_code=1 | ||
) | ||
ankatiyar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
hook_called = True | ||
finally: | ||
if not hook_called: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Thank you for the PR, @lrcouto! Could you please explain how this is possible? It looks like There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I guess that's in case of no exception There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes, this finally block is there to solve that issue where the hook was called twice when there was not an exception. |
||
self._cli_hook_manager.hook.after_command_run( | ||
project_metadata=self._metadata, command_args=args, exit_code=0 | ||
) | ||
sys.exit(exit_code) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is this #4026 is trying to change https://stackoverflow.com/questions/60780051/python-click-command-exit-flow This issue document the previous investigation done by @antonymilne and explains more in depth. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I've used it here as a way to ensure that it exits with the appropriate error code, because it was exiting with a 0 even when an error happened. It's not necessary to exit at this point, as long as when it exits, it's with the correct code. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What I did for now moving the |
||
|
||
@property | ||
def global_groups(self) -> Sequence[click.MultiCommand]: | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will hide
WARNING
level logs as I understand, what's the reasoning behind this?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My initial idea was that, since this would happen instead of the run stopping for an exception, it should appear only when an error occurs. But yeah it makes sense, we can lower it to a warning level.