From time to time, a previously approved Chocolatey Package needs to be deprecated. This could be for a number of reasons:
- It was created in error.
- It has been superseded by another package.
- It is an older package that no longer follows the Package Guidelines.
- It's package id has been changed to something that better fits with the package naming guidelines.
All versions of this package could simply be unlisted from chocolatey.org, meaning that they could no longer be installed, however, this solution is not ideal. Any user who previously installed this package, and added it as part of an installation script, would get an error the next time that they tried to install it, and this is far from ideal.
When a package needs to be deprecated, it needs to be handled in such a way that existing users will continue to be able to use the old package id, but take advantage of the replacement package, if there is one.
When deprecating a Chocolatey Package, the following steps should be followed:
- Create a new version of the deprecated Chocolatey Package.
- Prepend [Deprecated] to the title of the package.
- Update the package description: Why is the package being deprecated?
- Add a dependency on the other package (if the package is being superseded).
- Remove all files except the
.nuspec
from the Chocolatey Package. - Remove the iconUrl.
- Unlist all versions from the package gallery.
By following this process, any existing users who try to update the old package will automatically get the new package, as it will be installed as a dependency