From 9e956bd4c6d7a275ce1d51f7ddf51d98d70f425c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 13:27:53 +0100 Subject: [PATCH 01/18] qa: raise minimum composer requirement to for unit tests to 2.3.0-rc1+ MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This also re-enables tests for composer v1 which were dropped when migrating to PHP 8.1 Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- composer.json | 7 +- composer.lock | 378 ++++++++++++++++++++++++++++++++------------------ 2 files changed, 250 insertions(+), 135 deletions(-) diff --git a/composer.json b/composer.json index 3c5f236..4716646 100644 --- a/composer.json +++ b/composer.json @@ -19,7 +19,10 @@ "forum": "https://discourse.laminas.dev" }, "config": { - "sort-packages": true + "sort-packages": true, + "allow-plugins": { + "dealerdirect/phpcodesniffer-composer-installer": true + } }, "extra": { "class": "Laminas\\ComponentInstaller\\ComponentInstaller" @@ -29,7 +32,7 @@ "composer-plugin-api": "^1.0 || ^2.0" }, "require-dev": { - "composer/composer": "^2.1.9", + "composer/composer": "^1.10.25 || ^2.3.0-rc1", "laminas/laminas-coding-standard": "~2.3.0", "malukenho/docheader": "^0.1.6", "mikey179/vfsstream": "^1.6.10", diff --git a/composer.lock b/composer.lock index f7ffe51..75d6c73 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "b2f83b670b03f85921ac4b8e6b22b8df", + "content-hash": "ed44678195ec5cec9bdd2bcebbecc3bc", "packages": [], "packages-dev": [ { @@ -251,38 +251,45 @@ }, { "name": "composer/composer", - "version": "2.1.14", + "version": "2.3.0-RC1", "source": { "type": "git", "url": "https://github.com/composer/composer.git", - "reference": "cd28fc05b0c9d3beaf58b57018725c4dc15a6446" + "reference": "3b150d0ef6454694d074cac2807237894dfd6217" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/composer/zipball/cd28fc05b0c9d3beaf58b57018725c4dc15a6446", - "reference": "cd28fc05b0c9d3beaf58b57018725c4dc15a6446", + "url": "https://api.github.com/repos/composer/composer/zipball/3b150d0ef6454694d074cac2807237894dfd6217", + "reference": "3b150d0ef6454694d074cac2807237894dfd6217", "shasum": "" }, "require": { "composer/ca-bundle": "^1.0", "composer/metadata-minifier": "^1.0", + "composer/pcre": "^2 || ^3", "composer/semver": "^3.0", "composer/spdx-licenses": "^1.2", - "composer/xdebug-handler": "^2.0", + "composer/xdebug-handler": "^2.0.2 || ^3.0.3", "justinrainbow/json-schema": "^5.2.11", - "php": "^5.3.2 || ^7.0 || ^8.0", - "psr/log": "^1.0 || ^2.0", - "react/promise": "^1.2 || ^2.7", + "php": "^7.2.5 || ^8.0", + "psr/log": "^1.0 || ^2.0 || ^3.0", + "react/promise": "^2.8", "seld/jsonlint": "^1.4", - "seld/phar-utils": "^1.0", - "symfony/console": "^2.8.52 || ^3.4.35 || ^4.4 || ^5.0", - "symfony/filesystem": "^2.8.52 || ^3.4.35 || ^4.4 || ^5.0 || ^6.0", - "symfony/finder": "^2.8.52 || ^3.4.35 || ^4.4 || ^5.0 || ^6.0", - "symfony/process": "^2.8.52 || ^3.4.35 || ^4.4 || ^5.0 || ^6.0" + "seld/phar-utils": "^1.2", + "symfony/console": "^5.4.1 || ^6.0", + "symfony/filesystem": "^5.4 || ^6.0", + "symfony/finder": "^5.4 || ^6.0", + "symfony/polyfill-php73": "^1.24", + "symfony/polyfill-php80": "^1.24", + "symfony/process": "^5.4 || ^6.0" }, "require-dev": { - "phpspec/prophecy": "^1.10", - "symfony/phpunit-bridge": "^4.2 || ^5.0 || ^6.0" + "phpstan/phpstan": "^1.4.1", + "phpstan/phpstan-deprecation-rules": "^1", + "phpstan/phpstan-phpunit": "^1.0", + "phpstan/phpstan-strict-rules": "^1", + "phpstan/phpstan-symfony": "^1.1", + "symfony/phpunit-bridge": "^6.0" }, "suggest": { "ext-openssl": "Enabling the openssl extension allows you to access https URLs for repositories and packages", @@ -295,7 +302,7 @@ "type": "library", "extra": { "branch-alias": { - "dev-main": "2.1-dev" + "dev-main": "2.3-dev" } }, "autoload": { @@ -329,7 +336,7 @@ "support": { "irc": "ircs://irc.libera.chat:6697/composer", "issues": "https://github.com/composer/composer/issues", - "source": "https://github.com/composer/composer/tree/2.1.14" + "source": "https://github.com/composer/composer/tree/2.3.0-RC1" }, "funding": [ { @@ -345,7 +352,7 @@ "type": "tidelift" } ], - "time": "2021-11-30T09:51:43+00:00" + "time": "2022-03-16T08:25:31+00:00" }, { "name": "composer/metadata-minifier", @@ -489,25 +496,96 @@ ], "time": "2021-09-13T08:41:34+00:00" }, + { + "name": "composer/pcre", + "version": "3.0.0", + "source": { + "type": "git", + "url": "https://github.com/composer/pcre.git", + "reference": "e300eb6c535192decd27a85bc72a9290f0d6b3bd" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/composer/pcre/zipball/e300eb6c535192decd27a85bc72a9290f0d6b3bd", + "reference": "e300eb6c535192decd27a85bc72a9290f0d6b3bd", + "shasum": "" + }, + "require": { + "php": "^7.4 || ^8.0" + }, + "require-dev": { + "phpstan/phpstan": "^1.3", + "phpstan/phpstan-strict-rules": "^1.1", + "symfony/phpunit-bridge": "^5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Composer\\Pcre\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "http://seld.be" + } + ], + "description": "PCRE wrapping library that offers type-safe preg_* replacements.", + "keywords": [ + "PCRE", + "preg", + "regex", + "regular expression" + ], + "support": { + "issues": "https://github.com/composer/pcre/issues", + "source": "https://github.com/composer/pcre/tree/3.0.0" + }, + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2022-02-25T20:21:48+00:00" + }, { "name": "composer/semver", - "version": "3.2.6", + "version": "3.3.1", "source": { "type": "git", "url": "https://github.com/composer/semver.git", - "reference": "83e511e247de329283478496f7a1e114c9517506" + "reference": "5d8e574bb0e69188786b8ef77d43341222a41a71" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/semver/zipball/83e511e247de329283478496f7a1e114c9517506", - "reference": "83e511e247de329283478496f7a1e114c9517506", + "url": "https://api.github.com/repos/composer/semver/zipball/5d8e574bb0e69188786b8ef77d43341222a41a71", + "reference": "5d8e574bb0e69188786b8ef77d43341222a41a71", "shasum": "" }, "require": { "php": "^5.3.2 || ^7.0 || ^8.0" }, "require-dev": { - "phpstan/phpstan": "^0.12.54", + "phpstan/phpstan": "^1.4", "symfony/phpunit-bridge": "^4.2 || ^5" }, "type": "library", @@ -552,7 +630,7 @@ "support": { "irc": "irc://irc.freenode.org/composer", "issues": "https://github.com/composer/semver/issues", - "source": "https://github.com/composer/semver/tree/3.2.6" + "source": "https://github.com/composer/semver/tree/3.3.1" }, "funding": [ { @@ -568,7 +646,7 @@ "type": "tidelift" } ], - "time": "2021-10-25T11:34:17+00:00" + "time": "2022-03-16T11:22:07+00:00" }, { "name": "composer/spdx-licenses", @@ -2407,32 +2485,32 @@ }, { "name": "react/promise", - "version": "v2.8.0", + "version": "v2.9.0", "source": { "type": "git", "url": "https://github.com/reactphp/promise.git", - "reference": "f3cff96a19736714524ca0dd1d4130de73dbbbc4" + "reference": "234f8fd1023c9158e2314fa9d7d0e6a83db42910" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/reactphp/promise/zipball/f3cff96a19736714524ca0dd1d4130de73dbbbc4", - "reference": "f3cff96a19736714524ca0dd1d4130de73dbbbc4", + "url": "https://api.github.com/repos/reactphp/promise/zipball/234f8fd1023c9158e2314fa9d7d0e6a83db42910", + "reference": "234f8fd1023c9158e2314fa9d7d0e6a83db42910", "shasum": "" }, "require": { "php": ">=5.4.0" }, "require-dev": { - "phpunit/phpunit": "^7.0 || ^6.5 || ^5.7 || ^4.8.36" + "phpunit/phpunit": "^9.3 || ^5.7 || ^4.8.36" }, "type": "library", "autoload": { - "psr-4": { - "React\\Promise\\": "src/" - }, "files": [ "src/functions_include.php" - ] + ], + "psr-4": { + "React\\Promise\\": "src/" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -2441,7 +2519,23 @@ "authors": [ { "name": "Jan Sorgalla", - "email": "jsorgalla@gmail.com" + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" } ], "description": "A lightweight implementation of CommonJS Promises/A for PHP", @@ -2451,9 +2545,19 @@ ], "support": { "issues": "https://github.com/reactphp/promise/issues", - "source": "https://github.com/reactphp/promise/tree/v2.8.0" + "source": "https://github.com/reactphp/promise/tree/v2.9.0" }, - "time": "2020-05-12T15:16:56+00:00" + "funding": [ + { + "url": "https://github.com/WyriHaximus", + "type": "github" + }, + { + "url": "https://github.com/clue", + "type": "github" + } + ], + "time": "2022-02-11T10:27:51+00:00" }, { "name": "sebastian/cli-parser", @@ -3484,16 +3588,16 @@ }, { "name": "seld/phar-utils", - "version": "1.1.2", + "version": "1.2.0", "source": { "type": "git", "url": "https://github.com/Seldaek/phar-utils.git", - "reference": "749042a2315705d2dfbbc59234dd9ceb22bf3ff0" + "reference": "9f3452c93ff423469c0d56450431562ca423dcee" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Seldaek/phar-utils/zipball/749042a2315705d2dfbbc59234dd9ceb22bf3ff0", - "reference": "749042a2315705d2dfbbc59234dd9ceb22bf3ff0", + "url": "https://api.github.com/repos/Seldaek/phar-utils/zipball/9f3452c93ff423469c0d56450431562ca423dcee", + "reference": "9f3452c93ff423469c0d56450431562ca423dcee", "shasum": "" }, "require": { @@ -3526,9 +3630,9 @@ ], "support": { "issues": "https://github.com/Seldaek/phar-utils/issues", - "source": "https://github.com/Seldaek/phar-utils/tree/1.1.2" + "source": "https://github.com/Seldaek/phar-utils/tree/1.2.0" }, - "time": "2021-08-19T21:01:38+00:00" + "time": "2021-12-10T11:20:11+00:00" }, { "name": "slevomat/coding-standard", @@ -3649,23 +3753,23 @@ }, { "name": "symfony/console", - "version": "v5.4.0", + "version": "v5.4.5", "source": { "type": "git", "url": "https://github.com/symfony/console.git", - "reference": "ec3661faca1d110d6c307e124b44f99ac54179e3" + "reference": "d8111acc99876953f52fe16d4c50eb60940d49ad" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/console/zipball/ec3661faca1d110d6c307e124b44f99ac54179e3", - "reference": "ec3661faca1d110d6c307e124b44f99ac54179e3", + "url": "https://api.github.com/repos/symfony/console/zipball/d8111acc99876953f52fe16d4c50eb60940d49ad", + "reference": "d8111acc99876953f52fe16d4c50eb60940d49ad", "shasum": "" }, "require": { "php": ">=7.2.5", "symfony/deprecation-contracts": "^2.1|^3", "symfony/polyfill-mbstring": "~1.0", - "symfony/polyfill-php73": "^1.8", + "symfony/polyfill-php73": "^1.9", "symfony/polyfill-php80": "^1.16", "symfony/service-contracts": "^1.1|^2|^3", "symfony/string": "^5.1|^6.0" @@ -3728,7 +3832,7 @@ "terminal" ], "support": { - "source": "https://github.com/symfony/console/tree/v5.4.0" + "source": "https://github.com/symfony/console/tree/v5.4.5" }, "funding": [ { @@ -3744,7 +3848,7 @@ "type": "tidelift" } ], - "time": "2021-11-29T15:30:56+00:00" + "time": "2022-02-24T12:45:35+00:00" }, { "name": "symfony/deprecation-contracts", @@ -3815,16 +3919,16 @@ }, { "name": "symfony/filesystem", - "version": "v5.4.0", + "version": "v5.4.6", "source": { "type": "git", "url": "https://github.com/symfony/filesystem.git", - "reference": "731f917dc31edcffec2c6a777f3698c33bea8f01" + "reference": "d53a45039974952af7f7ebc461ccdd4295e29440" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/filesystem/zipball/731f917dc31edcffec2c6a777f3698c33bea8f01", - "reference": "731f917dc31edcffec2c6a777f3698c33bea8f01", + "url": "https://api.github.com/repos/symfony/filesystem/zipball/d53a45039974952af7f7ebc461ccdd4295e29440", + "reference": "d53a45039974952af7f7ebc461ccdd4295e29440", "shasum": "" }, "require": { @@ -3859,7 +3963,7 @@ "description": "Provides basic utilities for the filesystem", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/filesystem/tree/v5.4.0" + "source": "https://github.com/symfony/filesystem/tree/v5.4.6" }, "funding": [ { @@ -3875,20 +3979,20 @@ "type": "tidelift" } ], - "time": "2021-10-28T13:39:27+00:00" + "time": "2022-03-02T12:42:23+00:00" }, { "name": "symfony/finder", - "version": "v5.4.0", + "version": "v5.4.3", "source": { "type": "git", "url": "https://github.com/symfony/finder.git", - "reference": "d2f29dac98e96a98be467627bd49c2efb1bc2590" + "reference": "231313534dded84c7ecaa79d14bc5da4ccb69b7d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/finder/zipball/d2f29dac98e96a98be467627bd49c2efb1bc2590", - "reference": "d2f29dac98e96a98be467627bd49c2efb1bc2590", + "url": "https://api.github.com/repos/symfony/finder/zipball/231313534dded84c7ecaa79d14bc5da4ccb69b7d", + "reference": "231313534dded84c7ecaa79d14bc5da4ccb69b7d", "shasum": "" }, "require": { @@ -3922,7 +4026,7 @@ "description": "Finds files and directories via an intuitive fluent interface", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/finder/tree/v5.4.0" + "source": "https://github.com/symfony/finder/tree/v5.4.3" }, "funding": [ { @@ -3938,25 +4042,28 @@ "type": "tidelift" } ], - "time": "2021-11-28T15:25:38+00:00" + "time": "2022-01-26T16:34:36+00:00" }, { "name": "symfony/polyfill-ctype", - "version": "v1.23.0", + "version": "v1.25.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-ctype.git", - "reference": "46cd95797e9df938fdd2b03693b5fca5e64b01ce" + "reference": "30885182c981ab175d4d034db0f6f469898070ab" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/46cd95797e9df938fdd2b03693b5fca5e64b01ce", - "reference": "46cd95797e9df938fdd2b03693b5fca5e64b01ce", + "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/30885182c981ab175d4d034db0f6f469898070ab", + "reference": "30885182c981ab175d4d034db0f6f469898070ab", "shasum": "" }, "require": { "php": ">=7.1" }, + "provide": { + "ext-ctype": "*" + }, "suggest": { "ext-ctype": "For best performance" }, @@ -3971,12 +4078,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Ctype\\": "" - }, "files": [ "bootstrap.php" - ] + ], + "psr-4": { + "Symfony\\Polyfill\\Ctype\\": "" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -4001,7 +4108,7 @@ "portable" ], "support": { - "source": "https://github.com/symfony/polyfill-ctype/tree/v1.23.0" + "source": "https://github.com/symfony/polyfill-ctype/tree/v1.25.0" }, "funding": [ { @@ -4017,20 +4124,20 @@ "type": "tidelift" } ], - "time": "2021-02-19T12:13:01+00:00" + "time": "2021-10-20T20:35:02+00:00" }, { "name": "symfony/polyfill-intl-grapheme", - "version": "v1.23.1", + "version": "v1.25.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-intl-grapheme.git", - "reference": "16880ba9c5ebe3642d1995ab866db29270b36535" + "reference": "81b86b50cf841a64252b439e738e97f4a34e2783" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/16880ba9c5ebe3642d1995ab866db29270b36535", - "reference": "16880ba9c5ebe3642d1995ab866db29270b36535", + "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/81b86b50cf841a64252b439e738e97f4a34e2783", + "reference": "81b86b50cf841a64252b439e738e97f4a34e2783", "shasum": "" }, "require": { @@ -4050,12 +4157,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Intl\\Grapheme\\": "" - }, "files": [ "bootstrap.php" - ] + ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Grapheme\\": "" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -4082,7 +4189,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.23.1" + "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.25.0" }, "funding": [ { @@ -4098,11 +4205,11 @@ "type": "tidelift" } ], - "time": "2021-05-27T12:26:48+00:00" + "time": "2021-11-23T21:10:46+00:00" }, { "name": "symfony/polyfill-intl-normalizer", - "version": "v1.23.0", + "version": "v1.25.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-intl-normalizer.git", @@ -4131,12 +4238,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Intl\\Normalizer\\": "" - }, "files": [ "bootstrap.php" ], + "psr-4": { + "Symfony\\Polyfill\\Intl\\Normalizer\\": "" + }, "classmap": [ "Resources/stubs" ] @@ -4166,7 +4273,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.23.0" + "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.25.0" }, "funding": [ { @@ -4186,21 +4293,24 @@ }, { "name": "symfony/polyfill-mbstring", - "version": "v1.23.1", + "version": "v1.25.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-mbstring.git", - "reference": "9174a3d80210dca8daa7f31fec659150bbeabfc6" + "reference": "0abb51d2f102e00a4eefcf46ba7fec406d245825" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/9174a3d80210dca8daa7f31fec659150bbeabfc6", - "reference": "9174a3d80210dca8daa7f31fec659150bbeabfc6", + "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/0abb51d2f102e00a4eefcf46ba7fec406d245825", + "reference": "0abb51d2f102e00a4eefcf46ba7fec406d245825", "shasum": "" }, "require": { "php": ">=7.1" }, + "provide": { + "ext-mbstring": "*" + }, "suggest": { "ext-mbstring": "For best performance" }, @@ -4215,12 +4325,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Mbstring\\": "" - }, "files": [ "bootstrap.php" - ] + ], + "psr-4": { + "Symfony\\Polyfill\\Mbstring\\": "" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -4246,7 +4356,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.23.1" + "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.25.0" }, "funding": [ { @@ -4262,20 +4372,20 @@ "type": "tidelift" } ], - "time": "2021-05-27T12:26:48+00:00" + "time": "2021-11-30T18:21:41+00:00" }, { "name": "symfony/polyfill-php73", - "version": "v1.23.0", + "version": "v1.25.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-php73.git", - "reference": "fba8933c384d6476ab14fb7b8526e5287ca7e010" + "reference": "cc5db0e22b3cb4111010e48785a97f670b350ca5" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php73/zipball/fba8933c384d6476ab14fb7b8526e5287ca7e010", - "reference": "fba8933c384d6476ab14fb7b8526e5287ca7e010", + "url": "https://api.github.com/repos/symfony/polyfill-php73/zipball/cc5db0e22b3cb4111010e48785a97f670b350ca5", + "reference": "cc5db0e22b3cb4111010e48785a97f670b350ca5", "shasum": "" }, "require": { @@ -4292,12 +4402,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Php73\\": "" - }, "files": [ "bootstrap.php" ], + "psr-4": { + "Symfony\\Polyfill\\Php73\\": "" + }, "classmap": [ "Resources/stubs" ] @@ -4325,7 +4435,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-php73/tree/v1.23.0" + "source": "https://github.com/symfony/polyfill-php73/tree/v1.25.0" }, "funding": [ { @@ -4341,20 +4451,20 @@ "type": "tidelift" } ], - "time": "2021-02-19T12:13:01+00:00" + "time": "2021-06-05T21:20:04+00:00" }, { "name": "symfony/polyfill-php80", - "version": "v1.23.1", + "version": "v1.25.0", "source": { "type": "git", "url": "https://github.com/symfony/polyfill-php80.git", - "reference": "1100343ed1a92e3a38f9ae122fc0eb21602547be" + "reference": "4407588e0d3f1f52efb65fbe92babe41f37fe50c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/1100343ed1a92e3a38f9ae122fc0eb21602547be", - "reference": "1100343ed1a92e3a38f9ae122fc0eb21602547be", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/4407588e0d3f1f52efb65fbe92babe41f37fe50c", + "reference": "4407588e0d3f1f52efb65fbe92babe41f37fe50c", "shasum": "" }, "require": { @@ -4371,12 +4481,12 @@ } }, "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Php80\\": "" - }, "files": [ "bootstrap.php" ], + "psr-4": { + "Symfony\\Polyfill\\Php80\\": "" + }, "classmap": [ "Resources/stubs" ] @@ -4408,7 +4518,7 @@ "shim" ], "support": { - "source": "https://github.com/symfony/polyfill-php80/tree/v1.23.1" + "source": "https://github.com/symfony/polyfill-php80/tree/v1.25.0" }, "funding": [ { @@ -4424,20 +4534,20 @@ "type": "tidelift" } ], - "time": "2021-07-28T13:41:28+00:00" + "time": "2022-03-04T08:16:47+00:00" }, { "name": "symfony/process", - "version": "v5.4.0", + "version": "v5.4.5", "source": { "type": "git", "url": "https://github.com/symfony/process.git", - "reference": "5be20b3830f726e019162b26223110c8f47cf274" + "reference": "95440409896f90a5f85db07a32b517ecec17fa4c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/process/zipball/5be20b3830f726e019162b26223110c8f47cf274", - "reference": "5be20b3830f726e019162b26223110c8f47cf274", + "url": "https://api.github.com/repos/symfony/process/zipball/95440409896f90a5f85db07a32b517ecec17fa4c", + "reference": "95440409896f90a5f85db07a32b517ecec17fa4c", "shasum": "" }, "require": { @@ -4470,7 +4580,7 @@ "description": "Executes commands in sub-processes", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/process/tree/v5.4.0" + "source": "https://github.com/symfony/process/tree/v5.4.5" }, "funding": [ { @@ -4486,7 +4596,7 @@ "type": "tidelift" } ], - "time": "2021-11-28T15:25:38+00:00" + "time": "2022-01-30T18:16:22+00:00" }, { "name": "symfony/service-contracts", @@ -4573,16 +4683,16 @@ }, { "name": "symfony/string", - "version": "v5.4.0", + "version": "v5.4.3", "source": { "type": "git", "url": "https://github.com/symfony/string.git", - "reference": "9ffaaba53c61ba75a3c7a3a779051d1e9ec4fd2d" + "reference": "92043b7d8383e48104e411bc9434b260dbeb5a10" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/string/zipball/9ffaaba53c61ba75a3c7a3a779051d1e9ec4fd2d", - "reference": "9ffaaba53c61ba75a3c7a3a779051d1e9ec4fd2d", + "url": "https://api.github.com/repos/symfony/string/zipball/92043b7d8383e48104e411bc9434b260dbeb5a10", + "reference": "92043b7d8383e48104e411bc9434b260dbeb5a10", "shasum": "" }, "require": { @@ -4604,12 +4714,12 @@ }, "type": "library", "autoload": { - "psr-4": { - "Symfony\\Component\\String\\": "" - }, "files": [ "Resources/functions.php" ], + "psr-4": { + "Symfony\\Component\\String\\": "" + }, "exclude-from-classmap": [ "/Tests/" ] @@ -4639,7 +4749,7 @@ "utf8" ], "support": { - "source": "https://github.com/symfony/string/tree/v5.4.0" + "source": "https://github.com/symfony/string/tree/v5.4.3" }, "funding": [ { @@ -4655,7 +4765,7 @@ "type": "tidelift" } ], - "time": "2021-11-24T10:02:00+00:00" + "time": "2022-01-02T09:53:40+00:00" }, { "name": "theseer/tokenizer", @@ -4980,7 +5090,9 @@ ], "aliases": [], "minimum-stability": "stable", - "stability-flags": [], + "stability-flags": { + "composer/composer": 5 + }, "prefer-stable": false, "prefer-lowest": false, "platform": { @@ -4988,5 +5100,5 @@ "composer-plugin-api": "^1.0 || ^2.0" }, "platform-dev": [], - "plugin-api-version": "2.1.0" + "plugin-api-version": "2.2.0" } From 5009490c098da360716e1612658e978f0659ea78 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 13:44:40 +0100 Subject: [PATCH 02/18] feature: add support for composer v2.3.0+ MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- test/ComponentInstallerTest.php | 31 ++++++------------- .../NativeTypehintedRootPackageInterface.php | 26 ---------------- 2 files changed, 10 insertions(+), 47 deletions(-) delete mode 100644 test/TestAsset/NativeTypehintedRootPackageInterface.php diff --git a/test/ComponentInstallerTest.php b/test/ComponentInstallerTest.php index 45632b3..712b58f 100644 --- a/test/ComponentInstallerTest.php +++ b/test/ComponentInstallerTest.php @@ -12,7 +12,8 @@ use Composer\DependencyResolver\Pool; use Composer\Installer\PackageEvent; use Composer\IO\IOInterface; -use Composer\Repository\PlatformRepository; +use Composer\Package\RootPackage; +use Composer\Repository\InstalledRepositoryInterface; use Composer\Repository\RepositoryManager; use Composer\Repository\RootPackageRepository; use Generator; @@ -20,7 +21,6 @@ use Laminas\ComponentInstaller\PackageProvider\PackageProviderDetectionFactory; use LaminasTest\ComponentInstaller\TestAsset\NativeTypehintedInstallationManager as InstallationManager; use LaminasTest\ComponentInstaller\TestAsset\NativeTypehintedPackageInterface as PackageInterface; -use LaminasTest\ComponentInstaller\TestAsset\NativeTypehintedRootPackageInterface as RootPackageInterface; use org\bovigo\vfs\vfsStream; use org\bovigo\vfs\vfsStreamDirectory; use PHPUnit\Framework\MockObject\MockObject; @@ -52,26 +52,22 @@ final class ComponentInstallerTest extends TestCase private $installer; /** - * @var Composer|MockObject - * @psalm-var Composer&MockObject + * @var Composer&MockObject */ private $composer; /** - * @var RootPackageInterface|MockObject - * @psalm-var RootPackageInterface&MockObject + * @var RootPackage&MockObject */ private $rootPackage; /** - * @var IOInterface|MockObject - * @psalm-var IOInterface&MockObject + * @var IOInterface&MockObject */ private $io; /** - * @var InstallationManager|MockObject - * @psalm-var InstallationManager&MockObject + * @var InstallationManager&MockObject */ private $installationManager; @@ -85,12 +81,11 @@ protected function setUp(): void vfsStream::url('project') ); - /** @psalm-var Composer&MockObject $composer */ $composer = $this->createMock(Composer::class); $this->composer = $composer; - /** @psalm-var RootPackageInterface&MockObject $rootPackage */ - $rootPackage = $this->createMock(RootPackageInterface::class); + $rootPackage = $this->createMock(RootPackage::class); + $this->rootPackage = $rootPackage; $this->rootPackage ->method('getExtra') @@ -98,7 +93,6 @@ protected function setUp(): void return $this->rootPackageExtra; }); - /** @psalm-var IOInterface&MockObject $io */ $io = $this->createMock(IOInterface::class); $this->io = $io; @@ -108,7 +102,7 @@ protected function setUp(): void ->method('getConfig') ->willReturn($config); $repositoryManager = $this->createMock(RepositoryManager::class); - $localRepository = $this->createMock(PlatformRepository::class); + $localRepository = $this->createMock(InstalledRepositoryInterface::class); $localRepository ->method('getPackages') ->willReturn([]); @@ -136,7 +130,6 @@ protected function setUp(): void $this->io ); - /** @psalm-var InstallationManager&MockObject $installationManager */ $installationManager = $this->createMock(InstallationManager::class); $this->installationManager = $installationManager; @@ -214,8 +207,7 @@ private function createConfigFile($name, $contents): void } /** - * @param PackageEvent|MockObject $event - * @psalm-param PackageEvent&MockObject $event + * @param PackageEvent&MockObject $event */ private function prepareEventForPackageProviderDetection($event, string $packageName): void { @@ -1073,16 +1065,13 @@ public function testOnPostPackageInstallPromptsForConfigOptionsWhenDefinedAsArra public function testAddPackageToConfigWillPassProjectRootAsStringToConfigDiscovery(): void { - /** @psalm-var InstallationManager&MockObject $installationManager */ $installationManager = $this->createMock(InstallationManager::class); - /** @psalm-var Composer&MockObject $composer */ $composer = $this->createMock(Composer::class); $composer ->method('getInstallationManager') ->willReturn($installationManager); - /** @psalm-var IOInterface&MockObject $io */ $io = $this->createMock(IOInterface::class); $io ->expects(self::never()) diff --git a/test/TestAsset/NativeTypehintedRootPackageInterface.php b/test/TestAsset/NativeTypehintedRootPackageInterface.php deleted file mode 100644 index b44e25c..0000000 --- a/test/TestAsset/NativeTypehintedRootPackageInterface.php +++ /dev/null @@ -1,26 +0,0 @@ - Date: Wed, 16 Mar 2022 13:50:26 +0100 Subject: [PATCH 03/18] qa: optimize composer v1 testing MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 18 +++++++++++++----- composer.json | 2 +- composer.lock | 43 ++++++++++++++++++++----------------------- 3 files changed, 34 insertions(+), 29 deletions(-) diff --git a/.laminas-ci.json b/.laminas-ci.json index 985d864..45b2d2f 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -3,7 +3,7 @@ { "name": "PHPUnit on PHP 7.4 using Composer v1 with lowest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 install && ./vendor/bin/phpunit", + "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", "php": "7.4", "dependencies": "lowest" } @@ -11,7 +11,7 @@ { "name": "PHPUnit on PHP 7.4 using Composer v1 with latest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 install && ./vendor/bin/phpunit", + "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", "php": "7.4", "dependencies": "latest" } @@ -25,10 +25,18 @@ } }, { - "name": "PHPUnit on PHP 8.0 using Composer v1 with latest dependencies", + "name": "PHPUnit on PHP 8.1 using Composer v1 with latest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 install && ./vendor/bin/phpunit", - "php": "8.0", + "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", + "php": "8.1", + "dependencies": "latest" + } + }, + { + "name": "PHPUnit on PHP 8.1 using Composer v1 with latest dependencies", + "job": { + "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", + "php": "8.1", "dependencies": "latest" } } diff --git a/composer.json b/composer.json index 4716646..9d769fc 100644 --- a/composer.json +++ b/composer.json @@ -32,7 +32,7 @@ "composer-plugin-api": "^1.0 || ^2.0" }, "require-dev": { - "composer/composer": "^1.10.25 || ^2.3.0-rc1", + "composer/composer": "^2.3.0-rc1", "laminas/laminas-coding-standard": "~2.3.0", "malukenho/docheader": "^0.1.6", "mikey179/vfsstream": "^1.6.10", diff --git a/composer.lock b/composer.lock index 75d6c73..d06942d 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "ed44678195ec5cec9bdd2bcebbecc3bc", + "content-hash": "7e7b4b600330a14130f987c104fbfb12", "packages": [], "packages-dev": [ { @@ -40,13 +40,13 @@ } }, "autoload": { - "psr-4": { - "Amp\\": "lib" - }, "files": [ "lib/functions.php", "lib/Internal/functions.php" - ] + ], + "psr-4": { + "Amp\\": "lib" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -129,12 +129,12 @@ } }, "autoload": { - "psr-4": { - "Amp\\ByteStream\\": "lib" - }, "files": [ "lib/functions.php" - ] + ], + "psr-4": { + "Amp\\ByteStream\\": "lib" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -1316,9 +1316,6 @@ "require": { "php": "^7.1 || ^8.0" }, - "replace": { - "myclabs/deep-copy": "self.version" - }, "require-dev": { "doctrine/collections": "^1.0", "doctrine/common": "^2.6", @@ -1326,12 +1323,12 @@ }, "type": "library", "autoload": { - "psr-4": { - "DeepCopy\\": "src/DeepCopy/" - }, "files": [ "src/DeepCopy/deep_copy.php" - ] + ], + "psr-4": { + "DeepCopy\\": "src/DeepCopy/" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -2284,11 +2281,11 @@ } }, "autoload": { - "classmap": [ - "src/" - ], "files": [ "src/Framework/Assert/Functions.php" + ], + "classmap": [ + "src/" ] }, "notification-url": "https://packagist.org/downloads/", @@ -4894,13 +4891,13 @@ } }, "autoload": { - "psr-4": { - "Psalm\\": "src/Psalm/" - }, "files": [ "src/functions.php", "src/spl_object_id.php" - ] + ], + "psr-4": { + "Psalm\\": "src/Psalm/" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ From 1740e9b110530c52c0f620f817a19cc87381765b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 13:53:33 +0100 Subject: [PATCH 04/18] qa:apply coding standard MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- test/ComponentInstallerTest.php | 18 +++++------------- 1 file changed, 5 insertions(+), 13 deletions(-) diff --git a/test/ComponentInstallerTest.php b/test/ComponentInstallerTest.php index 712b58f..47ac074 100644 --- a/test/ComponentInstallerTest.php +++ b/test/ComponentInstallerTest.php @@ -51,24 +51,16 @@ final class ComponentInstallerTest extends TestCase /** @var ComponentInstaller */ private $installer; - /** - * @var Composer&MockObject - */ + /** @var Composer&MockObject */ private $composer; - /** - * @var RootPackage&MockObject - */ + /** @var RootPackage&MockObject */ private $rootPackage; - /** - * @var IOInterface&MockObject - */ + /** @var IOInterface&MockObject */ private $io; - /** - * @var InstallationManager&MockObject - */ + /** @var InstallationManager&MockObject */ private $installationManager; /** @var array{laminas?:array{component-whitelist?:list}} */ @@ -84,7 +76,7 @@ protected function setUp(): void $composer = $this->createMock(Composer::class); $this->composer = $composer; - $rootPackage = $this->createMock(RootPackage::class); + $rootPackage = $this->createMock(RootPackage::class); $this->rootPackage = $rootPackage; $this->rootPackage From 30ec19362e527e84f111df6c5481c3c6f4021ae1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 13:59:39 +0100 Subject: [PATCH 05/18] qa: bump `vimeo/psalm` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- composer.lock | 72 +++++++++++----------- psalm.xml.dist | 1 + src/ComponentInstaller.php | 13 +++- test/ComponentInstallerTest.php | 1 - test/Injector/AbstractInjectorTestCase.php | 3 +- 5 files changed, 50 insertions(+), 40 deletions(-) diff --git a/composer.lock b/composer.lock index d06942d..d985ed9 100644 --- a/composer.lock +++ b/composer.lock @@ -9,16 +9,16 @@ "packages-dev": [ { "name": "amphp/amp", - "version": "v2.6.1", + "version": "v2.6.2", "source": { "type": "git", "url": "https://github.com/amphp/amp.git", - "reference": "c5fc66a78ee38d7ac9195a37bacaf940eb3f65ae" + "reference": "9d5100cebffa729aaffecd3ad25dc5aeea4f13bb" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/amphp/amp/zipball/c5fc66a78ee38d7ac9195a37bacaf940eb3f65ae", - "reference": "c5fc66a78ee38d7ac9195a37bacaf940eb3f65ae", + "url": "https://api.github.com/repos/amphp/amp/zipball/9d5100cebffa729aaffecd3ad25dc5aeea4f13bb", + "reference": "9d5100cebffa729aaffecd3ad25dc5aeea4f13bb", "shasum": "" }, "require": { @@ -71,7 +71,7 @@ } ], "description": "A non-blocking concurrency framework for PHP applications.", - "homepage": "http://amphp.org/amp", + "homepage": "https://amphp.org/amp", "keywords": [ "async", "asynchronous", @@ -86,7 +86,7 @@ "support": { "irc": "irc://irc.freenode.org/amphp", "issues": "https://github.com/amphp/amp/issues", - "source": "https://github.com/amphp/amp/tree/v2.6.1" + "source": "https://github.com/amphp/amp/tree/v2.6.2" }, "funding": [ { @@ -94,7 +94,7 @@ "type": "github" } ], - "time": "2021-09-23T18:43:08+00:00" + "time": "2022-02-20T17:52:18+00:00" }, { "name": "amphp/byte-stream", @@ -425,16 +425,16 @@ }, { "name": "composer/package-versions-deprecated", - "version": "1.11.99.4", + "version": "1.11.99.5", "source": { "type": "git", "url": "https://github.com/composer/package-versions-deprecated.git", - "reference": "b174585d1fe49ceed21928a945138948cb394600" + "reference": "b4f54f74ef3453349c24a845d22392cd31e65f1d" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/package-versions-deprecated/zipball/b174585d1fe49ceed21928a945138948cb394600", - "reference": "b174585d1fe49ceed21928a945138948cb394600", + "url": "https://api.github.com/repos/composer/package-versions-deprecated/zipball/b4f54f74ef3453349c24a845d22392cd31e65f1d", + "reference": "b4f54f74ef3453349c24a845d22392cd31e65f1d", "shasum": "" }, "require": { @@ -478,7 +478,7 @@ "description": "Composer plugin that provides efficient querying for installed package versions (no runtime IO)", "support": { "issues": "https://github.com/composer/package-versions-deprecated/issues", - "source": "https://github.com/composer/package-versions-deprecated/tree/1.11.99.4" + "source": "https://github.com/composer/package-versions-deprecated/tree/1.11.99.5" }, "funding": [ { @@ -494,7 +494,7 @@ "type": "tidelift" } ], - "time": "2021-09-13T08:41:34+00:00" + "time": "2022-01-17T14:14:24+00:00" }, { "name": "composer/pcre", @@ -730,25 +730,27 @@ }, { "name": "composer/xdebug-handler", - "version": "2.0.2", + "version": "3.0.3", "source": { "type": "git", "url": "https://github.com/composer/xdebug-handler.git", - "reference": "84674dd3a7575ba617f5a76d7e9e29a7d3891339" + "reference": "ced299686f41dce890debac69273b47ffe98a40c" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/xdebug-handler/zipball/84674dd3a7575ba617f5a76d7e9e29a7d3891339", - "reference": "84674dd3a7575ba617f5a76d7e9e29a7d3891339", + "url": "https://api.github.com/repos/composer/xdebug-handler/zipball/ced299686f41dce890debac69273b47ffe98a40c", + "reference": "ced299686f41dce890debac69273b47ffe98a40c", "shasum": "" }, "require": { - "php": "^5.3.2 || ^7.0 || ^8.0", + "composer/pcre": "^1 || ^2 || ^3", + "php": "^7.2.5 || ^8.0", "psr/log": "^1 || ^2 || ^3" }, "require-dev": { - "phpstan/phpstan": "^0.12.55", - "symfony/phpunit-bridge": "^4.2 || ^5" + "phpstan/phpstan": "^1.0", + "phpstan/phpstan-strict-rules": "^1.1", + "symfony/phpunit-bridge": "^6.0" }, "type": "library", "autoload": { @@ -774,7 +776,7 @@ "support": { "irc": "irc://irc.freenode.org/composer", "issues": "https://github.com/composer/xdebug-handler/issues", - "source": "https://github.com/composer/xdebug-handler/tree/2.0.2" + "source": "https://github.com/composer/xdebug-handler/tree/3.0.3" }, "funding": [ { @@ -790,7 +792,7 @@ "type": "tidelift" } ], - "time": "2021-07-31T17:03:58+00:00" + "time": "2022-02-25T21:32:43+00:00" }, { "name": "dealerdirect/phpcodesniffer-composer-installer", @@ -1737,16 +1739,16 @@ }, { "name": "phpdocumentor/type-resolver", - "version": "1.5.1", + "version": "1.6.0", "source": { "type": "git", "url": "https://github.com/phpDocumentor/TypeResolver.git", - "reference": "a12f7e301eb7258bb68acd89d4aefa05c2906cae" + "reference": "93ebd0014cab80c4ea9f5e297ea48672f1b87706" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/a12f7e301eb7258bb68acd89d4aefa05c2906cae", - "reference": "a12f7e301eb7258bb68acd89d4aefa05c2906cae", + "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/93ebd0014cab80c4ea9f5e297ea48672f1b87706", + "reference": "93ebd0014cab80c4ea9f5e297ea48672f1b87706", "shasum": "" }, "require": { @@ -1781,9 +1783,9 @@ "description": "A PSR-5 based resolver of Class names, Types and Structural Element Names", "support": { "issues": "https://github.com/phpDocumentor/TypeResolver/issues", - "source": "https://github.com/phpDocumentor/TypeResolver/tree/1.5.1" + "source": "https://github.com/phpDocumentor/TypeResolver/tree/1.6.0" }, - "time": "2021-10-02T14:08:47+00:00" + "time": "2022-01-04T19:58:01+00:00" }, { "name": "phpspec/prophecy", @@ -4816,16 +4818,16 @@ }, { "name": "vimeo/psalm", - "version": "4.13.1", + "version": "4.22.0", "source": { "type": "git", "url": "https://github.com/vimeo/psalm.git", - "reference": "5cf660f63b548ccd4a56f62d916ee4d6028e01a3" + "reference": "fc2c6ab4d5fa5d644d8617089f012f3bb84b8703" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/vimeo/psalm/zipball/5cf660f63b548ccd4a56f62d916ee4d6028e01a3", - "reference": "5cf660f63b548ccd4a56f62d916ee4d6028e01a3", + "url": "https://api.github.com/repos/vimeo/psalm/zipball/fc2c6ab4d5fa5d644d8617089f012f3bb84b8703", + "reference": "fc2c6ab4d5fa5d644d8617089f012f3bb84b8703", "shasum": "" }, "require": { @@ -4833,7 +4835,7 @@ "amphp/byte-stream": "^1.5", "composer/package-versions-deprecated": "^1.8.0", "composer/semver": "^1.4 || ^2.0 || ^3.0", - "composer/xdebug-handler": "^1.1 || ^2.0", + "composer/xdebug-handler": "^1.1 || ^2.0 || ^3.0", "dnoegel/php-xdg-base-dir": "^0.1.1", "ext-ctype": "*", "ext-dom": "*", @@ -4916,9 +4918,9 @@ ], "support": { "issues": "https://github.com/vimeo/psalm/issues", - "source": "https://github.com/vimeo/psalm/tree/4.13.1" + "source": "https://github.com/vimeo/psalm/tree/4.22.0" }, - "time": "2021-11-23T23:52:49+00:00" + "time": "2022-02-24T20:34:05+00:00" }, { "name": "webimpress/coding-standard", diff --git a/psalm.xml.dist b/psalm.xml.dist index 4cc1b16..1d8570e 100644 --- a/psalm.xml.dist +++ b/psalm.xml.dist @@ -6,6 +6,7 @@ xsi:schemaLocation="https://getpsalm.org/schema/config vendor/vimeo/psalm/config.xsd" errorBaseline="psalm-baseline.xml" errorLevel="1" + findUnusedPsalmSuppress="true" > diff --git a/src/ComponentInstaller.php b/src/ComponentInstaller.php index 49126d4..18d5fdf 100644 --- a/src/ComponentInstaller.php +++ b/src/ComponentInstaller.php @@ -519,6 +519,7 @@ private function promptForConfigOption( $ask[] = sprintf(' Make your selection (default is %d):', $default); while (true) { + /** @psalm-suppress MixedAssignment Well the method returns mixed. We do verifying this in the next lines. */ $answer = $this->io->ask(implode($ask), $default); if (is_numeric($answer) && isset($options[(int) $answer])) { @@ -543,9 +544,12 @@ private function promptToRememberOption(InjectorInterface $injector, $packageTyp $ask = ["\n Remember this option for other packages of the same type? (Y/n)"]; while (true) { - $answer = strtolower($this->io->ask(implode($ask), 'y')); + $answer = $this->io->ask(implode($ask), 'y'); + if (! is_string($answer)) { + return; + } - switch ($answer) { + switch (strtolower($answer)) { case 'y': $this->cacheInjector($injector, $packageType); @@ -782,6 +786,11 @@ private function mapAutoloaders(array $autoload, ArrayObject $dependencies, stri private function mapType(array $map, string $type, ArrayObject $dependencies, string $packagePath): void { foreach ($map as $namespace => $paths) { + /** + * @psalm-suppress RedundantFunctionCallGivenDocblockType Since we only use psalm to verify v2 + * of composer here, lets keep this until dropping + * support for composer v1. + */ $paths = array_values((array) $paths); $this->mapNamespacePaths($paths, $namespace, $type, $dependencies, $packagePath); } diff --git a/test/ComponentInstallerTest.php b/test/ComponentInstallerTest.php index 47ac074..2f5525d 100644 --- a/test/ComponentInstallerTest.php +++ b/test/ComponentInstallerTest.php @@ -241,7 +241,6 @@ private function createInputAssertions(array $questionsAssertions): void { $consecutiveReturnValues = $consecutiveArguments = []; foreach ($questionsAssertions as $questionAssertion) { - /** @psalm-suppress MissingClosureParamType */ $consecutiveArguments[] = [ self::callback($questionAssertion->assertion()), ]; diff --git a/test/Injector/AbstractInjectorTestCase.php b/test/Injector/AbstractInjectorTestCase.php index 5430c3a..5a64f8e 100644 --- a/test/Injector/AbstractInjectorTestCase.php +++ b/test/Injector/AbstractInjectorTestCase.php @@ -41,8 +41,7 @@ protected function setUp(): void { $this->configDir = vfsStream::setup('project'); - $injectorClass = $this->injectorClass; - /** @psalm-suppress UnsafeInstantiation */ + $injectorClass = $this->injectorClass; $this->injector = new $injectorClass( vfsStream::url('project') ); From 1bf1fd0d17cbc90b83d1cdb149c7232737c608ba Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 14:12:16 +0100 Subject: [PATCH 06/18] qa: ensure that we properly detect `composer-1` commands MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci/pre-run.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.laminas-ci/pre-run.sh b/.laminas-ci/pre-run.sh index 695f8ac..4fa2cf4 100755 --- a/.laminas-ci/pre-run.sh +++ b/.laminas-ci/pre-run.sh @@ -10,7 +10,7 @@ function get_composer() { JOB=$3 COMMAND=$(echo "${JOB}" | jq -r ".command") -PATTERN="composer-1 install" +PATTERN="composer-1" if [[ "${COMMAND}" =~ ${PATTERN} ]];then get_composer From 0eb1427132fffb00125a98f8a67886d0a25deb77 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 14:50:17 +0100 Subject: [PATCH 07/18] qa: remove `pre-run.sh` which fetches composer v1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit We do not need composer v1 to run tests on composer v1. We can install composer v1 as `require-dev` using composer v2. Afterwards, unit tests are able to detect composer v1 by applying the appropriate checks. Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 8 ++++---- .laminas-ci/pre-run.sh | 17 ----------------- 2 files changed, 4 insertions(+), 21 deletions(-) delete mode 100755 .laminas-ci/pre-run.sh diff --git a/.laminas-ci.json b/.laminas-ci.json index 45b2d2f..a6ae644 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -3,7 +3,7 @@ { "name": "PHPUnit on PHP 7.4 using Composer v1 with lowest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", + "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", "php": "7.4", "dependencies": "lowest" } @@ -11,7 +11,7 @@ { "name": "PHPUnit on PHP 7.4 using Composer v1 with latest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", + "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", "php": "7.4", "dependencies": "latest" } @@ -27,7 +27,7 @@ { "name": "PHPUnit on PHP 8.1 using Composer v1 with latest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", + "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", "php": "8.1", "dependencies": "latest" } @@ -35,7 +35,7 @@ { "name": "PHPUnit on PHP 8.1 using Composer v1 with latest dependencies", "job": { - "command": "rm -rf ./vendor && composer-1 require --dev composer/composer:^1 && ./vendor/bin/phpunit", + "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", "php": "8.1", "dependencies": "latest" } diff --git a/.laminas-ci/pre-run.sh b/.laminas-ci/pre-run.sh deleted file mode 100755 index 4fa2cf4..0000000 --- a/.laminas-ci/pre-run.sh +++ /dev/null @@ -1,17 +0,0 @@ -#!/bin/bash - -set -e - -function get_composer() { - wget https://getcomposer.org/composer-1.phar - chmod a+x composer-1.phar - mv composer-1.phar /usr/local/bin/composer-1 -} - -JOB=$3 -COMMAND=$(echo "${JOB}" | jq -r ".command") -PATTERN="composer-1" - -if [[ "${COMMAND}" =~ ${PATTERN} ]];then - get_composer -fi From 1a6a210908f4ac3e55941555ba9296583a66122b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 14:56:19 +0100 Subject: [PATCH 08/18] qa: simplify `.laminas-ci.json` for composer v1 tests MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 38 +++----------------------------------- 1 file changed, 3 insertions(+), 35 deletions(-) diff --git a/.laminas-ci.json b/.laminas-ci.json index a6ae644..f362db9 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -1,43 +1,11 @@ { "additional_checks": [ { - "name": "PHPUnit on PHP 7.4 using Composer v1 with lowest dependencies", + "name": "PHPUnit using Composer v1", "job": { "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", - "php": "7.4", - "dependencies": "lowest" - } - }, - { - "name": "PHPUnit on PHP 7.4 using Composer v1 with latest dependencies", - "job": { - "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", - "php": "7.4", - "dependencies": "latest" - } - }, - { - "name": "PHPUnit on PHP 8.0 using Composer v1 with lowest dependencies", - "job": { - "command": "rm -rf ./vendor && composer-1 install --ignore-platform-reqs && ./vendor/bin/phpunit", - "php": "8.0", - "dependencies": "lowest" - } - }, - { - "name": "PHPUnit on PHP 8.1 using Composer v1 with latest dependencies", - "job": { - "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", - "php": "8.1", - "dependencies": "latest" - } - }, - { - "name": "PHPUnit on PHP 8.1 using Composer v1 with latest dependencies", - "job": { - "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", - "php": "8.1", - "dependencies": "latest" + "php": "*", + "dependencies": "*" } } ] From 666e011e179c43e0277c3ac4f4b9a30dd4fc661e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 15:22:57 +0100 Subject: [PATCH 09/18] bugfix: remove vendor directory before actually running `composer require` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.laminas-ci.json b/.laminas-ci.json index f362db9..8b069f3 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -3,7 +3,7 @@ { "name": "PHPUnit using Composer v1", "job": { - "command": "composer require --dev --update-with-all-dependencies composer/composer:^1 && ./vendor/bin/phpunit", + "command": "rm -r vendor/ && composer require --dev --update-with-all-dependencies composer/composer:^1 && vendor/bin/phpunit", "php": "*", "dependencies": "*" } From 397955c29976b91fd6222ead82f01a9754e932e8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 16:00:13 +0100 Subject: [PATCH 10/18] bugfix: add empty `ignore_php_platform_requirements` to `.laminas-ci.json` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit By adding an empty object to the config, we ensure that the default behavior of ignoring platform requirements for PHP 8 is disabled. Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.laminas-ci.json b/.laminas-ci.json index 8b069f3..4b2c853 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -8,5 +8,6 @@ "dependencies": "*" } } - ] + ], + "ignore_php_platform_requirements": {} } From c44d480d2d60703ab8484ae818329edf2bd5534c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Wed, 16 Mar 2022 16:21:33 +0100 Subject: [PATCH 11/18] qa: add `false` for PHP 8.0 as it is enabled by default due to previous implementation MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.laminas-ci.json b/.laminas-ci.json index 4b2c853..4735d03 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -9,5 +9,7 @@ } } ], - "ignore_php_platform_requirements": {} + "ignore_php_platform_requirements": { + "8.0": false + } } From 38748988574961425eb3c0f1b2b2c4a2b006e953 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 12:02:23 +0100 Subject: [PATCH 12/18] qa: require latest release candidate from `composer/composer` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This also restores tests on older composer v2 versions Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- composer.json | 2 +- composer.lock | 14 +++++++------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/composer.json b/composer.json index 9d769fc..361100c 100644 --- a/composer.json +++ b/composer.json @@ -32,7 +32,7 @@ "composer-plugin-api": "^1.0 || ^2.0" }, "require-dev": { - "composer/composer": "^2.3.0-rc1", + "composer/composer": "^2.1.9 || ^2.3.0-RC2", "laminas/laminas-coding-standard": "~2.3.0", "malukenho/docheader": "^0.1.6", "mikey179/vfsstream": "^1.6.10", diff --git a/composer.lock b/composer.lock index d985ed9..3577279 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "7e7b4b600330a14130f987c104fbfb12", + "content-hash": "d05409aa85b9505f371f7e7b5021de1a", "packages": [], "packages-dev": [ { @@ -251,16 +251,16 @@ }, { "name": "composer/composer", - "version": "2.3.0-RC1", + "version": "2.3.0-RC2", "source": { "type": "git", "url": "https://github.com/composer/composer.git", - "reference": "3b150d0ef6454694d074cac2807237894dfd6217" + "reference": "36dc875e1c6d5ce9411c78aae22b33ac24c86e13" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/composer/composer/zipball/3b150d0ef6454694d074cac2807237894dfd6217", - "reference": "3b150d0ef6454694d074cac2807237894dfd6217", + "url": "https://api.github.com/repos/composer/composer/zipball/36dc875e1c6d5ce9411c78aae22b33ac24c86e13", + "reference": "36dc875e1c6d5ce9411c78aae22b33ac24c86e13", "shasum": "" }, "require": { @@ -336,7 +336,7 @@ "support": { "irc": "ircs://irc.libera.chat:6697/composer", "issues": "https://github.com/composer/composer/issues", - "source": "https://github.com/composer/composer/tree/2.3.0-RC1" + "source": "https://github.com/composer/composer/tree/2.3.0-RC2" }, "funding": [ { @@ -352,7 +352,7 @@ "type": "tidelift" } ], - "time": "2022-03-16T08:25:31+00:00" + "time": "2022-03-20T12:20:49+00:00" }, { "name": "composer/metadata-minifier", From 22b7c677b492ebea697a5f52d81e141acef81c2d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 12:09:53 +0100 Subject: [PATCH 13/18] qa: optimize CI for composer v1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci.json | 2 +- .laminas-ci/prerun.sh | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) create mode 100755 .laminas-ci/prerun.sh diff --git a/.laminas-ci.json b/.laminas-ci.json index 4735d03..7e6e3f4 100644 --- a/.laminas-ci.json +++ b/.laminas-ci.json @@ -3,7 +3,7 @@ { "name": "PHPUnit using Composer v1", "job": { - "command": "rm -r vendor/ && composer require --dev --update-with-all-dependencies composer/composer:^1 && vendor/bin/phpunit", + "command": "rm -r vendor/ && composer require --dev --update-with-all-dependencies composer/composer:^1 && xmlstarlet ed -u '/phpunit/@convertDeprecationsToExceptions' -v 'false' phpunit.xml.dist > phpunit.xml && vendor/bin/phpunit", "php": "*", "dependencies": "*" } diff --git a/.laminas-ci/prerun.sh b/.laminas-ci/prerun.sh new file mode 100755 index 0000000..56e20dd --- /dev/null +++ b/.laminas-ci/prerun.sh @@ -0,0 +1,4 @@ +#!/bin/bash + +set -e +apt install xmlstarlet From 2efbd2c1b6775423d85d34b4990cf461cad7f7f5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 12:12:22 +0100 Subject: [PATCH 14/18] qa: rename pre run script MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- .laminas-ci/{prerun.sh => pre-run.sh} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename .laminas-ci/{prerun.sh => pre-run.sh} (100%) diff --git a/.laminas-ci/prerun.sh b/.laminas-ci/pre-run.sh similarity index 100% rename from .laminas-ci/prerun.sh rename to .laminas-ci/pre-run.sh From cf2b67d51a765afc569d75e8132910d74c95d146 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 12:17:44 +0100 Subject: [PATCH 15/18] bugfix: mock `RootPackage#getReplaces` and `RootPackage#getProvides` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This resolves type incompatibilities with latest mocking changes. Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- test/ComponentInstallerTest.php | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/test/ComponentInstallerTest.php b/test/ComponentInstallerTest.php index 2f5525d..05ec57c 100644 --- a/test/ComponentInstallerTest.php +++ b/test/ComponentInstallerTest.php @@ -85,6 +85,14 @@ protected function setUp(): void return $this->rootPackageExtra; }); + $this->rootPackage + ->method('getProvides') + ->willReturn([]); + + $this->rootPackage + ->method('getReplaces') + ->willReturn([]); + $io = $this->createMock(IOInterface::class); $this->io = $io; From 9bf0bf63032488130298d330c8e701e1db8f1378 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 14:12:41 +0100 Subject: [PATCH 16/18] qa: throw `RuntimeException` in case `IOInterface#ask` does not return a string MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- src/ComponentInstaller.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/ComponentInstaller.php b/src/ComponentInstaller.php index 18d5fdf..28045ad 100644 --- a/src/ComponentInstaller.php +++ b/src/ComponentInstaller.php @@ -21,6 +21,7 @@ use Laminas\ComponentInstaller\Injector\InjectorInterface; use Laminas\ComponentInstaller\PackageProvider\PackageProviderDetectionFactory; use Laminas\ComponentInstaller\PackageProvider\PackageProviderDetectionInterface; +use RuntimeException; use function array_diff_assoc; use function array_filter; @@ -34,6 +35,7 @@ use function explode; use function file_exists; use function file_get_contents; +use function gettype; use function implode; use function in_array; use function is_array; @@ -546,7 +548,7 @@ private function promptToRememberOption(InjectorInterface $injector, $packageTyp while (true) { $answer = $this->io->ask(implode($ask), 'y'); if (! is_string($answer)) { - return; + throw new RuntimeException(sprintf('Expected `%s#ask` to return a string: "%s" returned', IOInterface::class, gettype($answer))); } switch (strtolower($answer)) { From 3cd1c00d068b18825aa65a62404eedfe88337346 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 14:14:45 +0100 Subject: [PATCH 17/18] qa: allow release candidates for `composer/composer` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- composer.json | 2 +- composer.lock | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/composer.json b/composer.json index 361100c..6e4db1f 100644 --- a/composer.json +++ b/composer.json @@ -32,7 +32,7 @@ "composer-plugin-api": "^1.0 || ^2.0" }, "require-dev": { - "composer/composer": "^2.1.9 || ^2.3.0-RC2", + "composer/composer": "^2.1.9@RC", "laminas/laminas-coding-standard": "~2.3.0", "malukenho/docheader": "^0.1.6", "mikey179/vfsstream": "^1.6.10", diff --git a/composer.lock b/composer.lock index 3577279..229878a 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "d05409aa85b9505f371f7e7b5021de1a", + "content-hash": "c5f159d7d89b3a62856e2b328414444a", "packages": [], "packages-dev": [ { From 04bb6b2a066679677f8ffd272648b9d7729fe7f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Maximilian=20B=C3=B6sing?= <2189546+boesing@users.noreply.github.com> Date: Tue, 22 Mar 2022 15:26:04 +0100 Subject: [PATCH 18/18] qa: fix line-length issue MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Maximilian Bösing <2189546+boesing@users.noreply.github.com> --- src/ComponentInstaller.php | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/ComponentInstaller.php b/src/ComponentInstaller.php index 28045ad..e2313ff 100644 --- a/src/ComponentInstaller.php +++ b/src/ComponentInstaller.php @@ -548,7 +548,11 @@ private function promptToRememberOption(InjectorInterface $injector, $packageTyp while (true) { $answer = $this->io->ask(implode($ask), 'y'); if (! is_string($answer)) { - throw new RuntimeException(sprintf('Expected `%s#ask` to return a string: "%s" returned', IOInterface::class, gettype($answer))); + throw new RuntimeException(sprintf( + 'Expected `%s#ask` to return a string: "%s" returned', + IOInterface::class, + gettype($answer) + )); } switch (strtolower($answer)) {