-
Notifications
You must be signed in to change notification settings - Fork 8
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
Add lint option to only output models with score under some threshold #71
Comments
Hey @lhz, thanks for opening this issue! I agree, this is something that needs to be added. We are planning to work on it soon, but you are of course welcome to contribute as well. I think the most important features to include are:
These two options then can be combined to get: all models with all rules, all models showing only their failing rules, failing models with their failing rules and failing models with all their passing rules. (last option will probably never be used though 😁 ) |
As a workaround, you could also achieve this by using For a threshold that's e.g. dbt-score lint --format json | jq -r '.models | to_entries[] | select(.value.score < 7.7) | .key or to get all failing models dbt-score lint --format json | jq -r '.models | to_entries[] | select(.value.pass|not) | .key |
Hi there :) With regards to "Only show failing models". I think this could be achieved with something along the lines of: ...
if (
self.scores[model].value < self._scorer._config.fail_any_model_under
or not self._scorer._config.only_show_failing
):
self._formatter.model_evaluated(
model, self.results[model], self.scores[model]
)
... I forked the repo and already tried that out quicky (added the |
Hi @thomend, I'm very glad you enjoyed the talk! I believe it might make more sense to implement this logic directly within I also think "showing only failing models", and within a model "showing only failing rules" could be implemented together. And I'll argue it should be the default, with a CLI option to "show all". Does that make sense to you? |
Hi @matthieucan thank you for coming back to me. Yes indeed, this makes sense. I have created a draft PR covering this here: #77 Let me know if you agree on the overall approach and I will mark it as "Ready for Review". I followed your outline and only added a Is that what you had in mind? |
Amazing @thomend, this is indeed what I meant. Thank you for your PR 💪 |
…dableFormatter (PicnicSupermarket#77) Fixes PicnicSupermarket#71 It changes the default behavior of the HumanReadableFormatter: When running `dbt-score lint` it will now only show failing models and/or rules which were violated. To have all output printed (exactly the way it was before this PR) the user has now to pass the `--show_all` flag to `dbt-score lint`. It also considers the `fail_any_model_under` option. Furthermore, I had to adjust some of tests since the default behavior of the HumanReadableFormatter is now changed - let me know if I would need to expand this. The docs also reflect this change by slightly tweaking the first example in `index.md` In this current form, both rule violations and failing models are filtered through the same argument. This is based on @matthieucan. 's comment on PicnicSupermarket#71 (comment) --------- Co-authored-by: Jochem van Dooren <[email protected]> Co-authored-by: Matthieu Caneill <[email protected]>
We are mostly interested in knowing which models are not up to standard, and that can be hard to glimpse when the project has many models and most of them already have a gold badge.
It would be very useful to have an option for the
lint
command that will cause it to only output models whose score is less than the first threshold (or perhaps more flexible, a custom threshold given as argument to the option.)Related to this, it would also be useful to output only the rules that were not satisfied, but I'm unsure if that should be a separate option or a direct result of the one suggested.
The text was updated successfully, but these errors were encountered: