-
Notifications
You must be signed in to change notification settings - Fork 1.7k
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
Logging: restore previous (small) behaviors #4341
Conversation
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.
requesting changes just so I can have a question answered and some comments. Otherwise this seems like an ok fix to me.
@@ -56,6 +58,7 @@ def __init__(self, args, config): | |||
def pre_init_hook(cls, args): | |||
"""A hook called before the task is initialized.""" | |||
log_manager.stderr_console() | |||
event_logger.STDOUT_LOG.level = logging.WARN |
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.
I'm definitely not a fan of reaching in and modifying STDOUT_LOG
like this, but I'm fine with it as a quick fix. Can we just leave a comment here stating that this is a hack and describe what the right way is?
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.
actually, are there info-level logs we're trying to filter out? I'm not sure why we're setting it to warn here.
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.
Yes - the list
task wants to filter out all INFO-level logs, so that only its printed output appears in the command line:
Lines 517 to 521 in f72b603
# this is used by `dbt ls` to allow piping stdout to jq, etc | |
def stderr_console(self): | |
"""Output to stderr at WARNING level instead of stdout""" | |
self._output_handler.stream = self.stderr | |
self._output_handler.level = logbook.WARNING |
The way we've done this in the past is by setting the stdout logger level to WARN
instead. It will still include warnings + errors in stdout.
core/dbt/task/base.py
Outdated
if args.log_format == 'json': | ||
log_manager.format_json() | ||
event_logger.format_json = True | ||
else: | ||
log_manager.format_text() |
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.
it seems like these blocks won't need to exist once we refactor the early logs right? can we comment to that effect so the refactor goes smoother?
@@ -2365,7 +2365,7 @@ def message(self) -> str: | |||
|
|||
|
|||
@dataclass | |||
class SendingEvent(DebugLevel, Cli): | |||
class SendingEvent(DebugLevel, Cli, File): |
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.
awesome! glad this works now 💪
core/dbt/events/functions.py
Outdated
@@ -48,7 +48,7 @@ def setup_event_logger(log_path): | |||
this.format_color = True if flags.USE_COLORS else False | |||
# TODO this default should live somewhere better | |||
log_dest = os.path.join(log_path, 'dbt.log') | |||
level = logging.DEBUG if flags.DEBUG else logging.INFO | |||
level = logging.DEBUG if flags.DEBUG else this.STDOUT_LOG.level |
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.
If we set it to WARN
below what's the path for setting it back to INFO
for runs without the --debug
flag? I don't want those runs to be stuck on warn instead of info.
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.
Yeah, totally fair question. This would be an issue any place where we invoke dbt multiple times within the same CLI instantiation, i.e. in integration tests or in the dbt Server.
We could set the log level to INFO
within the base (non-list
) task pre_init_hook
? Perhaps even include the debug
logic there too?
Ultimately, we'll want to refactor this so that the logger is being instantiated/configured as soon as flags are available, and before all of this other stuff is happening
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.
ok so now that I think about it, wouldn't it get reset to info when we call setup_event_logger
if we DON'T change this line? do we need it to stay warn longer than that?
If so maybe we could change the signature of this function:
def setup_event_logger(log_path, level_override=None):
...
level = level_override or (logging.DEBUG if flags.DEBUG else logging.INFO)
...
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.
I'm just trying to keep rogue mutations to a minimum so we can refactor this fairly easily in the future.
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.
@nathaniel-may Just gave this approach a try, I do think it's slightly better
This reverts commit 5508fa2.
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.
Thanks for all the comments! I think this level_override looks pretty good. Happy for it to stick around for commands like list if we need it.
* Log formatting from flags earlier * WARN-level stdout for list task * Readd tracking events to File * PR feedback, annotate hacks * Revert "PR feedback, annotate hacks" This reverts commit 5508fa2. * This is maybe better * Annotate main.py * One more comment in base.py * Update changelog automatic commit by git-black, original commits: 8d2351d
From #4260:
For both of these, I took the goal as providing exact parity with legacy logging behavior, with as small a lift as possible. That means, if we hook into legacy logger methods from
main.py
by way of task methods in a few subtle ways (pre_init_hook
,set_log_format
), we should set the same configs for the new event logger. If we hate this and want to keep config centralized, we can take up a more serious refactor.This was just a matter of adding
File
back to tracking events. I'm able todbt clean
, withlogs/
as a clean target, without dbt throwing up an error that it can't find the file it expects to write to. If I had to guess, the switch fromWatchedFileHandler
toRotatingFileHandler
may have fixed this?Checklist
CHANGELOG.md
and added information about my change