It is rather tedious when trying to get dependencies of local Meteor packages up-to-date.
Currently, they are specified in package.js
like and I have to check for latest version of each dependency used and update manually.
E.g.
api.use([
'alanning:[email protected]',
'aldeed:[email protected]',
'aldeed:[email protected]',
'iron:[email protected]',
'useraccounts:[email protected]'
]);
Can meteor-tool
do this or is there a better way to update packages' dependencies, especially useful when you have multiple local packages in a project.
If you want to update to a newer version of a package after installing it, use meteor update . You can run meteor update without any arguments to update all packages and Meteor itself to their latest versions, or pass a specific package to update just that one, for example meteor update ostrio:flow-router-extra .
A function that takes in the package control 'api' object, which keeps track of dependencies and exports. Meteor packages can include NPM packages and Cordova plugins by using Npm. depends and Cordova. depends in the package. js file.
There is no real value in bumping the dependency version in package.js
, as I mentioned in my comment. It could lead to the counter effect and break version resolution.
The expectation is to mention the minimal compatible version (with the same major version number). When your local package is updated, its .versions
file is updated as well, which may hint the build system which version of the dependency is the preferred one to use (the one that your package was built with).
The closest thing that I can give as an answer is this quote of David Greenspan* taken from the Meteor forums:
We have made some small improvements to meteor update over time, but we don't have a way for a package to ask for one of its dependencies to be upgraded more aggressively. meteor update with no arguments will take patch updates to indirect dependencies, but not minor versions. I recently improved the messages that meteor update prints, so in the next release, it should tell you if an indirect dependency is not at the latest version after it runs (rather than printing the very wrong message "All packages are at their latest compatible versions").
If you bump the minor version of a package, I think the expectation at the moment is that you will republish the packages that depend on it if you want their users to get the new version (after running the tests to make sure all is well).
So, when the author of a package you depend on releases a new:
I would not count on things behaving as they do right now, as the packaging system undergoes pretty significant rework in order to be more compatible with NPM (including the ability to directly require NPM packages from Meteor apps and packages), expected to be included in v1.3.
* (actually, Sacha Greif posted the quote).
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With