-
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-277] [Feature] Improve mismatching package errors #4775
Comments
Hi @joellabes, I think this is a great improvement and would avoid my confusion in the future. I am not sure option 3 is necessary from my end. Option 2 is clear, concise and provides all the information I need to resolve. |
@joellabes this seems like a reasonable and logical request! Listing out the specific packages with the versions (or version ranges) would definitely be helpful! The error itself is being triggered here: Lines 377 to 385 in 0fce636
Right now we don't have access to the name of the package so we would need find a way for that to get passed along with the version. My only hesitation with option 2 is causing confusion if there is an update available but that update does not actually resolve this problem. Sometimes the solution may be to downgrade a package to resolve mismatching package errors. The same goes for option 3. The solution may be to downgrade package 3 and 4 and then there will be no conflict with package 2. Please correct me if this is not the case! Perhaps just a note that an update is available for the package but not instructing the specific version to upgrade to would be enough information? |
Agreed that option 2 could cause confusion - option 3 does address the option of saying "you might have to downgrade package 4" - the two bulleted items (remove package 2 or downgrade package 4) are alternatives as opposed to a checklist. My gut feeling is that although we could knock off option 3 in the future, it would be an excessive amount of work for the incremental benefit. If we did option 2 and there were no upgrades available, we'd still be listing out all the selected packages, which means they can see which one is causing trouble.
If we're going to say an upgrade version available, I think that we might as well list which the latest version is to make the default path easier. |
i'm wondering how helpful option 2 is without information about the version upgrade....would surfacing the text in the new version's Release Notes be on the table? |
+1 dbt Cloud user - are using a package that contains a package, and the error surfaced was for the package version within the other package, which was confusing to parse out. |
+1 dbt Cloud user - determining compatibility between package and core versions can feel more difficult than it needs to be for this user |
@fivetran-jamie we don't have the release notes information on the hub at the moment, so that would be a prerequisite. With that said, I don't think we'd want to drop potentially-very-long release notes into the console output anyway. |
the great @jtcohen6 spun up a working prototype over in #6902 for this packages.yml: packages:
- package: dbt-labs/dbt_utils
version: 1.0.0
# requires dbt-utils between 0.8.0 and 0.9.0
- package: dbt-labs/codegen
version: 0.6.0 🎩 Current behavior
New behavior
|
+1 for this, just ran into it and was about to raise an issue 😄 thank you for addressing it |
This issue has been marked as Stale because it has been open for 180 days with no activity. If you would like the issue to remain open, please comment on the issue or else it will be closed in 7 days. |
Although we are closing this issue as stale, it's not gone forever. Issues can be reopened if there is renewed community interest. Just add a comment to notify the maintainers. |
Return to meeeee Just saw another discussion in Slack, and I don't have any idea how it could be happening the way they're describing so I wish dbt would have listed out the offending packages
https://getdbt.slack.com/archives/CBSQTAPLG/p1718900461904149 |
+1 as customer is looking for a way for dbt deps to tell which packages have their version dependency on dbt_utils that needs to be updated rather than going through every other dependency manually:
|
Is there an existing feature request for this?
Describe the Feature
An extremely common failure point in the Community Slack is "I'm trying to install a new package (or update a package), and am hitting version errors". Example:
NB: Everywhere I say "utils" in this issue, I mean "the package we're trying to install but have conflicts"
Option 1. Minimum viable improvement:
It would be much easier for people to debug if we listed the packages and their requested utils versions:
By looking at that, you can see that packages 2 and 3 are in conflict with package 4. Displaying this information in the output would go a loooong way to clarifying + contextualising why there's so many version numbers being listed.
Option 2. Extra for experts
Combine this with the upgrades available notifications in #3759 to call out possible fixes.
This is the lazy but probably almost always correct version:
Option 3. Extr-est for expert-ests
I don't think this is necessary out of the gate, but I wanted to call out the edge case that would be created by Option 2. We could actually go and validate which utils version the latest version of each requested package can support:
If package_2 is a package like audit-helper, it's actually reasonable to suggest getting rid of it for a while.
Describe alternatives you've considered
I have dreams of some sort of package shopping cart on the Hub where you list all the packages you have/want and your target dbt version, and it builds your packages.yml file for you. We could delegate this to the Hub site instead
Who will this benefit?
Are you interested in contributing this feature?
I think I could do option 1, would need some help on the others
Anything else?
No response
The text was updated successfully, but these errors were encountered: