You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
(NOTE: This is a work in progress that we will continue to update).
This issue has been created to provide additional information on how to resolve dependency issues and to collect these dependency issues together.
When installing or upgrading a package, you may see the error:
[NuGet] One or more unresolved package dependency constraints detected in the Chocolatey lib folder. All dependency constraints must be resolved to add or update packages. If these packages are being updated this message may be ignored, if not the following error(s) may be blocking the current package operation: 'PACKAGE 3.11.4 constraint: PACKAGE (= 3.11.4)'
Unable to resolve dependency 'PACKAGE'. Source(s) used: 'SOURCE'.
(Note PACKAGE and SOURCE can be any package or source and are being used as examples).
There are a few common scenarios we have seen that can lead to this (in no particular order):
You have a meta-package (emacs for example) that depends on another package (emacs.install). The other package (emacs.install) has been uninstalled by some means. This would break the dependency for the meta-package (emacs).
(NOTE: The above list is a work in progress that we will continue to add to).
Please do not raise an issue on this until you have gone through the options above and the Chocolatey Team requests you to. If you do raise an issue before doing the above, it is highly likely it will be closed.
pauby
changed the title
When installing or upgrading packages with dependencies, the error 'Unable to resolve dependency' is given
When installing or upgrading packages with dependencies, the error 'Unable to resolve dependency' is encountered
Aug 7, 2024
I ran into a similar issue where Chocolatey happily did an upgrade that triggered a dependency resolution error for later operations. Specifically, when installing a new package that had a strict dependency version requirement, it properly installed the correct, older version of it's dependency and both packages worked as expected. However, as the dependency was not the latest version, it shows up as outdated and the choco upgrade command will happily update it to the latest release. The problem is that the upgrade operation does not attempt to detect that this will lead to a broken dependency tree and upgrades the package which the original package depends on. The install completed successfully and the chocolatey database now shows the new version, but now any operations, even for unrelated packages fail due to the broken dependency relationship.
Here is the specific case I hit. I installed ganttproject, a Java app which depends on openjdk, specifically any version in the 0.11.x range. Both packages installed correctly initially and it had selected 11.0.2.01 version of openjdk as the latest available to satisfy the dependencies for gantproject3.1.3100. However, running choco outdated, it reported that openjdk was outdated as 22.0.2 is currently available. The real problem, however, is that no warnings or errors were thrown when running choco upgrade openjdk. The package was happily updated and ganttproject is now broken. It's not so much that the software might be broken, but that the Chocolatey dependency relationships are now broken and any operations including installing or upgrading unrelated packages will now fail with something similar to following error:
powershell-core - Unable to resolve dependency 'openjdk': Unable to resolve dependencies. 'openjdk 22.0.2' is not compatible with 'ganttproject 3.1.3100 constraint: openjdk (>= 11.0.0 && < 12.0.0)'.
Ideally, an error should have been produced by the upgrade operation and the upgrade for openjdk should have been skipped (while not blocking other unrelated upgrades being requested in the same command). It should not be possible to execute an operation like this that will break Chocolatey. Another alternative would just be for broken dependencies to not block unrelated packages when dependencies are broken, but the preferable solution is to prevent the situation to begin with.
In order for me to continue using Chocolatey, I had to remove ganttproject so I could resume my normal operations.
(NOTE: This is a work in progress that we will continue to update).
This issue has been created to provide additional information on how to resolve dependency issues and to collect these dependency issues together.
When installing or upgrading a package, you may see the error:
(Note
PACKAGE
andSOURCE
can be any package or source and are being used as examples).There are a few common scenarios we have seen that can lead to this (in no particular order):
emacs
for example) that depends on another package (emacs.install
). The other package (emacs.install
) has been uninstalled by some means. This would break the dependency for the meta-package (emacs
).(NOTE: The above list is a work in progress that we will continue to add to).
There are a couple of options available:
Please do not raise an issue on this until you have gone through the options above and the Chocolatey Team requests you to. If you do raise an issue before doing the above, it is highly likely it will be closed.
Related Issues
'vcredist140 14.40.33810' is not compatible with 'missionplanner 1.3.81 constraint: vcredist140 (>= 14.30.30704)'
does not seem logical #3495The text was updated successfully, but these errors were encountered: