jbzoo / composer-diff
See what has changed after a composer update.
Installs: 785 855
Dependents: 2
Suggesters: 0
Security: 0
Stars: 51
Watchers: 2
Forks: 5
Open Issues: 3
Requires
- php: ^8.1
- ext-filter: *
- ext-json: *
- composer/semver: >=1.0
- jbzoo/cli: ^7.1.1
- jbzoo/data: ^7.1
- jbzoo/markdown: ^7.0
- symfony/console: >=6.4
- symfony/process: >=6.4
Requires (Dev)
- composer/composer: >=2.0
- jbzoo/toolbox-dev: ^7.1
- roave/security-advisories: dev-master
README
- Why?
- Installation
- Usage
- Help Description
- Output Examples
- Roadmap
- Unit tests and check code style
- License
- See Also
Why?
See what packages have been changed after you run composer update
by comparing composer.lock
to the git show HEAD:composer.lock
.
Installation
composer require jbzoo/composer-diff # For specific project composer global require jbzoo/composer-diff # As global tool # OR use phar file. wget https://github.com/JBZoo/Composer-Diff/releases/latest/download/composer-diff.phar
Usage
composer update # if it's installed via composer php ./vendor/bin/composer-diff # OR (if installed globally) composer-diff # OR (if you downloaded phar file) php composer-diff.phar
Help Description
./vendor/bin/composer-diff --help
Description:
Show difference between two versions of composer.lock files
Usage:
diff [options]
Options:
--source=SOURCE The file, git ref, or git ref with filename to compare FROM [default: "HEAD:composer.lock"]
--target=TARGET The file, git ref, or git ref with filename to compare TO [default: "./composer.lock"]
--env=ENV Show only selected environment. Available options: both, require, require-dev [default: "both"]
--output=OUTPUT Output format. Available options: console, markdown, json [default: "console"]
--no-links Hide all links in tables
--strict Return exit code if you have any difference
--no-progress Disable progress bar animation for logs. It will be used only for text output format.
--mute-errors Mute any sort of errors. So exit code will be always "0" (if it's possible).
It has major priority then --non-zero-on-error. It's on your own risk!
--stdout-only For any errors messages application will use StdOut instead of StdErr. It's on your own risk!
--non-zero-on-error None-zero exit code on any StdErr message.
--timestamp Show timestamp at the beginning of each message.It will be used only for text output format.
--profile Display timing and memory usage information.
--output-mode=OUTPUT-MODE Output format. Available options:
text - Default text output format, userfriendly and easy to read.
cron - Shortcut for crontab. It's basically focused on human-readable logs output.
It's combination of --timestamp --profile --stdout-only --no-progress -vv.
logstash - Logstash output format, for integration with ELK stack.
[default: "text"]
--cron Alias for --output-mode=cron. Deprecated!
-h, --help Display help for the given command. When no command is given display help for the diff command
-q, --quiet Do not output any message
-V, --version Display this application version
--ansi|--no-ansi Force (or disable --no-ansi) ANSI output
-n, --no-interaction Do not ask any interactive question
-v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
Output Examples
Default view (--output=console)
PHP Production Dependencies (require)
+-------------------+------------+--------------------+---------------------+---------------------------------------------------------------+
| Package | Action | Old Version | New Version | Details |
+-------------------+------------+--------------------+---------------------+---------------------------------------------------------------+
| vendor/downgraded | Downgraded | 2.0.0 | 1.0.0 | https://gitlab.com/vendor/downgraded/compare/2.0.0...1.0.0 |
| vendor/new | New | - | 1.0.0 | |
| vendor/no-tag | Changed | dev-master@bbc0fba | dev-master@f2f9280 | https://gitlab.com/vendor/package-1/compare/bbc0fba...f2f9280 |
| vendor/no-tag-new | New | - | dev-develop@a999014 | |
| vendor/removed | Removed | 1.0.0 | - | |
| vendor/upgraded | Upgraded | 1.0.0 | 2.0.0 | https://gitlab.com/vendor/upgraded/compare/1.0.0...2.0.0 |
+-------------------+------------+--------------------+---------------------+---------------------------------------------------------------+
Also, see colored example in travis-ci
Markdown Output (--output=markdown)
Source code:
## PHP Production Dependencies (require) | Package | Action | Old Version | New Version | | |:-----------------------------------------------------------|:-----------|-------------------:|--------------------:|:-----------------------------------------------------------------------------| | [vendor/downgraded](https://gitlab.com/vendor/downgraded) | Downgraded | 2.0.0 | 1.0.0 | [See details](https://gitlab.com/vendor/downgraded/compare/2.0.0...1.0.0) | | [vendor/new](https://gitlab.com/vendor/new) | New | - | 1.0.0 | | | [vendor/no-tag](https://gitlab.com/vendor/package-1) | Changed | dev-master@bbc0fba | dev-master@f2f9280 | [See details](https://gitlab.com/vendor/package-1/compare/bbc0fba...f2f9280) | | [vendor/no-tag-new](https://gitlab.com/vendor-1/package-1) | New | - | dev-develop@a999014 | | | [vendor/removed](https://gitlab.com/vendor/removed) | Removed | 1.0.0 | - | | | [vendor/upgraded](https://gitlab.com/vendor/upgraded) | Upgraded | 1.0.0 | 2.0.0 | [See details](https://gitlab.com/vendor/upgraded/compare/1.0.0...2.0.0) |
Rendered in your readme or PR/MR description:
JSON Output (--output=json)
{ "require": { "vendor\/downgraded": { "name": "vendor\/downgraded", "url": "https:\/\/gitlab.com\/vendor\/downgraded", "version_from": "2.0.0", "version_to": "1.0.0", "mode": "Downgraded", "compare": "https:\/\/gitlab.com\/vendor\/downgraded\/compare\/2.0.0...1.0.0" }, "vendor\/new": { "name": "vendor\/new", "url": "https:\/\/gitlab.com\/vendor\/new", "version_from": null, "version_to": "1.0.0", "mode": "New", "compare": null }, "vendor\/no-tag": { "name": "vendor\/no-tag", "url": "https:\/\/gitlab.com\/vendor\/package-1", "version_from": "dev-master@bbc0fba", "version_to": "dev-master@f2f9280", "mode": "Changed", "compare": "https:\/\/gitlab.com\/vendor\/package-1\/compare\/bbc0fba...f2f9280" }, "vendor\/no-tag-new": { "name": "vendor\/no-tag-new", "url": "https:\/\/gitlab.com\/vendor-1\/package-1", "version_from": null, "version_to": "dev-develop@a999014", "mode": "New", "compare": null }, "vendor\/removed": { "name": "vendor\/removed", "url": "https:\/\/gitlab.com\/vendor\/removed", "version_from": "1.0.0", "version_to": null, "mode": "Removed", "compare": null }, "vendor\/upgraded": { "name": "vendor\/upgraded", "url": "https:\/\/gitlab.com\/vendor\/upgraded", "version_from": "1.0.0", "version_to": "2.0.0", "mode": "Upgraded", "compare": "https:\/\/gitlab.com\/vendor\/upgraded\/compare\/1.0.0...2.0.0" } } }
Roadmap
- Supporting Drupal repos. For example.
- Add action in the composer via API like
composer lock-diff
. - Fixes the same issue with complex/custom name of tag.
- Auto-detecting alias name of branch.
- No warp links for Markdown format.
- (?) Support MS Windows...
Unit tests and check code style
make build make test-all
License
MIT
See Also
- CI-Report-Converter - Converting different error reports for deep compatibility with popular CI systems.
- Composer-Graph - Dependency graph visualization of composer.json based on mermaid-js.
- Mermaid-PHP - Generate diagrams and flowcharts with the help of the mermaid script language.
- Utils - Collection of useful PHP functions, mini-classes, and snippets for every day.
- Image - Package provides object-oriented way to manipulate with images as simple as possible.
- Data - Extended implementation of ArrayObject. Use files as config/array.
- Retry - Tiny PHP library providing retry/backoff functionality with multiple backoff strategies and jitter support.
- SimpleTypes - Converting any values and measures - money, weight, exchange rates, length, ...
Special thanks to the project davidrjonas/composer-lock-diff which inspired me to make a great utility :)