-
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
[CT-1763] [Feature] Configurable behavior for print
#6543
Comments
print
print
Does this overlap with #6481, our message-only "FYI" event type? |
@peterallenwebb Hmm - maybe? The "printed" output of As outlined in the issue above, we may want all current instances of Python |
Talked about this live, the path forward would be
Will create new implementation ticket for it. |
Let's open as a new issue. We believe Targeting the two important remaining pieces:
So we need new behavior for the text-formatted stdout logger, to include timestamp/formatting by default, but not for:
Acceptance criteria:
|
Closing in favor of implementation ticket: |
In addition to the simple default behavior (Python's
print
function → stdout), which is fine for CLI use, we should support programmatic invocations, where printing tostdout
doesn't make sense. We could do this with a "print" event/log instead, probably with a special level.If we do go the logging route, we'd need to respect these flags:
--quiet
: suppress all log messages from stdout, except those with the special "print" level--no-print
: suppress all "print"-level log messages from stdoutImplementation options:
print
, we add conditional logic that eitherprint
s, or fires an event specific to that call site. (E.g.CustomMacroPrint
,ListResult
)PrintMessage
. We swap out 1:1 all direct calls toprint
with a new custom "print" method, defined either inclients.system
or theevents
module, and define the conditional logic (to print or not to print) one time in that method.Current call sites
There are three primary places in the codebase where we call
print
today, plus a few miscellaneous others.1.
print
dbt-Jinja context membera.k.a. the "codegen" use case
dbt-core/core/dbt/context/base.py
Lines 640 to 656 in 94d6d19
This should optionally fire an event, instead of just calling
print
.2.
dbt list
We definitely need a way to make the results of
list
available programmatically. But that might already be the case—we already bothprint
the results, and return them as the task result:dbt-core/core/dbt/task/list.py
Lines 150 to 154 in 94d6d19
So when the new CLI/API supports
list
(#5549), we should expect thelist
results being returned like:In the spirit of completeness, I think it makes sense to opt for sending a structured logging event for each
list
result, instead of printing it to stdout (default). It should be possible to suppress those in-lieu-of-printing events via the--no-print
flag described above.3.
dbt debug
This is pretty clearly a case where we want actual events/logs, and not just text
print
ed to stdout.Already open in #5353
Proposed resolution in #6541
4. Misc other spots
In
dbt init
— this is probably just an oversight, I believe there should be an event manager available:dbt-core/core/dbt/task/init.py
Line 284 in 94d6d19
In our functional testing framework — nbd
The text was updated successfully, but these errors were encountered: