Tool to automatically update dependencies one by one in chronological order. Most dependencies are compatible with other packages from a similar time or pastime. This tool helps to find the latest compatible version of the dependencies and update them.
This tool is intended to simulate the typical updating workflow as it was done regularly.
Run with npx to find the next recommended dependency to update:
npx dependency-time-machine --update --install
or install globally:
# npm
npm install -g dependency-time-machine
# yarn
yarn global add dependency-time-machine
# pnpm
pnpm add -g dependency-time-machine
Basic usage to find the next recommended dependency to update:
npx dependency-time-machine --update --install
Automatically update dependencies one-by-one running tests after each update. Tests are run with the npm test
command:
npx dependency-time-machine --update --install --auto
You can specify custom install and test commands:
npx dependency-time-machine --update --install --auto --install-script "yarn install" --test-script "yarn test"
Get a timeline of the updates in JSON format:
npx dependency-time-machine --timeline
To exclude some dependencies from the update, use the --exclude
option:
npx dependency-time-machine --update --install --exclude react,react-dom
or use the --exclude-file
option to exclude dependencies from the file:
npx dependency-time-machine --update --install --exclude-file exclude.txt
The tool reads the package.json
file and finds all dependencies. Then it resolves all the versions from the registry, sorts them by date and
finds the latest version of the dependency before finding another. Searching in version groups allows one to spot
incompatibility between dependencies. Built-in cache and auto mode allow to update dependencies faster.
Usage: dependency-time-machine [options]
Tool to automatically update dependencies one-by-one in the time order
Options:
-p, --packageFile <file> Path to package.json file (default: "package.json")
-u, --update Update package.json file with new versions
-is, --install-script <command> Install with script (default: "npm install")
-ts, --test-script <command> Test command (default: "npm test")
-i, --install Install with script
-t, --timeline Print timeline
-a, --auto Run in auto mode
-c, --cache Cache resolved dependencies
-ans, --allow-non-semver Allow non-semver versions (compare with dates then, experimental)
-cf, --cache-file <file> Cache file (default: "./.dependency-time-machine-cache.json")
-e, --exclude <dependency> Exclude dependency from update, separated by comma
-r, --registry-url <url> Registry url (default: "https://registry.npmjs.org")
-x, --exclude-file <file> Exclude dependencies from file, one per line (default: "")
-shmn, --stop-if-higher-major-number Stop if higher major number
-shmnv, --stop-if-higher-minor-number Stop if higher minor or major number
-pi, --print-info Print info about the packages
-h, --help display help for command
MIT