From ed05c6096ae273808501fd580809386c4e4674cd Mon Sep 17 00:00:00 2001 From: Ferdinand Thiessen Date: Sun, 19 Apr 2026 22:49:07 +0200 Subject: [PATCH 1/3] chore: split phpunit into vendor-bin Signed-off-by: Ferdinand Thiessen --- .github/workflows/phpunit-mariadb.yml | 2 +- .github/workflows/phpunit-mysql.yml | 2 +- .github/workflows/phpunit-oci.yml | 2 +- .github/workflows/phpunit-pgsql.yml | 2 +- REUSE.toml | 16 +- composer.json | 3 +- composer.lock | 1799 +------------------------ psalm.xml | 3 - tests/phpunit.xml | 26 +- vendor-bin/phpunit/composer.json | 12 + vendor-bin/phpunit/composer.lock | 1691 +++++++++++++++++++++++ 11 files changed, 1725 insertions(+), 1833 deletions(-) create mode 100644 vendor-bin/phpunit/composer.json create mode 100644 vendor-bin/phpunit/composer.lock diff --git a/.github/workflows/phpunit-mariadb.yml b/.github/workflows/phpunit-mariadb.yml index 9cab8d1e8..8fa549cca 100644 --- a/.github/workflows/phpunit-mariadb.yml +++ b/.github/workflows/phpunit-mariadb.yml @@ -163,7 +163,7 @@ jobs: # Only run if phpunit config file exists if: steps.check_phpunit.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:unit + run: composer run test:unit -- --no-coverage - name: Check PHPUnit integration script is defined id: check_integration diff --git a/.github/workflows/phpunit-mysql.yml b/.github/workflows/phpunit-mysql.yml index ca2d6d862..233c6e156 100644 --- a/.github/workflows/phpunit-mysql.yml +++ b/.github/workflows/phpunit-mysql.yml @@ -161,7 +161,7 @@ jobs: # Only run if phpunit config file exists if: steps.check_phpunit.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:unit + run: composer run test:unit -- --no-coverage - name: Check PHPUnit integration script is defined id: check_integration diff --git a/.github/workflows/phpunit-oci.yml b/.github/workflows/phpunit-oci.yml index 415183940..847f6626e 100644 --- a/.github/workflows/phpunit-oci.yml +++ b/.github/workflows/phpunit-oci.yml @@ -168,7 +168,7 @@ jobs: # Only run if phpunit config file exists if: steps.check_phpunit.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:unit + run: composer run test:unit -- --no-coverage - name: Check PHPUnit integration script is defined id: check_integration diff --git a/.github/workflows/phpunit-pgsql.yml b/.github/workflows/phpunit-pgsql.yml index 8bdb9e424..aacbb975a 100644 --- a/.github/workflows/phpunit-pgsql.yml +++ b/.github/workflows/phpunit-pgsql.yml @@ -159,7 +159,7 @@ jobs: # Only run if phpunit config file exists if: steps.check_phpunit.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:unit + run: composer run test:unit -- --no-coverage - name: Check PHPUnit integration script is defined id: check_integration diff --git a/REUSE.toml b/REUSE.toml index 8e0d35133..6518d3e04 100644 --- a/REUSE.toml +++ b/REUSE.toml @@ -12,19 +12,13 @@ SPDX-FileCopyrightText = "2019-2026 Nextcloud GmbH and Nextcloud contributors" SPDX-License-Identifier = "AGPL-3.0-or-later" [[annotations]] -path = ["composer.json", "composer.lock"] +path = ["composer.json", "composer.lock", "vendor-bin/*/composer.json", "vendor-bin/*/composer.lock", "package-lock.json", "package.json"] precedence = "aggregate" SPDX-FileCopyrightText = "2019-2026 Nextcloud GmbH and Nextcloud contributors" SPDX-License-Identifier = "AGPL-3.0-or-later" [[annotations]] -path = ["package-lock.json", "package.json"] -precedence = "aggregate" -SPDX-FileCopyrightText = "2018-2026 Nextcloud GmbH and Nextcloud contributors" -SPDX-License-Identifier = "AGPL-3.0-or-later" - -[[annotations]] -path = ["vendor-bin/psalm/composer.json", "vendor-bin/psalm/composer.lock"] +path = ["openapi.json"] precedence = "aggregate" SPDX-FileCopyrightText = "2018-2026 Nextcloud GmbH and Nextcloud contributors" SPDX-License-Identifier = "AGPL-3.0-or-later" @@ -35,12 +29,6 @@ precedence = "aggregate" SPDX-FileCopyrightText = "Nextcloud GmbH and Nextcloud contributors" SPDX-License-Identifier = "CC0-1.0" -[[annotations]] -path = ["vendor-bin/cs-fixer/composer.json", "vendor-bin/cs-fixer/composer.lock", "vendor-bin/psalm/composer.json", "vendor-bin/psalm/composer.lock", "vendor-bin/openapi-extractor/composer.json", "vendor-bin/openapi-extractor/composer.lock", "openapi.json"] -precedence = "aggregate" -SPDX-FileCopyrightText = "2021-2026 Nextcloud GmbH and Nextcloud contributors" -SPDX-License-Identifier = "AGPL-3.0-or-later" - [[annotations]] path = [".tx/backport", ".tx/config"] precedence = "aggregate" diff --git a/composer.json b/composer.json index 1c8dd4131..2dcf6b6e4 100644 --- a/composer.json +++ b/composer.json @@ -23,8 +23,7 @@ "openapi": "generate-spec" }, "require-dev": { - "bamarni/composer-bin-plugin": "^1.8", - "phpunit/phpunit": "^9" + "bamarni/composer-bin-plugin": "^1.8" }, "require": { "maennchen/zipstream-php": "^2.4", diff --git a/composer.lock b/composer.lock index 2f8d20634..56bf746d5 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": "75a22c759b51788b44878cd2e9bb1463", + "content-hash": "907e3a4a8de0cfae7822ae8d7e62ecc2", "packages": [ { "name": "composer/pcre", @@ -604,1803 +604,6 @@ "source": "https://github.com/bamarni/composer-bin-plugin/tree/1.9.1" }, "time": "2026-02-04T10:18:12+00:00" - }, - { - "name": "doctrine/instantiator", - "version": "2.0.0", - "source": { - "type": "git", - "url": "https://github.com/doctrine/instantiator.git", - "reference": "c6222283fa3f4ac679f8b9ced9a4e23f163e80d0" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/doctrine/instantiator/zipball/c6222283fa3f4ac679f8b9ced9a4e23f163e80d0", - "reference": "c6222283fa3f4ac679f8b9ced9a4e23f163e80d0", - "shasum": "" - }, - "require": { - "php": "^8.1" - }, - "require-dev": { - "doctrine/coding-standard": "^11", - "ext-pdo": "*", - "ext-phar": "*", - "phpbench/phpbench": "^1.2", - "phpstan/phpstan": "^1.9.4", - "phpstan/phpstan-phpunit": "^1.3", - "phpunit/phpunit": "^9.5.27", - "vimeo/psalm": "^5.4" - }, - "type": "library", - "autoload": { - "psr-4": { - "Doctrine\\Instantiator\\": "src/Doctrine/Instantiator/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Marco Pivetta", - "email": "ocramius@gmail.com", - "homepage": "https://ocramius.github.io/" - } - ], - "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors", - "homepage": "https://www.doctrine-project.org/projects/instantiator.html", - "keywords": [ - "constructor", - "instantiate" - ], - "support": { - "issues": "https://github.com/doctrine/instantiator/issues", - "source": "https://github.com/doctrine/instantiator/tree/2.0.0" - }, - "funding": [ - { - "url": "https://www.doctrine-project.org/sponsorship.html", - "type": "custom" - }, - { - "url": "https://www.patreon.com/phpdoctrine", - "type": "patreon" - }, - { - "url": "https://tidelift.com/funding/github/packagist/doctrine%2Finstantiator", - "type": "tidelift" - } - ], - "time": "2022-12-30T00:23:10+00:00" - }, - { - "name": "myclabs/deep-copy", - "version": "1.13.4", - "source": { - "type": "git", - "url": "https://github.com/myclabs/DeepCopy.git", - "reference": "07d290f0c47959fd5eed98c95ee5602db07e0b6a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/07d290f0c47959fd5eed98c95ee5602db07e0b6a", - "reference": "07d290f0c47959fd5eed98c95ee5602db07e0b6a", - "shasum": "" - }, - "require": { - "php": "^7.1 || ^8.0" - }, - "conflict": { - "doctrine/collections": "<1.6.8", - "doctrine/common": "<2.13.3 || >=3 <3.2.2" - }, - "require-dev": { - "doctrine/collections": "^1.6.8", - "doctrine/common": "^2.13.3 || ^3.2.2", - "phpspec/prophecy": "^1.10", - "phpunit/phpunit": "^7.5.20 || ^8.5.23 || ^9.5.13" - }, - "type": "library", - "autoload": { - "files": [ - "src/DeepCopy/deep_copy.php" - ], - "psr-4": { - "DeepCopy\\": "src/DeepCopy/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "description": "Create deep copies (clones) of your objects", - "keywords": [ - "clone", - "copy", - "duplicate", - "object", - "object graph" - ], - "support": { - "issues": "https://github.com/myclabs/DeepCopy/issues", - "source": "https://github.com/myclabs/DeepCopy/tree/1.13.4" - }, - "funding": [ - { - "url": "https://tidelift.com/funding/github/packagist/myclabs/deep-copy", - "type": "tidelift" - } - ], - "time": "2025-08-01T08:46:24+00:00" - }, - { - "name": "nikic/php-parser", - "version": "v5.7.0", - "source": { - "type": "git", - "url": "https://github.com/nikic/PHP-Parser.git", - "reference": "dca41cd15c2ac9d055ad70dbfd011130757d1f82" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/dca41cd15c2ac9d055ad70dbfd011130757d1f82", - "reference": "dca41cd15c2ac9d055ad70dbfd011130757d1f82", - "shasum": "" - }, - "require": { - "ext-ctype": "*", - "ext-json": "*", - "ext-tokenizer": "*", - "php": ">=7.4" - }, - "require-dev": { - "ircmaxell/php-yacc": "^0.0.7", - "phpunit/phpunit": "^9.0" - }, - "bin": [ - "bin/php-parse" - ], - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "5.x-dev" - } - }, - "autoload": { - "psr-4": { - "PhpParser\\": "lib/PhpParser" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Nikita Popov" - } - ], - "description": "A PHP parser written in PHP", - "keywords": [ - "parser", - "php" - ], - "support": { - "issues": "https://github.com/nikic/PHP-Parser/issues", - "source": "https://github.com/nikic/PHP-Parser/tree/v5.7.0" - }, - "time": "2025-12-06T11:56:16+00:00" - }, - { - "name": "phar-io/manifest", - "version": "2.0.4", - "source": { - "type": "git", - "url": "https://github.com/phar-io/manifest.git", - "reference": "54750ef60c58e43759730615a392c31c80e23176" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/phar-io/manifest/zipball/54750ef60c58e43759730615a392c31c80e23176", - "reference": "54750ef60c58e43759730615a392c31c80e23176", - "shasum": "" - }, - "require": { - "ext-dom": "*", - "ext-libxml": "*", - "ext-phar": "*", - "ext-xmlwriter": "*", - "phar-io/version": "^3.0.1", - "php": "^7.2 || ^8.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Arne Blankerts", - "email": "arne@blankerts.de", - "role": "Developer" - }, - { - "name": "Sebastian Heuer", - "email": "sebastian@phpeople.de", - "role": "Developer" - }, - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "Developer" - } - ], - "description": "Component for reading phar.io manifest information from a PHP Archive (PHAR)", - "support": { - "issues": "https://github.com/phar-io/manifest/issues", - "source": "https://github.com/phar-io/manifest/tree/2.0.4" - }, - "funding": [ - { - "url": "https://github.com/theseer", - "type": "github" - } - ], - "time": "2024-03-03T12:33:53+00:00" - }, - { - "name": "phar-io/version", - "version": "3.2.1", - "source": { - "type": "git", - "url": "https://github.com/phar-io/version.git", - "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/phar-io/version/zipball/4f7fd7836c6f332bb2933569e566a0d6c4cbed74", - "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74", - "shasum": "" - }, - "require": { - "php": "^7.2 || ^8.0" - }, - "type": "library", - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Arne Blankerts", - "email": "arne@blankerts.de", - "role": "Developer" - }, - { - "name": "Sebastian Heuer", - "email": "sebastian@phpeople.de", - "role": "Developer" - }, - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "Developer" - } - ], - "description": "Library for handling version information and constraints", - "support": { - "issues": "https://github.com/phar-io/version/issues", - "source": "https://github.com/phar-io/version/tree/3.2.1" - }, - "time": "2022-02-21T01:04:05+00:00" - }, - { - "name": "phpunit/php-code-coverage", - "version": "9.2.32", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-code-coverage.git", - "reference": "85402a822d1ecf1db1096959413d35e1c37cf1a5" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/85402a822d1ecf1db1096959413d35e1c37cf1a5", - "reference": "85402a822d1ecf1db1096959413d35e1c37cf1a5", - "shasum": "" - }, - "require": { - "ext-dom": "*", - "ext-libxml": "*", - "ext-xmlwriter": "*", - "nikic/php-parser": "^4.19.1 || ^5.1.0", - "php": ">=7.3", - "phpunit/php-file-iterator": "^3.0.6", - "phpunit/php-text-template": "^2.0.4", - "sebastian/code-unit-reverse-lookup": "^2.0.3", - "sebastian/complexity": "^2.0.3", - "sebastian/environment": "^5.1.5", - "sebastian/lines-of-code": "^1.0.4", - "sebastian/version": "^3.0.2", - "theseer/tokenizer": "^1.2.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.6" - }, - "suggest": { - "ext-pcov": "PHP extension that provides line coverage", - "ext-xdebug": "PHP extension that provides line coverage as well as branch and path coverage" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-main": "9.2.x-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", - "homepage": "https://github.com/sebastianbergmann/php-code-coverage", - "keywords": [ - "coverage", - "testing", - "xunit" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/php-code-coverage/issues", - "security": "https://github.com/sebastianbergmann/php-code-coverage/security/policy", - "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/9.2.32" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2024-08-22T04:23:01+00:00" - }, - { - "name": "phpunit/php-file-iterator", - "version": "3.0.6", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-file-iterator.git", - "reference": "cf1c2e7c203ac650e352f4cc675a7021e7d1b3cf" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/cf1c2e7c203ac650e352f4cc675a7021e7d1b3cf", - "reference": "cf1c2e7c203ac650e352f4cc675a7021e7d1b3cf", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "FilterIterator implementation that filters files based on a list of suffixes.", - "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", - "keywords": [ - "filesystem", - "iterator" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues", - "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/3.0.6" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2021-12-02T12:48:52+00:00" - }, - { - "name": "phpunit/php-invoker", - "version": "3.1.1", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-invoker.git", - "reference": "5a10147d0aaf65b58940a0b72f71c9ac0423cc67" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-invoker/zipball/5a10147d0aaf65b58940a0b72f71c9ac0423cc67", - "reference": "5a10147d0aaf65b58940a0b72f71c9ac0423cc67", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "ext-pcntl": "*", - "phpunit/phpunit": "^9.3" - }, - "suggest": { - "ext-pcntl": "*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.1-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Invoke callables with a timeout", - "homepage": "https://github.com/sebastianbergmann/php-invoker/", - "keywords": [ - "process" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/php-invoker/issues", - "source": "https://github.com/sebastianbergmann/php-invoker/tree/3.1.1" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-09-28T05:58:55+00:00" - }, - { - "name": "phpunit/php-text-template", - "version": "2.0.4", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-text-template.git", - "reference": "5da5f67fc95621df9ff4c4e5a84d6a8a2acf7c28" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/5da5f67fc95621df9ff4c4e5a84d6a8a2acf7c28", - "reference": "5da5f67fc95621df9ff4c4e5a84d6a8a2acf7c28", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Simple template engine.", - "homepage": "https://github.com/sebastianbergmann/php-text-template/", - "keywords": [ - "template" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/php-text-template/issues", - "source": "https://github.com/sebastianbergmann/php-text-template/tree/2.0.4" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-10-26T05:33:50+00:00" - }, - { - "name": "phpunit/php-timer", - "version": "5.0.3", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/php-timer.git", - "reference": "5a63ce20ed1b5bf577850e2c4e87f4aa902afbd2" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/5a63ce20ed1b5bf577850e2c4e87f4aa902afbd2", - "reference": "5a63ce20ed1b5bf577850e2c4e87f4aa902afbd2", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "5.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Utility class for timing", - "homepage": "https://github.com/sebastianbergmann/php-timer/", - "keywords": [ - "timer" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/php-timer/issues", - "source": "https://github.com/sebastianbergmann/php-timer/tree/5.0.3" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-10-26T13:16:10+00:00" - }, - { - "name": "phpunit/phpunit", - "version": "9.6.33", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/phpunit.git", - "reference": "fea06253ecc0a32faf787bd31b261f56f351d049" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/fea06253ecc0a32faf787bd31b261f56f351d049", - "reference": "fea06253ecc0a32faf787bd31b261f56f351d049", - "shasum": "" - }, - "require": { - "doctrine/instantiator": "^1.5.0 || ^2", - "ext-dom": "*", - "ext-json": "*", - "ext-libxml": "*", - "ext-mbstring": "*", - "ext-xml": "*", - "ext-xmlwriter": "*", - "myclabs/deep-copy": "^1.13.4", - "phar-io/manifest": "^2.0.4", - "phar-io/version": "^3.2.1", - "php": ">=7.3", - "phpunit/php-code-coverage": "^9.2.32", - "phpunit/php-file-iterator": "^3.0.6", - "phpunit/php-invoker": "^3.1.1", - "phpunit/php-text-template": "^2.0.4", - "phpunit/php-timer": "^5.0.3", - "sebastian/cli-parser": "^1.0.2", - "sebastian/code-unit": "^1.0.8", - "sebastian/comparator": "^4.0.10", - "sebastian/diff": "^4.0.6", - "sebastian/environment": "^5.1.5", - "sebastian/exporter": "^4.0.8", - "sebastian/global-state": "^5.0.8", - "sebastian/object-enumerator": "^4.0.4", - "sebastian/resource-operations": "^3.0.4", - "sebastian/type": "^3.2.1", - "sebastian/version": "^3.0.2" - }, - "suggest": { - "ext-soap": "To be able to generate mocks based on WSDL files", - "ext-xdebug": "PHP extension that provides line coverage as well as branch and path coverage" - }, - "bin": [ - "phpunit" - ], - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "9.6-dev" - } - }, - "autoload": { - "files": [ - "src/Framework/Assert/Functions.php" - ], - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "The PHP Unit Testing framework.", - "homepage": "https://phpunit.de/", - "keywords": [ - "phpunit", - "testing", - "xunit" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/phpunit/issues", - "security": "https://github.com/sebastianbergmann/phpunit/security/policy", - "source": "https://github.com/sebastianbergmann/phpunit/tree/9.6.33" - }, - "funding": [ - { - "url": "https://phpunit.de/sponsors.html", - "type": "custom" - }, - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - }, - { - "url": "https://liberapay.com/sebastianbergmann", - "type": "liberapay" - }, - { - "url": "https://thanks.dev/u/gh/sebastianbergmann", - "type": "thanks_dev" - }, - { - "url": "https://tidelift.com/funding/github/packagist/phpunit/phpunit", - "type": "tidelift" - } - ], - "time": "2026-01-27T05:25:09+00:00" - }, - { - "name": "sebastian/cli-parser", - "version": "1.0.2", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/cli-parser.git", - "reference": "2b56bea83a09de3ac06bb18b92f068e60cc6f50b" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/cli-parser/zipball/2b56bea83a09de3ac06bb18b92f068e60cc6f50b", - "reference": "2b56bea83a09de3ac06bb18b92f068e60cc6f50b", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Library for parsing CLI options", - "homepage": "https://github.com/sebastianbergmann/cli-parser", - "support": { - "issues": "https://github.com/sebastianbergmann/cli-parser/issues", - "source": "https://github.com/sebastianbergmann/cli-parser/tree/1.0.2" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2024-03-02T06:27:43+00:00" - }, - { - "name": "sebastian/code-unit", - "version": "1.0.8", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/code-unit.git", - "reference": "1fc9f64c0927627ef78ba436c9b17d967e68e120" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/code-unit/zipball/1fc9f64c0927627ef78ba436c9b17d967e68e120", - "reference": "1fc9f64c0927627ef78ba436c9b17d967e68e120", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Collection of value objects that represent the PHP code units", - "homepage": "https://github.com/sebastianbergmann/code-unit", - "support": { - "issues": "https://github.com/sebastianbergmann/code-unit/issues", - "source": "https://github.com/sebastianbergmann/code-unit/tree/1.0.8" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-10-26T13:08:54+00:00" - }, - { - "name": "sebastian/code-unit-reverse-lookup", - "version": "2.0.3", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/code-unit-reverse-lookup.git", - "reference": "ac91f01ccec49fb77bdc6fd1e548bc70f7faa3e5" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/code-unit-reverse-lookup/zipball/ac91f01ccec49fb77bdc6fd1e548bc70f7faa3e5", - "reference": "ac91f01ccec49fb77bdc6fd1e548bc70f7faa3e5", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - } - ], - "description": "Looks up which function or method a line of code belongs to", - "homepage": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/", - "support": { - "issues": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/issues", - "source": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/tree/2.0.3" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-09-28T05:30:19+00:00" - }, - { - "name": "sebastian/comparator", - "version": "4.0.10", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/comparator.git", - "reference": "e4df00b9b3571187db2831ae9aada2c6efbd715d" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/e4df00b9b3571187db2831ae9aada2c6efbd715d", - "reference": "e4df00b9b3571187db2831ae9aada2c6efbd715d", - "shasum": "" - }, - "require": { - "php": ">=7.3", - "sebastian/diff": "^4.0", - "sebastian/exporter": "^4.0" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Volker Dusch", - "email": "github@wallbash.com" - }, - { - "name": "Bernhard Schussek", - "email": "bschussek@2bepublished.at" - } - ], - "description": "Provides the functionality to compare PHP values for equality", - "homepage": "https://github.com/sebastianbergmann/comparator", - "keywords": [ - "comparator", - "compare", - "equality" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/comparator/issues", - "source": "https://github.com/sebastianbergmann/comparator/tree/4.0.10" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - }, - { - "url": "https://liberapay.com/sebastianbergmann", - "type": "liberapay" - }, - { - "url": "https://thanks.dev/u/gh/sebastianbergmann", - "type": "thanks_dev" - }, - { - "url": "https://tidelift.com/funding/github/packagist/sebastian/comparator", - "type": "tidelift" - } - ], - "time": "2026-01-24T09:22:56+00:00" - }, - { - "name": "sebastian/complexity", - "version": "2.0.3", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/complexity.git", - "reference": "25f207c40d62b8b7aa32f5ab026c53561964053a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/25f207c40d62b8b7aa32f5ab026c53561964053a", - "reference": "25f207c40d62b8b7aa32f5ab026c53561964053a", - "shasum": "" - }, - "require": { - "nikic/php-parser": "^4.18 || ^5.0", - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Library for calculating the complexity of PHP code units", - "homepage": "https://github.com/sebastianbergmann/complexity", - "support": { - "issues": "https://github.com/sebastianbergmann/complexity/issues", - "source": "https://github.com/sebastianbergmann/complexity/tree/2.0.3" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2023-12-22T06:19:30+00:00" - }, - { - "name": "sebastian/diff", - "version": "4.0.6", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/diff.git", - "reference": "ba01945089c3a293b01ba9badc29ad55b106b0bc" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/ba01945089c3a293b01ba9badc29ad55b106b0bc", - "reference": "ba01945089c3a293b01ba9badc29ad55b106b0bc", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3", - "symfony/process": "^4.2 || ^5" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - }, - { - "name": "Kore Nordmann", - "email": "mail@kore-nordmann.de" - } - ], - "description": "Diff implementation", - "homepage": "https://github.com/sebastianbergmann/diff", - "keywords": [ - "diff", - "udiff", - "unidiff", - "unified diff" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/diff/issues", - "source": "https://github.com/sebastianbergmann/diff/tree/4.0.6" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2024-03-02T06:30:58+00:00" - }, - { - "name": "sebastian/environment", - "version": "5.1.5", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/environment.git", - "reference": "830c43a844f1f8d5b7a1f6d6076b784454d8b7ed" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/830c43a844f1f8d5b7a1f6d6076b784454d8b7ed", - "reference": "830c43a844f1f8d5b7a1f6d6076b784454d8b7ed", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "suggest": { - "ext-posix": "*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "5.1-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - } - ], - "description": "Provides functionality to handle HHVM/PHP environments", - "homepage": "http://www.github.com/sebastianbergmann/environment", - "keywords": [ - "Xdebug", - "environment", - "hhvm" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/environment/issues", - "source": "https://github.com/sebastianbergmann/environment/tree/5.1.5" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2023-02-03T06:03:51+00:00" - }, - { - "name": "sebastian/exporter", - "version": "4.0.8", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/exporter.git", - "reference": "14c6ba52f95a36c3d27c835d65efc7123c446e8c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/14c6ba52f95a36c3d27c835d65efc7123c446e8c", - "reference": "14c6ba52f95a36c3d27c835d65efc7123c446e8c", - "shasum": "" - }, - "require": { - "php": ">=7.3", - "sebastian/recursion-context": "^4.0" - }, - "require-dev": { - "ext-mbstring": "*", - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Volker Dusch", - "email": "github@wallbash.com" - }, - { - "name": "Adam Harvey", - "email": "aharvey@php.net" - }, - { - "name": "Bernhard Schussek", - "email": "bschussek@gmail.com" - } - ], - "description": "Provides the functionality to export PHP variables for visualization", - "homepage": "https://www.github.com/sebastianbergmann/exporter", - "keywords": [ - "export", - "exporter" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/exporter/issues", - "source": "https://github.com/sebastianbergmann/exporter/tree/4.0.8" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - }, - { - "url": "https://liberapay.com/sebastianbergmann", - "type": "liberapay" - }, - { - "url": "https://thanks.dev/u/gh/sebastianbergmann", - "type": "thanks_dev" - }, - { - "url": "https://tidelift.com/funding/github/packagist/sebastian/exporter", - "type": "tidelift" - } - ], - "time": "2025-09-24T06:03:27+00:00" - }, - { - "name": "sebastian/global-state", - "version": "5.0.8", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/global-state.git", - "reference": "b6781316bdcd28260904e7cc18ec983d0d2ef4f6" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/b6781316bdcd28260904e7cc18ec983d0d2ef4f6", - "reference": "b6781316bdcd28260904e7cc18ec983d0d2ef4f6", - "shasum": "" - }, - "require": { - "php": ">=7.3", - "sebastian/object-reflector": "^2.0", - "sebastian/recursion-context": "^4.0" - }, - "require-dev": { - "ext-dom": "*", - "phpunit/phpunit": "^9.3" - }, - "suggest": { - "ext-uopz": "*" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "5.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - } - ], - "description": "Snapshotting of global state", - "homepage": "http://www.github.com/sebastianbergmann/global-state", - "keywords": [ - "global state" - ], - "support": { - "issues": "https://github.com/sebastianbergmann/global-state/issues", - "source": "https://github.com/sebastianbergmann/global-state/tree/5.0.8" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - }, - { - "url": "https://liberapay.com/sebastianbergmann", - "type": "liberapay" - }, - { - "url": "https://thanks.dev/u/gh/sebastianbergmann", - "type": "thanks_dev" - }, - { - "url": "https://tidelift.com/funding/github/packagist/sebastian/global-state", - "type": "tidelift" - } - ], - "time": "2025-08-10T07:10:35+00:00" - }, - { - "name": "sebastian/lines-of-code", - "version": "1.0.4", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/lines-of-code.git", - "reference": "e1e4a170560925c26d424b6a03aed157e7dcc5c5" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/e1e4a170560925c26d424b6a03aed157e7dcc5c5", - "reference": "e1e4a170560925c26d424b6a03aed157e7dcc5c5", - "shasum": "" - }, - "require": { - "nikic/php-parser": "^4.18 || ^5.0", - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Library for counting the lines of code in PHP source code", - "homepage": "https://github.com/sebastianbergmann/lines-of-code", - "support": { - "issues": "https://github.com/sebastianbergmann/lines-of-code/issues", - "source": "https://github.com/sebastianbergmann/lines-of-code/tree/1.0.4" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2023-12-22T06:20:34+00:00" - }, - { - "name": "sebastian/object-enumerator", - "version": "4.0.4", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/object-enumerator.git", - "reference": "5c9eeac41b290a3712d88851518825ad78f45c71" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/object-enumerator/zipball/5c9eeac41b290a3712d88851518825ad78f45c71", - "reference": "5c9eeac41b290a3712d88851518825ad78f45c71", - "shasum": "" - }, - "require": { - "php": ">=7.3", - "sebastian/object-reflector": "^2.0", - "sebastian/recursion-context": "^4.0" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - } - ], - "description": "Traverses array structures and object graphs to enumerate all referenced objects", - "homepage": "https://github.com/sebastianbergmann/object-enumerator/", - "support": { - "issues": "https://github.com/sebastianbergmann/object-enumerator/issues", - "source": "https://github.com/sebastianbergmann/object-enumerator/tree/4.0.4" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-10-26T13:12:34+00:00" - }, - { - "name": "sebastian/object-reflector", - "version": "2.0.4", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/object-reflector.git", - "reference": "b4f479ebdbf63ac605d183ece17d8d7fe49c15c7" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/object-reflector/zipball/b4f479ebdbf63ac605d183ece17d8d7fe49c15c7", - "reference": "b4f479ebdbf63ac605d183ece17d8d7fe49c15c7", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - } - ], - "description": "Allows reflection of object attributes, including inherited and non-public ones", - "homepage": "https://github.com/sebastianbergmann/object-reflector/", - "support": { - "issues": "https://github.com/sebastianbergmann/object-reflector/issues", - "source": "https://github.com/sebastianbergmann/object-reflector/tree/2.0.4" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-10-26T13:14:26+00:00" - }, - { - "name": "sebastian/recursion-context", - "version": "4.0.6", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/recursion-context.git", - "reference": "539c6691e0623af6dc6f9c20384c120f963465a0" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/539c6691e0623af6dc6f9c20384c120f963465a0", - "reference": "539c6691e0623af6dc6f9c20384c120f963465a0", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "4.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - }, - { - "name": "Jeff Welch", - "email": "whatthejeff@gmail.com" - }, - { - "name": "Adam Harvey", - "email": "aharvey@php.net" - } - ], - "description": "Provides functionality to recursively process PHP variables", - "homepage": "https://github.com/sebastianbergmann/recursion-context", - "support": { - "issues": "https://github.com/sebastianbergmann/recursion-context/issues", - "source": "https://github.com/sebastianbergmann/recursion-context/tree/4.0.6" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - }, - { - "url": "https://liberapay.com/sebastianbergmann", - "type": "liberapay" - }, - { - "url": "https://thanks.dev/u/gh/sebastianbergmann", - "type": "thanks_dev" - }, - { - "url": "https://tidelift.com/funding/github/packagist/sebastian/recursion-context", - "type": "tidelift" - } - ], - "time": "2025-08-10T06:57:39+00:00" - }, - { - "name": "sebastian/resource-operations", - "version": "3.0.4", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/resource-operations.git", - "reference": "05d5692a7993ecccd56a03e40cd7e5b09b1d404e" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/resource-operations/zipball/05d5692a7993ecccd56a03e40cd7e5b09b1d404e", - "reference": "05d5692a7993ecccd56a03e40cd7e5b09b1d404e", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.0" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-main": "3.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de" - } - ], - "description": "Provides a list of PHP built-in functions that operate on resources", - "homepage": "https://www.github.com/sebastianbergmann/resource-operations", - "support": { - "source": "https://github.com/sebastianbergmann/resource-operations/tree/3.0.4" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2024-03-14T16:00:52+00:00" - }, - { - "name": "sebastian/type", - "version": "3.2.1", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/type.git", - "reference": "75e2c2a32f5e0b3aef905b9ed0b179b953b3d7c7" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/type/zipball/75e2c2a32f5e0b3aef905b9ed0b179b953b3d7c7", - "reference": "75e2c2a32f5e0b3aef905b9ed0b179b953b3d7c7", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "require-dev": { - "phpunit/phpunit": "^9.5" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.2-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Collection of value objects that represent the types of the PHP type system", - "homepage": "https://github.com/sebastianbergmann/type", - "support": { - "issues": "https://github.com/sebastianbergmann/type/issues", - "source": "https://github.com/sebastianbergmann/type/tree/3.2.1" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2023-02-03T06:13:03+00:00" - }, - { - "name": "sebastian/version", - "version": "3.0.2", - "source": { - "type": "git", - "url": "https://github.com/sebastianbergmann/version.git", - "reference": "c6c1022351a901512170118436c764e473f6de8c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/c6c1022351a901512170118436c764e473f6de8c", - "reference": "c6c1022351a901512170118436c764e473f6de8c", - "shasum": "" - }, - "require": { - "php": ">=7.3" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.0-dev" - } - }, - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Sebastian Bergmann", - "email": "sebastian@phpunit.de", - "role": "lead" - } - ], - "description": "Library that helps with managing the version number of Git-hosted PHP projects", - "homepage": "https://github.com/sebastianbergmann/version", - "support": { - "issues": "https://github.com/sebastianbergmann/version/issues", - "source": "https://github.com/sebastianbergmann/version/tree/3.0.2" - }, - "funding": [ - { - "url": "https://github.com/sebastianbergmann", - "type": "github" - } - ], - "time": "2020-09-28T06:39:44+00:00" - }, - { - "name": "theseer/tokenizer", - "version": "1.3.1", - "source": { - "type": "git", - "url": "https://github.com/theseer/tokenizer.git", - "reference": "b7489ce515e168639d17feec34b8847c326b0b3c" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/theseer/tokenizer/zipball/b7489ce515e168639d17feec34b8847c326b0b3c", - "reference": "b7489ce515e168639d17feec34b8847c326b0b3c", - "shasum": "" - }, - "require": { - "ext-dom": "*", - "ext-tokenizer": "*", - "ext-xmlwriter": "*", - "php": "^7.2 || ^8.0" - }, - "type": "library", - "autoload": { - "classmap": [ - "src/" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "BSD-3-Clause" - ], - "authors": [ - { - "name": "Arne Blankerts", - "email": "arne@blankerts.de", - "role": "Developer" - } - ], - "description": "A small library for converting tokenized PHP source code into XML and potentially other formats", - "support": { - "issues": "https://github.com/theseer/tokenizer/issues", - "source": "https://github.com/theseer/tokenizer/tree/1.3.1" - }, - "funding": [ - { - "url": "https://github.com/theseer", - "type": "github" - } - ], - "time": "2025-11-17T20:03:58+00:00" } ], "aliases": [], diff --git a/psalm.xml b/psalm.xml index 0479684f5..409f6d3cb 100644 --- a/psalm.xml +++ b/psalm.xml @@ -20,9 +20,6 @@ - - - diff --git a/tests/phpunit.xml b/tests/phpunit.xml index ff12b92b7..91ccf7fee 100644 --- a/tests/phpunit.xml +++ b/tests/phpunit.xml @@ -1,22 +1,24 @@ - + ./Unit - - - ../lib - - + + + ../lib + + diff --git a/vendor-bin/phpunit/composer.json b/vendor-bin/phpunit/composer.json new file mode 100644 index 000000000..c7b07e195 --- /dev/null +++ b/vendor-bin/phpunit/composer.json @@ -0,0 +1,12 @@ +{ + "config": { + "optimize-autoloader": true, + "sort-packages": true, + "platform": { + "php": "8.1" + } + }, + "require-dev": { + "phpunit/phpunit": "^10.5" + } +} diff --git a/vendor-bin/phpunit/composer.lock b/vendor-bin/phpunit/composer.lock new file mode 100644 index 000000000..66efdefd2 --- /dev/null +++ b/vendor-bin/phpunit/composer.lock @@ -0,0 +1,1691 @@ +{ + "_readme": [ + "This file locks the dependencies of your project to a known state", + "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", + "This file is @generated automatically" + ], + "content-hash": "fb78960ff7e774a72d424270c4bd3d90", + "packages": [], + "packages-dev": [ + { + "name": "myclabs/deep-copy", + "version": "1.13.4", + "source": { + "type": "git", + "url": "https://github.com/myclabs/DeepCopy.git", + "reference": "07d290f0c47959fd5eed98c95ee5602db07e0b6a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/07d290f0c47959fd5eed98c95ee5602db07e0b6a", + "reference": "07d290f0c47959fd5eed98c95ee5602db07e0b6a", + "shasum": "" + }, + "require": { + "php": "^7.1 || ^8.0" + }, + "conflict": { + "doctrine/collections": "<1.6.8", + "doctrine/common": "<2.13.3 || >=3 <3.2.2" + }, + "require-dev": { + "doctrine/collections": "^1.6.8", + "doctrine/common": "^2.13.3 || ^3.2.2", + "phpspec/prophecy": "^1.10", + "phpunit/phpunit": "^7.5.20 || ^8.5.23 || ^9.5.13" + }, + "type": "library", + "autoload": { + "files": [ + "src/DeepCopy/deep_copy.php" + ], + "psr-4": { + "DeepCopy\\": "src/DeepCopy/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Create deep copies (clones) of your objects", + "keywords": [ + "clone", + "copy", + "duplicate", + "object", + "object graph" + ], + "support": { + "issues": "https://github.com/myclabs/DeepCopy/issues", + "source": "https://github.com/myclabs/DeepCopy/tree/1.13.4" + }, + "funding": [ + { + "url": "https://tidelift.com/funding/github/packagist/myclabs/deep-copy", + "type": "tidelift" + } + ], + "time": "2025-08-01T08:46:24+00:00" + }, + { + "name": "nikic/php-parser", + "version": "v5.7.0", + "source": { + "type": "git", + "url": "https://github.com/nikic/PHP-Parser.git", + "reference": "dca41cd15c2ac9d055ad70dbfd011130757d1f82" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/dca41cd15c2ac9d055ad70dbfd011130757d1f82", + "reference": "dca41cd15c2ac9d055ad70dbfd011130757d1f82", + "shasum": "" + }, + "require": { + "ext-ctype": "*", + "ext-json": "*", + "ext-tokenizer": "*", + "php": ">=7.4" + }, + "require-dev": { + "ircmaxell/php-yacc": "^0.0.7", + "phpunit/phpunit": "^9.0" + }, + "bin": [ + "bin/php-parse" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "5.x-dev" + } + }, + "autoload": { + "psr-4": { + "PhpParser\\": "lib/PhpParser" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Nikita Popov" + } + ], + "description": "A PHP parser written in PHP", + "keywords": [ + "parser", + "php" + ], + "support": { + "issues": "https://github.com/nikic/PHP-Parser/issues", + "source": "https://github.com/nikic/PHP-Parser/tree/v5.7.0" + }, + "time": "2025-12-06T11:56:16+00:00" + }, + { + "name": "phar-io/manifest", + "version": "2.0.4", + "source": { + "type": "git", + "url": "https://github.com/phar-io/manifest.git", + "reference": "54750ef60c58e43759730615a392c31c80e23176" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phar-io/manifest/zipball/54750ef60c58e43759730615a392c31c80e23176", + "reference": "54750ef60c58e43759730615a392c31c80e23176", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-libxml": "*", + "ext-phar": "*", + "ext-xmlwriter": "*", + "phar-io/version": "^3.0.1", + "php": "^7.2 || ^8.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.0.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Arne Blankerts", + "email": "arne@blankerts.de", + "role": "Developer" + }, + { + "name": "Sebastian Heuer", + "email": "sebastian@phpeople.de", + "role": "Developer" + }, + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "Developer" + } + ], + "description": "Component for reading phar.io manifest information from a PHP Archive (PHAR)", + "support": { + "issues": "https://github.com/phar-io/manifest/issues", + "source": "https://github.com/phar-io/manifest/tree/2.0.4" + }, + "funding": [ + { + "url": "https://github.com/theseer", + "type": "github" + } + ], + "time": "2024-03-03T12:33:53+00:00" + }, + { + "name": "phar-io/version", + "version": "3.2.1", + "source": { + "type": "git", + "url": "https://github.com/phar-io/version.git", + "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phar-io/version/zipball/4f7fd7836c6f332bb2933569e566a0d6c4cbed74", + "reference": "4f7fd7836c6f332bb2933569e566a0d6c4cbed74", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0" + }, + "type": "library", + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Arne Blankerts", + "email": "arne@blankerts.de", + "role": "Developer" + }, + { + "name": "Sebastian Heuer", + "email": "sebastian@phpeople.de", + "role": "Developer" + }, + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "Developer" + } + ], + "description": "Library for handling version information and constraints", + "support": { + "issues": "https://github.com/phar-io/version/issues", + "source": "https://github.com/phar-io/version/tree/3.2.1" + }, + "time": "2022-02-21T01:04:05+00:00" + }, + { + "name": "phpunit/php-code-coverage", + "version": "10.1.16", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-code-coverage.git", + "reference": "7e308268858ed6baedc8704a304727d20bc07c77" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/7e308268858ed6baedc8704a304727d20bc07c77", + "reference": "7e308268858ed6baedc8704a304727d20bc07c77", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-libxml": "*", + "ext-xmlwriter": "*", + "nikic/php-parser": "^4.19.1 || ^5.1.0", + "php": ">=8.1", + "phpunit/php-file-iterator": "^4.1.0", + "phpunit/php-text-template": "^3.0.1", + "sebastian/code-unit-reverse-lookup": "^3.0.0", + "sebastian/complexity": "^3.2.0", + "sebastian/environment": "^6.1.0", + "sebastian/lines-of-code": "^2.0.2", + "sebastian/version": "^4.0.1", + "theseer/tokenizer": "^1.2.3" + }, + "require-dev": { + "phpunit/phpunit": "^10.1" + }, + "suggest": { + "ext-pcov": "PHP extension that provides line coverage", + "ext-xdebug": "PHP extension that provides line coverage as well as branch and path coverage" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "10.1.x-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.", + "homepage": "https://github.com/sebastianbergmann/php-code-coverage", + "keywords": [ + "coverage", + "testing", + "xunit" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-code-coverage/issues", + "security": "https://github.com/sebastianbergmann/php-code-coverage/security/policy", + "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/10.1.16" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-08-22T04:31:57+00:00" + }, + { + "name": "phpunit/php-file-iterator", + "version": "4.1.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-file-iterator.git", + "reference": "a95037b6d9e608ba092da1b23931e537cadc3c3c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/a95037b6d9e608ba092da1b23931e537cadc3c3c", + "reference": "a95037b6d9e608ba092da1b23931e537cadc3c3c", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "FilterIterator implementation that filters files based on a list of suffixes.", + "homepage": "https://github.com/sebastianbergmann/php-file-iterator/", + "keywords": [ + "filesystem", + "iterator" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues", + "security": "https://github.com/sebastianbergmann/php-file-iterator/security/policy", + "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/4.1.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-08-31T06:24:48+00:00" + }, + { + "name": "phpunit/php-invoker", + "version": "4.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-invoker.git", + "reference": "f5e568ba02fa5ba0ddd0f618391d5a9ea50b06d7" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-invoker/zipball/f5e568ba02fa5ba0ddd0f618391d5a9ea50b06d7", + "reference": "f5e568ba02fa5ba0ddd0f618391d5a9ea50b06d7", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "ext-pcntl": "*", + "phpunit/phpunit": "^10.0" + }, + "suggest": { + "ext-pcntl": "*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Invoke callables with a timeout", + "homepage": "https://github.com/sebastianbergmann/php-invoker/", + "keywords": [ + "process" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-invoker/issues", + "source": "https://github.com/sebastianbergmann/php-invoker/tree/4.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T06:56:09+00:00" + }, + { + "name": "phpunit/php-text-template", + "version": "3.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-text-template.git", + "reference": "0c7b06ff49e3d5072f057eb1fa59258bf287a748" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/0c7b06ff49e3d5072f057eb1fa59258bf287a748", + "reference": "0c7b06ff49e3d5072f057eb1fa59258bf287a748", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Simple template engine.", + "homepage": "https://github.com/sebastianbergmann/php-text-template/", + "keywords": [ + "template" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-text-template/issues", + "security": "https://github.com/sebastianbergmann/php-text-template/security/policy", + "source": "https://github.com/sebastianbergmann/php-text-template/tree/3.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-08-31T14:07:24+00:00" + }, + { + "name": "phpunit/php-timer", + "version": "6.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/php-timer.git", + "reference": "e2a2d67966e740530f4a3343fe2e030ffdc1161d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/e2a2d67966e740530f4a3343fe2e030ffdc1161d", + "reference": "e2a2d67966e740530f4a3343fe2e030ffdc1161d", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Utility class for timing", + "homepage": "https://github.com/sebastianbergmann/php-timer/", + "keywords": [ + "timer" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/php-timer/issues", + "source": "https://github.com/sebastianbergmann/php-timer/tree/6.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T06:57:52+00:00" + }, + { + "name": "phpunit/phpunit", + "version": "10.5.63", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/phpunit.git", + "reference": "33198268dad71e926626b618f3ec3966661e4d90" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/33198268dad71e926626b618f3ec3966661e4d90", + "reference": "33198268dad71e926626b618f3ec3966661e4d90", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-json": "*", + "ext-libxml": "*", + "ext-mbstring": "*", + "ext-xml": "*", + "ext-xmlwriter": "*", + "myclabs/deep-copy": "^1.13.4", + "phar-io/manifest": "^2.0.4", + "phar-io/version": "^3.2.1", + "php": ">=8.1", + "phpunit/php-code-coverage": "^10.1.16", + "phpunit/php-file-iterator": "^4.1.0", + "phpunit/php-invoker": "^4.0.0", + "phpunit/php-text-template": "^3.0.1", + "phpunit/php-timer": "^6.0.0", + "sebastian/cli-parser": "^2.0.1", + "sebastian/code-unit": "^2.0.0", + "sebastian/comparator": "^5.0.5", + "sebastian/diff": "^5.1.1", + "sebastian/environment": "^6.1.0", + "sebastian/exporter": "^5.1.4", + "sebastian/global-state": "^6.0.2", + "sebastian/object-enumerator": "^5.0.0", + "sebastian/recursion-context": "^5.0.1", + "sebastian/type": "^4.0.0", + "sebastian/version": "^4.0.1" + }, + "suggest": { + "ext-soap": "To be able to generate mocks based on WSDL files" + }, + "bin": [ + "phpunit" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "10.5-dev" + } + }, + "autoload": { + "files": [ + "src/Framework/Assert/Functions.php" + ], + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "The PHP Unit Testing framework.", + "homepage": "https://phpunit.de/", + "keywords": [ + "phpunit", + "testing", + "xunit" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/phpunit/issues", + "security": "https://github.com/sebastianbergmann/phpunit/security/policy", + "source": "https://github.com/sebastianbergmann/phpunit/tree/10.5.63" + }, + "funding": [ + { + "url": "https://phpunit.de/sponsors.html", + "type": "custom" + }, + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + }, + { + "url": "https://liberapay.com/sebastianbergmann", + "type": "liberapay" + }, + { + "url": "https://thanks.dev/u/gh/sebastianbergmann", + "type": "thanks_dev" + }, + { + "url": "https://tidelift.com/funding/github/packagist/phpunit/phpunit", + "type": "tidelift" + } + ], + "time": "2026-01-27T05:48:37+00:00" + }, + { + "name": "sebastian/cli-parser", + "version": "2.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/cli-parser.git", + "reference": "c34583b87e7b7a8055bf6c450c2c77ce32a24084" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/cli-parser/zipball/c34583b87e7b7a8055bf6c450c2c77ce32a24084", + "reference": "c34583b87e7b7a8055bf6c450c2c77ce32a24084", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "2.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library for parsing CLI options", + "homepage": "https://github.com/sebastianbergmann/cli-parser", + "support": { + "issues": "https://github.com/sebastianbergmann/cli-parser/issues", + "security": "https://github.com/sebastianbergmann/cli-parser/security/policy", + "source": "https://github.com/sebastianbergmann/cli-parser/tree/2.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-03-02T07:12:49+00:00" + }, + { + "name": "sebastian/code-unit", + "version": "2.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/code-unit.git", + "reference": "a81fee9eef0b7a76af11d121767abc44c104e503" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/code-unit/zipball/a81fee9eef0b7a76af11d121767abc44c104e503", + "reference": "a81fee9eef0b7a76af11d121767abc44c104e503", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "2.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Collection of value objects that represent the PHP code units", + "homepage": "https://github.com/sebastianbergmann/code-unit", + "support": { + "issues": "https://github.com/sebastianbergmann/code-unit/issues", + "source": "https://github.com/sebastianbergmann/code-unit/tree/2.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T06:58:43+00:00" + }, + { + "name": "sebastian/code-unit-reverse-lookup", + "version": "3.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/code-unit-reverse-lookup.git", + "reference": "5e3a687f7d8ae33fb362c5c0743794bbb2420a1d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/code-unit-reverse-lookup/zipball/5e3a687f7d8ae33fb362c5c0743794bbb2420a1d", + "reference": "5e3a687f7d8ae33fb362c5c0743794bbb2420a1d", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Looks up which function or method a line of code belongs to", + "homepage": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/", + "support": { + "issues": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/issues", + "source": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/tree/3.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T06:59:15+00:00" + }, + { + "name": "sebastian/comparator", + "version": "5.0.5", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/comparator.git", + "reference": "55dfef806eb7dfeb6e7a6935601fef866f8ca48d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/55dfef806eb7dfeb6e7a6935601fef866f8ca48d", + "reference": "55dfef806eb7dfeb6e7a6935601fef866f8ca48d", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-mbstring": "*", + "php": ">=8.1", + "sebastian/diff": "^5.0", + "sebastian/exporter": "^5.0" + }, + "require-dev": { + "phpunit/phpunit": "^10.5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@2bepublished.at" + } + ], + "description": "Provides the functionality to compare PHP values for equality", + "homepage": "https://github.com/sebastianbergmann/comparator", + "keywords": [ + "comparator", + "compare", + "equality" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/comparator/issues", + "security": "https://github.com/sebastianbergmann/comparator/security/policy", + "source": "https://github.com/sebastianbergmann/comparator/tree/5.0.5" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + }, + { + "url": "https://liberapay.com/sebastianbergmann", + "type": "liberapay" + }, + { + "url": "https://thanks.dev/u/gh/sebastianbergmann", + "type": "thanks_dev" + }, + { + "url": "https://tidelift.com/funding/github/packagist/sebastian/comparator", + "type": "tidelift" + } + ], + "time": "2026-01-24T09:25:16+00:00" + }, + { + "name": "sebastian/complexity", + "version": "3.2.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/complexity.git", + "reference": "68ff824baeae169ec9f2137158ee529584553799" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/68ff824baeae169ec9f2137158ee529584553799", + "reference": "68ff824baeae169ec9f2137158ee529584553799", + "shasum": "" + }, + "require": { + "nikic/php-parser": "^4.18 || ^5.0", + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.2-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library for calculating the complexity of PHP code units", + "homepage": "https://github.com/sebastianbergmann/complexity", + "support": { + "issues": "https://github.com/sebastianbergmann/complexity/issues", + "security": "https://github.com/sebastianbergmann/complexity/security/policy", + "source": "https://github.com/sebastianbergmann/complexity/tree/3.2.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-12-21T08:37:17+00:00" + }, + { + "name": "sebastian/diff", + "version": "5.1.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/diff.git", + "reference": "c41e007b4b62af48218231d6c2275e4c9b975b2e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/c41e007b4b62af48218231d6c2275e4c9b975b2e", + "reference": "c41e007b4b62af48218231d6c2275e4c9b975b2e", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0", + "symfony/process": "^6.4" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Kore Nordmann", + "email": "mail@kore-nordmann.de" + } + ], + "description": "Diff implementation", + "homepage": "https://github.com/sebastianbergmann/diff", + "keywords": [ + "diff", + "udiff", + "unidiff", + "unified diff" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/diff/issues", + "security": "https://github.com/sebastianbergmann/diff/security/policy", + "source": "https://github.com/sebastianbergmann/diff/tree/5.1.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-03-02T07:15:17+00:00" + }, + { + "name": "sebastian/environment", + "version": "6.1.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/environment.git", + "reference": "8074dbcd93529b357029f5cc5058fd3e43666984" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/8074dbcd93529b357029f5cc5058fd3e43666984", + "reference": "8074dbcd93529b357029f5cc5058fd3e43666984", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "suggest": { + "ext-posix": "*" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Provides functionality to handle HHVM/PHP environments", + "homepage": "https://github.com/sebastianbergmann/environment", + "keywords": [ + "Xdebug", + "environment", + "hhvm" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/environment/issues", + "security": "https://github.com/sebastianbergmann/environment/security/policy", + "source": "https://github.com/sebastianbergmann/environment/tree/6.1.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-03-23T08:47:14+00:00" + }, + { + "name": "sebastian/exporter", + "version": "5.1.4", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/exporter.git", + "reference": "0735b90f4da94969541dac1da743446e276defa6" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/0735b90f4da94969541dac1da743446e276defa6", + "reference": "0735b90f4da94969541dac1da743446e276defa6", + "shasum": "" + }, + "require": { + "ext-mbstring": "*", + "php": ">=8.1", + "sebastian/recursion-context": "^5.0" + }, + "require-dev": { + "phpunit/phpunit": "^10.5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.1-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Volker Dusch", + "email": "github@wallbash.com" + }, + { + "name": "Adam Harvey", + "email": "aharvey@php.net" + }, + { + "name": "Bernhard Schussek", + "email": "bschussek@gmail.com" + } + ], + "description": "Provides the functionality to export PHP variables for visualization", + "homepage": "https://www.github.com/sebastianbergmann/exporter", + "keywords": [ + "export", + "exporter" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/exporter/issues", + "security": "https://github.com/sebastianbergmann/exporter/security/policy", + "source": "https://github.com/sebastianbergmann/exporter/tree/5.1.4" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + }, + { + "url": "https://liberapay.com/sebastianbergmann", + "type": "liberapay" + }, + { + "url": "https://thanks.dev/u/gh/sebastianbergmann", + "type": "thanks_dev" + }, + { + "url": "https://tidelift.com/funding/github/packagist/sebastian/exporter", + "type": "tidelift" + } + ], + "time": "2025-09-24T06:09:11+00:00" + }, + { + "name": "sebastian/global-state", + "version": "6.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/global-state.git", + "reference": "987bafff24ecc4c9ac418cab1145b96dd6e9cbd9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/987bafff24ecc4c9ac418cab1145b96dd6e9cbd9", + "reference": "987bafff24ecc4c9ac418cab1145b96dd6e9cbd9", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "sebastian/object-reflector": "^3.0", + "sebastian/recursion-context": "^5.0" + }, + "require-dev": { + "ext-dom": "*", + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "6.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Snapshotting of global state", + "homepage": "https://www.github.com/sebastianbergmann/global-state", + "keywords": [ + "global state" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/global-state/issues", + "security": "https://github.com/sebastianbergmann/global-state/security/policy", + "source": "https://github.com/sebastianbergmann/global-state/tree/6.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-03-02T07:19:19+00:00" + }, + { + "name": "sebastian/lines-of-code", + "version": "2.0.2", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/lines-of-code.git", + "reference": "856e7f6a75a84e339195d48c556f23be2ebf75d0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/856e7f6a75a84e339195d48c556f23be2ebf75d0", + "reference": "856e7f6a75a84e339195d48c556f23be2ebf75d0", + "shasum": "" + }, + "require": { + "nikic/php-parser": "^4.18 || ^5.0", + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "2.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library for counting the lines of code in PHP source code", + "homepage": "https://github.com/sebastianbergmann/lines-of-code", + "support": { + "issues": "https://github.com/sebastianbergmann/lines-of-code/issues", + "security": "https://github.com/sebastianbergmann/lines-of-code/security/policy", + "source": "https://github.com/sebastianbergmann/lines-of-code/tree/2.0.2" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-12-21T08:38:20+00:00" + }, + { + "name": "sebastian/object-enumerator", + "version": "5.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/object-enumerator.git", + "reference": "202d0e344a580d7f7d04b3fafce6933e59dae906" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/object-enumerator/zipball/202d0e344a580d7f7d04b3fafce6933e59dae906", + "reference": "202d0e344a580d7f7d04b3fafce6933e59dae906", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "sebastian/object-reflector": "^3.0", + "sebastian/recursion-context": "^5.0" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Traverses array structures and object graphs to enumerate all referenced objects", + "homepage": "https://github.com/sebastianbergmann/object-enumerator/", + "support": { + "issues": "https://github.com/sebastianbergmann/object-enumerator/issues", + "source": "https://github.com/sebastianbergmann/object-enumerator/tree/5.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T07:08:32+00:00" + }, + { + "name": "sebastian/object-reflector", + "version": "3.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/object-reflector.git", + "reference": "24ed13d98130f0e7122df55d06c5c4942a577957" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/object-reflector/zipball/24ed13d98130f0e7122df55d06c5c4942a577957", + "reference": "24ed13d98130f0e7122df55d06c5c4942a577957", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Allows reflection of object attributes, including inherited and non-public ones", + "homepage": "https://github.com/sebastianbergmann/object-reflector/", + "support": { + "issues": "https://github.com/sebastianbergmann/object-reflector/issues", + "source": "https://github.com/sebastianbergmann/object-reflector/tree/3.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T07:06:18+00:00" + }, + { + "name": "sebastian/recursion-context", + "version": "5.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/recursion-context.git", + "reference": "47e34210757a2f37a97dcd207d032e1b01e64c7a" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/47e34210757a2f37a97dcd207d032e1b01e64c7a", + "reference": "47e34210757a2f37a97dcd207d032e1b01e64c7a", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "5.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Jeff Welch", + "email": "whatthejeff@gmail.com" + }, + { + "name": "Adam Harvey", + "email": "aharvey@php.net" + } + ], + "description": "Provides functionality to recursively process PHP variables", + "homepage": "https://github.com/sebastianbergmann/recursion-context", + "support": { + "issues": "https://github.com/sebastianbergmann/recursion-context/issues", + "security": "https://github.com/sebastianbergmann/recursion-context/security/policy", + "source": "https://github.com/sebastianbergmann/recursion-context/tree/5.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + }, + { + "url": "https://liberapay.com/sebastianbergmann", + "type": "liberapay" + }, + { + "url": "https://thanks.dev/u/gh/sebastianbergmann", + "type": "thanks_dev" + }, + { + "url": "https://tidelift.com/funding/github/packagist/sebastian/recursion-context", + "type": "tidelift" + } + ], + "time": "2025-08-10T07:50:56+00:00" + }, + { + "name": "sebastian/type", + "version": "4.0.0", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/type.git", + "reference": "462699a16464c3944eefc02ebdd77882bd3925bf" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/type/zipball/462699a16464c3944eefc02ebdd77882bd3925bf", + "reference": "462699a16464c3944eefc02ebdd77882bd3925bf", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "require-dev": { + "phpunit/phpunit": "^10.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Collection of value objects that represent the types of the PHP type system", + "homepage": "https://github.com/sebastianbergmann/type", + "support": { + "issues": "https://github.com/sebastianbergmann/type/issues", + "source": "https://github.com/sebastianbergmann/type/tree/4.0.0" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-03T07:10:45+00:00" + }, + { + "name": "sebastian/version", + "version": "4.0.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/version.git", + "reference": "c51fa83a5d8f43f1402e3f32a005e6262244ef17" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/c51fa83a5d8f43f1402e3f32a005e6262244ef17", + "reference": "c51fa83a5d8f43f1402e3f32a005e6262244ef17", + "shasum": "" + }, + "require": { + "php": ">=8.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de", + "role": "lead" + } + ], + "description": "Library that helps with managing the version number of Git-hosted PHP projects", + "homepage": "https://github.com/sebastianbergmann/version", + "support": { + "issues": "https://github.com/sebastianbergmann/version/issues", + "source": "https://github.com/sebastianbergmann/version/tree/4.0.1" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2023-02-07T11:34:05+00:00" + }, + { + "name": "theseer/tokenizer", + "version": "1.3.1", + "source": { + "type": "git", + "url": "https://github.com/theseer/tokenizer.git", + "reference": "b7489ce515e168639d17feec34b8847c326b0b3c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/theseer/tokenizer/zipball/b7489ce515e168639d17feec34b8847c326b0b3c", + "reference": "b7489ce515e168639d17feec34b8847c326b0b3c", + "shasum": "" + }, + "require": { + "ext-dom": "*", + "ext-tokenizer": "*", + "ext-xmlwriter": "*", + "php": "^7.2 || ^8.0" + }, + "type": "library", + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Arne Blankerts", + "email": "arne@blankerts.de", + "role": "Developer" + } + ], + "description": "A small library for converting tokenized PHP source code into XML and potentially other formats", + "support": { + "issues": "https://github.com/theseer/tokenizer/issues", + "source": "https://github.com/theseer/tokenizer/tree/1.3.1" + }, + "funding": [ + { + "url": "https://github.com/theseer", + "type": "github" + } + ], + "time": "2025-11-17T20:03:58+00:00" + } + ], + "aliases": [], + "minimum-stability": "stable", + "stability-flags": {}, + "prefer-stable": false, + "prefer-lowest": false, + "platform": {}, + "platform-dev": {}, + "platform-overrides": { + "php": "8.1" + }, + "plugin-api-version": "2.9.0" +} From 9fb1887938af34e63de8d0f6bbc597cbbec53fd8 Mon Sep 17 00:00:00 2001 From: Ferdinand Thiessen Date: Sun, 19 Apr 2026 23:01:00 +0200 Subject: [PATCH 2/3] chore: adjust code for breaking changes of PHPUnit 10 Signed-off-by: Ferdinand Thiessen --- .github/workflows/phpunit-mariadb.yml | 2 +- .github/workflows/phpunit-mysql.yml | 2 +- .github/workflows/phpunit-oci.yml | 2 +- .github/workflows/phpunit-pgsql.yml | 2 +- composer.json | 4 +- tests/Integration/Api/ApiV3Test.php | 88 +++++------- tests/Unit/Activity/ActivityManagerTest.php | 74 ++++++---- tests/Unit/Activity/ProviderTest.php | 6 +- tests/Unit/Controller/ApiControllerTest.php | 12 +- .../Unit/Controller/ConfigControllerTest.php | 2 +- .../Controller/ShareApiControllerTest.php | 6 +- tests/Unit/FormsMigratorTest.php | 12 +- tests/Unit/Service/CirclesServiceTest.php | 31 ++-- tests/Unit/Service/ConfigServiceTest.php | 6 +- tests/Unit/Service/FormsServiceTest.php | 132 ++++++------------ tests/Unit/Service/SubmissionServiceTest.php | 6 +- tests/phpunit.integration.xml | 36 ++--- 17 files changed, 188 insertions(+), 235 deletions(-) diff --git a/.github/workflows/phpunit-mariadb.yml b/.github/workflows/phpunit-mariadb.yml index 8fa549cca..c9710f399 100644 --- a/.github/workflows/phpunit-mariadb.yml +++ b/.github/workflows/phpunit-mariadb.yml @@ -181,7 +181,7 @@ jobs: # Only run if phpunit integration config file exists if: steps.check_integration.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:integration + run: composer run test:integration -- --no-coverage - name: Print logs if: always() diff --git a/.github/workflows/phpunit-mysql.yml b/.github/workflows/phpunit-mysql.yml index 233c6e156..6c2477d56 100644 --- a/.github/workflows/phpunit-mysql.yml +++ b/.github/workflows/phpunit-mysql.yml @@ -179,7 +179,7 @@ jobs: # Only run if phpunit integration config file exists if: steps.check_integration.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:integration + run: composer run test:integration -- --no-coverage - name: Print logs if: always() diff --git a/.github/workflows/phpunit-oci.yml b/.github/workflows/phpunit-oci.yml index 847f6626e..b9eef9885 100644 --- a/.github/workflows/phpunit-oci.yml +++ b/.github/workflows/phpunit-oci.yml @@ -186,7 +186,7 @@ jobs: # Only run if phpunit integration config file exists if: steps.check_integration.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:integration + run: composer run test:integration -- --no-coverage - name: Print logs if: always() diff --git a/.github/workflows/phpunit-pgsql.yml b/.github/workflows/phpunit-pgsql.yml index aacbb975a..f7c59d336 100644 --- a/.github/workflows/phpunit-pgsql.yml +++ b/.github/workflows/phpunit-pgsql.yml @@ -177,7 +177,7 @@ jobs: # Only run if phpunit integration config file exists if: steps.check_integration.outcome == 'success' working-directory: apps/${{ env.APP_NAME }} - run: composer run test:integration + run: composer run test:integration -- --no-coverage - name: Print logs if: always() diff --git a/composer.json b/composer.json index 2dcf6b6e4..982060bd0 100644 --- a/composer.json +++ b/composer.json @@ -17,8 +17,8 @@ "cs:fix": "php-cs-fixer fix", "cs:check": "php-cs-fixer fix --dry-run --diff", "lint": "find . -name \\*.php -not -path './vendor*/*' -print0 | xargs -0 -n1 php -l", - "test:unit": "phpunit -c tests/phpunit.xml", - "test:integration": "phpunit -c tests/phpunit.integration.xml", + "test:unit": "phpunit --display-all-issues -c tests/phpunit.xml", + "test:integration": "phpunit --display-all-issues -c tests/phpunit.integration.xml", "psalm": "psalm --no-cache", "openapi": "generate-spec" }, diff --git a/tests/Integration/Api/ApiV3Test.php b/tests/Integration/Api/ApiV3Test.php index 9cfe3394f..0605ffe91 100644 --- a/tests/Integration/Api/ApiV3Test.php +++ b/tests/Integration/Api/ApiV3Test.php @@ -12,6 +12,7 @@ use OCA\Forms\Constants; use OCA\Forms\Tests\Integration\IntegrationBase; +use PHPUnit\Framework\Attributes\DataProvider; /** * @group DB @@ -281,7 +282,7 @@ private function arrayUnsetId(array $arr): array { return $arr; } - public function dataGetForms() { + public static function dataGetForms() { return [ 'getTestforms' => [ 'expected' => [ @@ -328,7 +329,7 @@ public function testGetForms(array $expected): void { $this->assertEquals($expected, $data); } - public function dataGetSharedForms() { + public static function dataGetSharedForms() { return [ 'getTestforms' => [ 'expected' => [ @@ -364,7 +365,7 @@ public function testGetSharedForms(array $expected): void { $this->assertEquals($expected, $data); } - public function dataGetNewForm() { + public static function dataGetNewForm() { return [ 'getNewForm' => [ 'expected' => [ @@ -428,7 +429,7 @@ public function testGetNewForm(array $expected): void { $this->assertEquals($expected, $data); } - public function dataGetFullForm() { + public static function dataGetFullForm() { return [ 'getFullForm' => [ 'expected' => [ @@ -577,8 +578,8 @@ public function testGetFullForm(array $expected): void { $this->assertEquals($expected, $data); } - public function dataCloneForm() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataCloneForm() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; // Compared to full form expected, update changed properties $fullFormExpected['title'] = 'Title of a Form - Copy'; $fullFormExpected['shares'] = []; @@ -645,8 +646,8 @@ public function testCloneForm(array $expected): void { $this->assertEquals($expected, $data); } - public function dataUpdateFormProperties() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataUpdateFormProperties() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; $fullFormExpected['title'] = 'This is my NEW Title!'; $fullFormExpected['access'] = [ 'permitAllUsers' => true, @@ -704,7 +705,7 @@ public function testDeleteForm() { $this->assertEquals(404, $resp->getStatusCode()); } - public function dataCreateNewQuestion() { + public static function dataCreateNewQuestion() { return [ 'newQuestion' => [ 'expected' => [ @@ -764,8 +765,8 @@ public function testCreateNewQuestion(array $expected): void { $this->assertEquals($expected, $data); } - public function dataUpdateQuestionProperties() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataUpdateQuestionProperties() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; $fullFormExpected['questions'][0]['text'] = 'Still first Question!'; $fullFormExpected['questions'][0]['isRequired'] = false; @@ -802,8 +803,8 @@ public function testUpdateQuestionProperties(array $fullFormExpected): void { $this->testGetFullForm($fullFormExpected); } - public function dataReorderQuestions() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataReorderQuestions() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; $fullFormExpected['questions'][0]['order'] = 2; $fullFormExpected['questions'][1]['order'] = 1; @@ -850,8 +851,8 @@ public function testReorderQuestions(array $fullFormExpected): void { $this->testGetFullForm($fullFormExpected); } - public function dataDeleteQuestion() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataDeleteQuestion() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; array_splice($fullFormExpected['questions'], 0, 1); $fullFormExpected['questions'][0]['order'] = 1; $fullFormExpected['questions'][1]['order'] = 2; @@ -897,7 +898,7 @@ public function testCloneQuestion() { } } - public function dataCreateNewOption() { + public static function dataCreateNewOption() { return [ 'newOption' => [ 'expected' => [ @@ -934,8 +935,8 @@ public function testCreateNewOption(array $expected): void { $this->assertEquals($expected, $data); } - public function dataUpdateOptionProperties() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataUpdateOptionProperties() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; $fullFormExpected['questions'][1]['options'][0]['text'] = 'New option Text.'; return [ @@ -970,8 +971,8 @@ public function testUpdateOptionProperties(array $fullFormExpected): void { $this->testGetFullForm($fullFormExpected); } - public function dataDeleteOption() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataDeleteOption() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; array_splice($fullFormExpected['questions'][1]['options'], 0, 1); return [ @@ -1001,7 +1002,7 @@ public function testDeleteOption(array $fullFormExpected) { $this->testGetFullForm($fullFormExpected); } - public function dataAddShare() { + public static function dataAddShare() { return [ 'addAShare' => [ 'expected' => [ @@ -1039,8 +1040,8 @@ public function testAddShare(array $expected) { $this->assertEquals($expected, $data); } - public function dataUpdateShare() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataUpdateShare() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; $fullFormExpected['shares'][0]['permissions'] = [ Constants::PERMISSION_SUBMIT ]; return [ @@ -1074,8 +1075,8 @@ public function testUpdateShare(array $fullFormExpected) { $this->testGetFullForm($fullFormExpected); } - public function dataDeleteShare() { - $fullFormExpected = $this->dataGetFullForm()['getFullForm']['expected']; + public static function dataDeleteShare() { + $fullFormExpected = self::dataGetFullForm()['getFullForm']['expected']; array_splice($fullFormExpected['shares'], 0, 1); return [ @@ -1103,7 +1104,7 @@ public function testDeleteShare(array $fullFormExpected) { $this->testGetFullForm($fullFormExpected); } - public function dataGetSubmissions() { + public static function dataGetSubmissions() { return [ 'getSubmissions' => [ 'expected' => [ @@ -1165,7 +1166,7 @@ public function dataGetSubmissions() { ] ] ], - 'questions' => $this->dataGetFullForm()['getFullForm']['expected']['questions'], + 'questions' => self::dataGetFullForm()['getFullForm']['expected']['questions'], 'filteredSubmissionsCount' => 3, ] ] @@ -1212,7 +1213,7 @@ public function testGetSubmissions(array $expected) { $this->assertEquals($expected, $data); } - public function dataExportSubmissions() { + public static function dataExportSubmissions() { return [ 'exportSubmissions' => [ 'expected' => <<<'CSV' @@ -1283,8 +1284,8 @@ public function testExportToCloud() { $this->assertEquals('Title of a Form (responses).csv', $data); } - public function dataDeleteSubmissions() { - $submissionsExpected = $this->dataGetSubmissions()['getSubmissions']['expected']; + public static function dataDeleteSubmissions() { + $submissionsExpected = self::dataGetSubmissions()['getSubmissions']['expected']; $submissionsExpected['submissions'] = []; $submissionsExpected['filteredSubmissionsCount'] = 0; @@ -1294,11 +1295,8 @@ public function dataDeleteSubmissions() { ] ]; } - /** - * @dataProvider dataDeleteSubmissions - * - * @param array $submissionsExpected - */ + + #[DataProvider('dataDeleteSubmissions')] public function testDeleteSubmissions(array $submissionsExpected) { $resp = $this->http->request('DELETE', "api/v3/forms/{$this->testForms[0]['id']}/submissions"); $data = $this->OcsResponse2Data($resp); @@ -1309,23 +1307,7 @@ public function testDeleteSubmissions(array $submissionsExpected) { $this->testGetSubmissions($submissionsExpected); } - public function dataNewSubmission() { - $submissionsExpected = $this->dataGetSubmissions()['getSubmissions']['expected']; - $submissionsExpected['submissions'][] = [ - 'userId' => 'test' - ]; - - return [ - 'insertSubmission' => [ - 'submissionsExpected' => $submissionsExpected - ] - ]; - } - /** - * @dataProvider dataNewSubmission - */ public function testNewSubmission() { - $uploadedFileResponse = $this->http->request('POST', "api/v3/forms/{$this->testForms[0]['id']}/submissions/files/{$this->testForms[0]['questions'][2]['id']}", [ @@ -1405,8 +1387,8 @@ public function testNewSubmission() { ], $data['submissions'][0]); } - public function dataDeleteSingleSubmission() { - $submissionsExpected = $this->dataGetSubmissions()['getSubmissions']['expected']; + public static function dataDeleteSingleSubmission() { + $submissionsExpected = self::dataGetSubmissions()['getSubmissions']['expected']; array_splice($submissionsExpected['submissions'], 0, 1); return [ diff --git a/tests/Unit/Activity/ActivityManagerTest.php b/tests/Unit/Activity/ActivityManagerTest.php index 21d61d5ff..5b4256da6 100644 --- a/tests/Unit/Activity/ActivityManagerTest.php +++ b/tests/Unit/Activity/ActivityManagerTest.php @@ -16,22 +16,16 @@ use OCP\IGroupManager; use OCP\IUser; use OCP\Share\IShare; +use PHPUnit\Framework\Attributes\DataProvider; use PHPUnit\Framework\MockObject\MockObject; use Test\TestCase; class ActivityManagerTest extends TestCase { - /** @var ActivityManager */ - private $activityManager; - - /** @var IManager|MockObject */ - private $manager; - - /** @var IGroupManager|MockObject */ - private $groupManager; - - /** @var CirclesService|MockObject */ - private $circlesService; + private ActivityManager $activityManager; + private IManager&MockObject $manager; + private IGroupManager&MockObject $groupManager; + private CirclesService&MockObject $circlesService; public function setUp(): void { parent::setUp(); @@ -43,7 +37,7 @@ public function setUp(): void { } public function testPublishNewShare() { - // Can't mock the DB-Classes, as their Property-Methods are not explicitely defined. + // Can't mock the DB-Classes, as their Property-Methods are not explicitly defined. $form = new Form(); $form->setId(5); $form->setTitle('TestForm-Title'); @@ -73,7 +67,7 @@ public function testPublishNewShare() { } public function testPublishNewGroupShare() { - // Can't mock the DB-Classes, as their Property-Methods are not explicitely defined. + // Can't mock the DB-Classes, as their Property-Methods are not explicitly defined. $form = new Form(); $form->setId(5); $form->setTitle('TestForm-Title'); @@ -81,14 +75,18 @@ public function testPublishNewGroupShare() { $groupId = 'sharedGroup'; $group = $this->createMock(IGroup::class); - $user = $this->createMock(IUser::class); + $users = [ + $this->createMock(IUser::class), + $this->createMock(IUser::class), + $this->createMock(IUser::class) + ]; - $user->expects($this->exactly(3)) - ->method('getUID') - ->will($this->onConsecutiveCalls('user1', 'user2', 'user3')); + $users[0]->method('getUID')->willReturn('user1'); + $users[1]->method('getUID')->willReturn('user2'); + $users[2]->method('getUID')->willReturn('user3'); $group->expects($this->once()) ->method('getUsers') - ->willReturn([$user, $user, $user]); + ->willReturn($users); $this->groupManager->expects($this->once()) ->method('get') ->with($groupId) @@ -100,7 +98,6 @@ public function testPublishNewGroupShare() { ->willReturn($event); $event->expects($this->exactly(3))->method('setApp')->with('forms')->willReturn($event); $event->expects($this->exactly(3))->method('setType')->with('forms_newshare')->willReturn($event); - $event->expects($this->exactly(3))->method('setAffectedUser')->withConsecutive(['user1'], ['user2'], ['user3'])->willReturn($event); $event->expects($this->exactly(3))->method('setAuthor')->with('currentUser')->willReturn($event); $event->expects($this->exactly(3))->method('setObject')->with('form', 5)->willReturn($event); $event->expects($this->exactly(3))->method('setSubject')->with('newgroupshare', [ @@ -110,15 +107,24 @@ public function testPublishNewGroupShare() { 'groupId' => 'sharedGroup' ])->willReturn($event); + $affectedUsers = []; + $event->expects($this->exactly(3)) + ->method('setAffectedUser') + ->willReturnCallback(function ($userId) use (&$affectedUsers, &$event) { + $affectedUsers[] = $userId; + return $event; + }); + $this->manager->expects($this->exactly(3)) ->method('publish') ->with($event); $this->activityManager->publishNewGroupShare($form, $groupId); + $this->assertEquals(['user1', 'user2', 'user3'], $affectedUsers); } public function testPublishNewCircleShare() { - // Can't mock the DB-Classes, as their Property-Methods are not explicitely defined. + // Can't mock the DB-Classes, as their Property-Methods are not explicitly defined. $form = new Form(); $form->setId(5); $form->setTitle('TestForm-Title'); @@ -135,7 +141,6 @@ public function testPublishNewCircleShare() { ->willReturn($event); $event->expects($this->exactly(4))->method('setApp')->with('forms')->willReturn($event); $event->expects($this->exactly(4))->method('setType')->with('forms_newshare')->willReturn($event); - $event->expects($this->exactly(4))->method('setAffectedUser')->withConsecutive(['userId'], ['user1'], ['user2'], ['user3'])->willReturn($event); $event->expects($this->exactly(4))->method('setAuthor')->with('currentUser')->willReturn($event); $event->expects($this->exactly(4))->method('setObject')->with('form', 5)->willReturn($event); $event->expects($this->exactly(4))->method('setSubject')->with('newcircleshare', [ @@ -144,12 +149,20 @@ public function testPublishNewCircleShare() { 'formHash' => 'abcdefg12345', 'circleId' => $circleId ])->willReturn($event); + $affectedUsers = []; + $event->expects($this->exactly(4)) + ->method('setAffectedUser') + ->willReturnCallback(function (string $userId) use (&$affectedUsers, &$event) { + $affectedUsers[] = $userId; + return $event; + }); $this->manager->expects($this->exactly(4)) ->method('publish') ->with($event); $this->activityManager->publishNewCircleShare($form, $circleId); + $this->assertEquals(['userId', 'user1', 'user2', 'user3'], $affectedUsers); } public function testPublishNewCircleShare_circlesDisabled() { @@ -167,7 +180,7 @@ public function testPublishNewCircleShare_circlesDisabled() { } public function testPublishNewSubmission() { - // Can't mock the DB-Classes, as their Property-Methods are not explicitely defined. + // Can't mock the DB-Classes, as their Property-Methods are not explicitly defined. $form = new Form(); $form->setId(5); $form->setTitle('TestForm-Title'); @@ -197,12 +210,13 @@ public function testPublishNewSubmission() { $this->activityManager->publishNewSubmission($form, $submittorId); } - public function dataPublichNewSharedSubmission() { + public static function dataPublishNewSharedSubmission() { return [ 'user-share' => [ 'shareType' => IShare::TYPE_USER, 'shareWith' => 'sharedUser', - 'expected' => [['sharedUser']] + 'expected' => [['sharedUser']], + 'sharedUsers' => ['sharedUser'], ], 'group-share' => [ IShare::TYPE_GROUP, @@ -221,9 +235,8 @@ public function dataPublichNewSharedSubmission() { /** * Test notify shared results - * - * @dataProvider dataPublichNewSharedSubmission */ + #[DataProvider('dataPublishNewSharedSubmission')] public function testPublishNewSharedSubmission(int $shareType, string $shareWith, array $expected, ?array $sharedUsers = null) { // Can't mock the DB-Classes, as their Property-Methods are not explicitely defined. $form = new Form(); @@ -255,7 +268,6 @@ public function testPublishNewSharedSubmission(int $shareType, string $shareWith ->willReturn($event); $event->expects($this->exactly(count($expected)))->method('setApp')->with('forms')->willReturn($event); $event->expects($this->exactly(count($expected)))->method('setType')->with('forms_newsharedsubmission')->willReturn($event); - $event->expects($this->exactly(count($expected)))->method('setAffectedUser')->withConsecutive(...[...$expected])->willReturn($event); $event->expects($this->exactly(count($expected)))->method('setAuthor')->with('submittingUser')->willReturn($event); $event->expects($this->exactly(count($expected)))->method('setObject')->with('form', 5)->willReturn($event); $event->expects($this->exactly(count($expected)))->method('setSubject')->with('newsubmission', [ @@ -263,11 +275,19 @@ public function testPublishNewSharedSubmission(int $shareType, string $shareWith 'formTitle' => 'TestForm-Title', 'formHash' => 'abcdefg12345' ])->willReturn($event); + $affectedUsers = []; + $event->expects($this->exactly(count($sharedUsers))) + ->method('setAffectedUser') + ->willReturnCallback(function (string $userId) use (&$affectedUsers, &$event) { + $affectedUsers[] = $userId; + return $event; + }); $this->manager->expects($this->exactly(count($expected))) ->method('publish') ->with($event); $this->activityManager->publishNewSharedSubmission($form, $shareType, $shareWith, $submitterId); + $this->assertEquals($sharedUsers, $affectedUsers); } } diff --git a/tests/Unit/Activity/ProviderTest.php b/tests/Unit/Activity/ProviderTest.php index 6b3d3f22b..cb54c751d 100644 --- a/tests/Unit/Activity/ProviderTest.php +++ b/tests/Unit/Activity/ProviderTest.php @@ -189,7 +189,7 @@ public function testFullParse() { } // Expected data for Subject-Strings - public function dataGetSubjectString() { + public static function dataGetSubjectString() { return [ ['newshare', '{user} has shared the form {formTitle} with you'], ['newgroupshare', '{user} has shared the form {formTitle} with group {group}'], @@ -248,7 +248,7 @@ public function testParseSubjectString() { /** * Typical cases of RichParams for subjects */ - public function dataGetRichParams() { + public static function dataGetRichParams() { $newShareResult = [ 'user' => [ 'type' => 'user', @@ -463,7 +463,7 @@ public function testGetRichFormTitle() { /** * IconList for Subjects */ - public function dataGetEventIcon() { + public static function dataGetEventIcon() { return [ ['newshare', 'http://localhost/core/img/actions/shared.svg'], ['newgroupshare', 'http://localhost/core/img/actions/shared.svg'], diff --git a/tests/Unit/Controller/ApiControllerTest.php b/tests/Unit/Controller/ApiControllerTest.php index beabf0b0d..28c77c60b 100644 --- a/tests/Unit/Controller/ApiControllerTest.php +++ b/tests/Unit/Controller/ApiControllerTest.php @@ -217,7 +217,7 @@ public function testGetSubmissions_noPermissions() { $this->apiController->getSubmissions(1); } - public function dataGetSubmissions() { + public static function dataGetSubmissions() { return [ 'anon' => [ 'submissions' => [ @@ -491,7 +491,7 @@ public function testCreateNewForm_notAllowed() { $this->apiController->newForm(); } - public function dataTestCreateNewForm() { + public static function dataTestCreateNewForm() { return [ 'forms' => ['expectedForm' => [ 'id' => 7, @@ -545,7 +545,7 @@ public function testCreateNewForm($expectedForm) { $this->assertEquals(new DataResponse([], Http::STATUS_CREATED), $this->apiController->newForm()); } - public function dataCloneForm_exceptions() { + public static function dataCloneForm_exceptions() { return [ 'disabled' => [ 'canCreate' => false, @@ -580,7 +580,7 @@ public function testCloneForm_exceptions(bool $canCreate, $callback, string $exc $this->apiController->newForm(7); } - public function dataCloneForm() { + public static function dataCloneForm() { return [ 'works' => [ 'old' => [ @@ -876,7 +876,7 @@ public function testNewSubmission_formNotFound() { /** * Values for the formsService mock object for the following methods: hasUserAccess, hasFormExpired, canSubmit. */ - public function dataForCheckForbiddenException() { + public static function dataForCheckForbiddenException() { return [ 'user_dont_have_access_to_form' => [false, true, true, NoSuchFormException::class], 'form_expired' => [true, true, true, OCSForbiddenException::class], @@ -1006,7 +1006,7 @@ public function testDeleteSubmission($submissionData, $formData) { $this->assertEquals(new DataResponse(42), $this->apiController->deleteSubmission(1, 42)); } - public function dataTestDeletePermission() { + public static function dataTestDeletePermission() { return [ [ [ diff --git a/tests/Unit/Controller/ConfigControllerTest.php b/tests/Unit/Controller/ConfigControllerTest.php index ef6a46b5b..7e5020c6a 100644 --- a/tests/Unit/Controller/ConfigControllerTest.php +++ b/tests/Unit/Controller/ConfigControllerTest.php @@ -67,7 +67,7 @@ public function testGetAppConfig() { ]), $this->configController->getAppConfig()); } - public function dataUpdateAppConfig() { + public static function dataUpdateAppConfig() { return [ 'booleanConfig' => [ 'configKey' => 'allowPermitAll', diff --git a/tests/Unit/Controller/ShareApiControllerTest.php b/tests/Unit/Controller/ShareApiControllerTest.php index 0c4572815..3f3dad8e7 100644 --- a/tests/Unit/Controller/ShareApiControllerTest.php +++ b/tests/Unit/Controller/ShareApiControllerTest.php @@ -131,7 +131,7 @@ public function setUp(): void { ); } - public function dataValidNewShare() { + public static function dataValidNewShare() { return [ 'newUserShare' => [ 'shareType' => IShare::TYPE_USER, @@ -232,7 +232,7 @@ public function testValidNewShare(int $shareType, string $shareWith, array $perm $this->assertEquals($expectedResponse, $this->shareApiController->newShare(5, $shareType, $shareWith, $permissions)); } - public function dataNewLinkShare() { + public static function dataNewLinkShare() { return [ 'newLinkShare' => [ 'shareType' => IShare::TYPE_LINK, @@ -669,7 +669,7 @@ public function testDeleteForeignShare() { $this->shareApiController->deleteShare(5, 8); } - public function dataUpdateShare() { + public static function dataUpdateShare() { return [ 'valid-permissions' => [ 'share' => [ diff --git a/tests/Unit/FormsMigratorTest.php b/tests/Unit/FormsMigratorTest.php index 454f6d2ef..97f584a6c 100644 --- a/tests/Unit/FormsMigratorTest.php +++ b/tests/Unit/FormsMigratorTest.php @@ -22,6 +22,7 @@ use OCP\IUserManager; use OCP\UserMigration\IExportDestination; use OCP\UserMigration\IImportSource; +use PHPUnit\Framework\Attributes\DataProvider; use PHPUnit\Framework\MockObject\MockObject; use Symfony\Component\Console\Output\OutputInterface; @@ -85,7 +86,7 @@ public function setUp(): void { ); } - public function dataExport() { + public static function dataExport() { return [ 'exactlyOneOfEach' => [ 'expectedJson' => <<<'JSON' @@ -251,19 +252,18 @@ public function testExport(string $expectedJson) { $this->formsMigrator->export($user, $exportDestination, $output); } - public function dataImport() { + public static function dataImport() { return [ 'exactlyOneOfEach' => [ - '$inputJson' => '[{"title":"Link","description":"","created":1646251830,"access":{"permitAllUsers":false,"showToAllUsers":false},"expires":0,"state":0,"lockedBy":null,"lockedUntil":null,"maxSubmissions":null,"isAnonymous":false,"submitMultiple":false,"allowEditSubmissions":false,"showExpiration":false,"lastUpdated":123456789,"questions":[{"id":14,"order":2,"type":"multiple","isRequired":false,"text":"checkbox","description":"huhu","extraSettings":{},"options":[{"text":"ans1"}]}],"submissions":[{"userId":"anyUser@localhost","timestamp":1651354059,"answers":[{"questionId":14,"text":"ans1"}]}]}]' + 'inputJson' => '[{"title":"Link","description":"","created":1646251830,"access":{"permitAllUsers":false,"showToAllUsers":false},"expires":0,"state":0,"lockedBy":null,"lockedUntil":null,"maxSubmissions":null,"isAnonymous":false,"submitMultiple":false,"allowEditSubmissions":false,"showExpiration":false,"lastUpdated":123456789,"questions":[{"id":14,"order":2,"type":"multiple","isRequired":false,"text":"checkbox","description":"huhu","extraSettings":{},"options":[{"text":"ans1"}]}],"submissions":[{"userId":"anyUser@localhost","timestamp":1651354059,"answers":[{"questionId":14,"text":"ans1"}]}]}]' ] ]; } /** - * @dataProvider dataImport - * * @param string $inputJson JsonString to input */ + #[DataProvider('dataImport')] public function testImport(string $inputJson) { $user = $this->createMock(IUser::class); $importSource = $this->createMock(IImportSource::class); @@ -335,7 +335,7 @@ public function testGetVersion() { $this->assertEquals(1, $this->formsMigrator->getVersion()); } - public function dataCanImport() { + public static function dataCanImport() { return [ 'goodVersion' => [ 'version' => 1, diff --git a/tests/Unit/Service/CirclesServiceTest.php b/tests/Unit/Service/CirclesServiceTest.php index 772714acb..ba07cdbe4 100644 --- a/tests/Unit/Service/CirclesServiceTest.php +++ b/tests/Unit/Service/CirclesServiceTest.php @@ -12,29 +12,30 @@ use OCA\Circles\Model\Member; use OCA\Forms\Service\CirclesService; use OCP\App\IAppManager; +use PHPUnit\Framework\Attributes\DataProvider; use PHPUnit\Framework\MockObject\MockObject; use Psr\Container\ContainerInterface; use Psr\Log\LoggerInterface; use Test\TestCase; use Throwable; -class CirclesServiceText extends TestCase { - /** @var ContainerInterface|MockObject */ - private $container; - /** @var IAppManager|MockObject */ - private $appManager; - /** @var LoggerInterface|MockObject */ - private $logger; +class CirclesServiceTest extends TestCase { + private ContainerInterface&MockObject $container; + private IAppManager&MockObject $appManager; + private LoggerInterface&MockObject $logger; public function setUp(): void { - parent::setUp(); + if (!class_exists(CirclesManager::class)) { + $this->markTestSkipped('Circles app not available'); + } + parent::setUp(); $this->container = $this->createMock(ContainerInterface::class); $this->logger = $this->createMock(LoggerInterface::class); $this->appManager = $this->createMock(IAppManager::class); } - public function dataIsEnabled() { + public static function dataIsEnabled() { return [ 'not-enabled' => [ false, @@ -47,9 +48,7 @@ public function dataIsEnabled() { ]; } - /** - * @dataProvider dataIsEnabled - */ + #[DataProvider('dataIsEnabled')] public function testIsEnabled($enabled, $expected) { $this->appManager->expects($this->once()) ->method('isEnabledForUser') @@ -59,8 +58,8 @@ public function testIsEnabled($enabled, $expected) { $this->assertEquals($circlesService->isCirclesEnabled(), $expected); } - public function dataGetCircle() { - $circle = $this->createMock(Circle::class); + public static function dataGetCircle() { + $circle = self::createStub(Circle::class); return [ 'valid-circle' => [ @@ -84,9 +83,7 @@ public function dataGetCircle() { ]; } - /** - * @dataProvider dataGetCircle - */ + #[DataProvider('dataGetCircle')] public function testGetCircle($enabled, $throws, $circle, $expected) { $this->appManager->expects($this->once()) ->method('isEnabledForUser') diff --git a/tests/Unit/Service/ConfigServiceTest.php b/tests/Unit/Service/ConfigServiceTest.php index a46a724fb..d0ff7a420 100644 --- a/tests/Unit/Service/ConfigServiceTest.php +++ b/tests/Unit/Service/ConfigServiceTest.php @@ -56,7 +56,7 @@ public function setUp(): void { ); } - public function dataGetAppConfig() { + public static function dataGetAppConfig() { return [ 'oneFullConfig' => [ 'strConfig' => [ @@ -130,7 +130,7 @@ public function testGetAppConfig(array $strConfig, array $groupDisplayNames, arr $this->assertEquals($expected, $this->configService->getAppConfig()); } - public function dataGetAppConfig_Default() { + public static function dataGetAppConfig_Default() { return [ 'defaultValues' => [ 'expected' => [ @@ -160,7 +160,7 @@ public function testGetAppConfig_Default(array $expected) { $this->assertEquals($expected, $this->configService->getAppConfig()); } - public function dataCanCreateForms() { + public static function dataCanCreateForms() { return [ 'notRestriced' => [ 'config' => [ diff --git a/tests/Unit/Service/FormsServiceTest.php b/tests/Unit/Service/FormsServiceTest.php index 15b0021b9..0ae0378de 100644 --- a/tests/Unit/Service/FormsServiceTest.php +++ b/tests/Unit/Service/FormsServiceTest.php @@ -58,6 +58,7 @@ function microtime(bool|float $asFloat = false) { use OCP\IUserSession; use OCP\Security\ISecureRandom; use OCP\Share\IShare; +use PHPUnit\Framework\Attributes\DataProvider; use PHPUnit\Framework\MockObject\MockObject; use Psr\Log\LoggerInterface; @@ -139,9 +140,7 @@ public function setUp(): void { $this->l10n = $this->createMock(IL10N::class); $this->l10n->expects($this->any()) ->method('t') - ->will($this->returnCallback(function (string $identity) { - return $identity; - })); + ->willReturnArgument(0); $this->formsService = new FormsService( $userSession, @@ -173,7 +172,7 @@ public function testGenerateFormHash() { $this->assertEquals('testHash', $this->formsService->generateFormHash()); } - public function dataGetForm() { + public static function dataGetForm() { return [ // Just the full form without submissions 'one-full-form' => [[ @@ -261,11 +260,7 @@ public function dataGetForm() { ]; } - /** - * @dataProvider dataGetForm - * - * @param array $expected - */ + #[DataProvider('dataGetForm')] public function testGetForm(array $expected) { // The form $form = new Form(); @@ -358,7 +353,7 @@ public function testGetForm(array $expected) { $this->assertEquals($expected, $this->formsService->getForm($form)); } - public function dataGetPartialForm() { + public static function dataGetPartialForm() { return [ 'onePartialOwnedForm' => [[ 'id' => 42, @@ -399,7 +394,7 @@ public function testGetPartialForm(array $expected) { $this->assertEquals($expected, $this->formsService->getPartialFormArray($form)); } - public function dataGetPartialFormShared() { + public static function dataGetPartialFormShared() { return [ 'onePartialOwnedForm' => [[ 'id' => 42, @@ -418,10 +413,10 @@ public function dataGetPartialFormShared() { } /** * Make sure shared users with results permission also receive the submission count - * @dataProvider dataGetPartialFormShared * * @param array $expected */ + #[DataProvider('dataGetPartialFormShared')] public function testGetPartialFormShared(array $expected) { $form = new Form(); $form->setId(42); @@ -452,7 +447,7 @@ public function testGetPartialFormShared(array $expected) { $this->assertEquals($expected, $this->formsService->getPartialFormArray($form)); } - public function dataGetPublicForm() { + public static function dataGetPublicForm() { return [ // Bare form without questions, checking removed access & ownerId 'one-full-form' => [[ @@ -481,11 +476,8 @@ public function dataGetPublicForm() { ]] ]; } - /** - * @dataProvider dataGetPublicForm - * - * @param array $expected - */ + + #[DataProvider('dataGetPublicForm')] public function testGetPublicForm(array $expected) { // The form $form = new Form(); @@ -538,7 +530,7 @@ public function testGetPublicForm(array $expected) { $this->assertEquals($expected, $this->formsService->getPublicForm($form)); } - public function dataGetPermissions() { + public static function dataGetPermissions() { return [ 'ownerHasAllPermissions' => [ 'ownerId' => 'currentUser', @@ -592,13 +584,8 @@ public function dataGetPermissions() { ] ]; } - /** - * @dataProvider dataGetPermissions - * - * @param string $ownerId - * @param array $access - * @param array $expected - */ + + #[DataProvider('dataGetPermissions')] public function testGetPermissions(string $ownerId, array $access, array $shares, array $expected) { $form = new Form(); $form->setId(42); @@ -662,7 +649,7 @@ public function testGetPermissions_NotLoggedIn() { $this->assertEquals([], $formsService->getPermissions($form)); } - public function dataCanSeeResults() { + public static function dataCanSeeResults() { return [ 'allowFormOwner' => [ 'ownerId' => 'currentUser', @@ -694,13 +681,8 @@ public function dataCanSeeResults() { ] ]; } - /** - * @dataProvider dataCanSeeResults - * - * @param string $ownerId - * @param array $sharesArray - * @param bool $expected - */ + + #[DataProvider('dataCanSeeResults')] public function testCanSeeResults(string $ownerId, array $sharesArray, bool $expected) { $form = new Form(); $form->setId(42); @@ -729,7 +711,7 @@ public function testCanSeeResults(string $ownerId, array $sharesArray, bool $exp $this->assertEquals($expected, $this->formsService->canSeeResults($form)); } - public function dataCanDeleteResults() { + public static function dataCanDeleteResults() { return [ 'allowFormOwner' => [ 'ownerId' => 'currentUser', @@ -761,13 +743,8 @@ public function dataCanDeleteResults() { ] ]; } - /** - * @dataProvider dataCanDeleteResults - * - * @param string $ownerId - * @param array $sharesArray - * @param bool $expected - */ + + #[DataProvider('dataCanDeleteResults')] public function testCanDeleteResults(string $ownerId, array $sharesArray, bool $expected) { $form = new Form(); $form->setId(42); @@ -796,7 +773,7 @@ public function testCanDeleteResults(string $ownerId, array $sharesArray, bool $ $this->assertEquals($expected, $this->formsService->canDeleteResults($form)); } - public function dataCanSubmit() { + public static function dataCanSubmit() { return [ 'allowFormOwner' => [ 'ownerId' => 'currentUser', @@ -824,14 +801,8 @@ public function dataCanSubmit() { ] ]; } - /** - * @dataProvider dataCanSubmit - * - * @param string $ownerId - * @param bool $submitMultiple - * @param bool $hasFormSubmissionsByUser - * @param bool $expected - */ + + #[DataProvider('dataCanSubmit')] public function testCanSubmit(string $ownerId, bool $submitMultiple, bool $hasFormSubmissionsByUser, bool $expected) { $form = new Form(); $form->setId(42); @@ -900,7 +871,7 @@ public function testPublicCanSubmit() { $this->assertEquals(true, $formsService->canSubmit($form)); } - public function dataHasUserAccess() { + public static function dataHasUserAccess() { return [ 'ownerhasAccess' => [ 'accessArray' => [ @@ -928,13 +899,8 @@ public function dataHasUserAccess() { ], ]; } - /** - * @dataProvider dataHasUserAccess - * - * @param array $accessArray - * @param string $ownerId - * @param array $expected - */ + + #[DataProvider('dataHasUserAccess')] public function testHasUserAccess(array $accessArray, string $ownerId, bool $expected) { $form = new Form(); $form->setId(42); @@ -1021,7 +987,7 @@ public function testHasUserAccess_NotLoggedIn() { $this->assertEquals(false, $formsService->hasUserAccess($form)); } - public function dataHasFormExpired() { + public static function dataHasFormExpired() { return [ 'hasExpired' => [time() - 3600, Constants::FORM_STATE_ACTIVE, true], 'hasNotExpired' => [time() + 3600, Constants::FORM_STATE_ACTIVE, false], @@ -1030,13 +996,8 @@ public function dataHasFormExpired() { 'isArchived' => [time() + 3600, Constants::FORM_STATE_ARCHIVED, true], ]; } - /** - * @dataProvider dataHasFormExpired - * - * @param int $expires - * @param int $state the form state - * @param bool $expected has expired - */ + + #[DataProvider('dataHasFormExpired')] public function testHasFormExpired(int $expires, int $state, bool $expected) { $form = new Form(); $form->setState($state); @@ -1045,7 +1006,7 @@ public function testHasFormExpired(int $expires, int $state, bool $expected) { $this->assertEquals($expected, $this->formsService->hasFormExpired($form)); } - public function dataGetShareDisplayName() { + public static function dataGetShareDisplayName() { return [ 'userShare' => [ 'share' => [ @@ -1077,12 +1038,8 @@ public function dataGetShareDisplayName() { ], ]; } - /** - * @dataProvider dataGetShareDisplayName - * - * @param array $share - * @param string $expected - */ + + #[DataProvider('dataGetShareDisplayName')] public function testGetShareDisplayName(array $share, string $expected) { $user = $this->createMock(IUser::class); $user->expects($share['shareType'] === IShare::TYPE_USER ? $this->once() : $this->never()) @@ -1127,7 +1084,7 @@ public function testGetCircleShareDisplayName_circlesDisabled() { $this->assertEquals('', $this->formsService->getShareDisplayName($share)); } - public function dataNotifyNewShares() { + public static function dataNotifyNewShares() { return [ 'newUserShare' => [ 'shareType' => IShare::TYPE_USER, @@ -1146,13 +1103,13 @@ public function dataNotifyNewShares() { ] ]; } + /** - * @dataProvider dataNotifyNewShares - * * @param int $shareType * @param string $shareWith * @param string $expectedMethod that will be called on activityManager. */ + #[DataProvider('dataNotifyNewShares')] public function testNotifyNewShares(int $shareType, string $shareWith, string $expectedMethod) { $form = $this->createMock(Form::class); $share = new Share(); @@ -1166,7 +1123,7 @@ public function testNotifyNewShares(int $shareType, string $shareWith, string $e $this->formsService->notifyNewShares($form, $share); } - public function dataNotifyNewSubmission() { + public static function dataNotifyNewSubmission() { return [ 'no-shares' => [ [], @@ -1207,9 +1164,8 @@ public function dataNotifyNewSubmission() { /** * Test creating notifications for new submissions - * - * @dataProvider dataNotifyNewSubmission */ + #[DataProvider('dataNotifyNewSubmission')] public function testNotifyNewSubmission($shares, $shareNotifications) { $owner = 'ownerUser'; $submitter = 'someUser'; @@ -1261,18 +1217,16 @@ public function testNotifyNewSubmission($shares, $shareNotifications) { } /** - * @dataProvider dataAreExtraSettingsValid - * * @param array $extraSettings input settings * @param string $questionType question type * @param bool $expected expected return value - * */ + #[DataProvider('dataAreExtraSettingsValid')] public function testAreExtraSettingsValid(array $extraSettings, string $questionType, bool $expected) { $this->assertEquals($expected, $this->formsService->areExtraSettingsValid($extraSettings, $questionType)); } - public function dataAreExtraSettingsValid() { + public static function dataAreExtraSettingsValid() { return [ 'empty-extra-settings' => [ 'extraSettings' => [], @@ -1369,7 +1323,7 @@ public function dataAreExtraSettingsValid() { 'validationRegex' => '[' ], 'questionType' => Constants::ANSWER_TYPE_SHORT, - 'rval' => false + 'expected' => false ], 'invalid-custom-regex-delimiters' => [ 'extraSettings' => [ @@ -1377,7 +1331,7 @@ public function dataAreExtraSettingsValid() { 'validationRegex' => '/1/2/' ], 'questionType' => Constants::ANSWER_TYPE_SHORT, - 'rval' => false + 'expected' => false ], 'invalid-custom-regex-pattern' => [ 'extraSettings' => [ @@ -1385,7 +1339,7 @@ public function dataAreExtraSettingsValid() { 'validationRegex' => '/' . '[/' ], 'questionType' => Constants::ANSWER_TYPE_SHORT, - 'rval' => false + 'expected' => false ], 'invalid-custom-regex-type' => [ 'extraSettings' => [ @@ -1393,14 +1347,14 @@ public function dataAreExtraSettingsValid() { 'validationRegex' => 112 ], 'questionType' => Constants::ANSWER_TYPE_SHORT, - 'rval' => false + 'expected' => false ], 'invalid-custom-missing-regex' => [ 'extraSettings' => [ 'validationType' => 'regex', ], 'questionType' => Constants::ANSWER_TYPE_SHORT, - 'rval' => false + 'expected' => false ], 'valid-date-settings' => [ 'extraSettings' => [ diff --git a/tests/Unit/Service/SubmissionServiceTest.php b/tests/Unit/Service/SubmissionServiceTest.php index a5f92bcb2..746e42404 100644 --- a/tests/Unit/Service/SubmissionServiceTest.php +++ b/tests/Unit/Service/SubmissionServiceTest.php @@ -284,7 +284,7 @@ public function testGetSubmissionNotFound() { $this->assertNull($this->submissionService->getSubmission(999)); } - public function dataWriteFileToCloud() { + public static function dataWriteFileToCloud() { return [ 'rootFolder' => ['Some nice Form Title', '', Folder::class, 'csv', 'Some nice Form Title (responses).csv', false], 'subFolder' => ['Some nice Form Title', '/folder path', Folder::class, 'csv', 'Some nice Form Title (responses).csv', false], @@ -382,7 +382,7 @@ public function testWriteFileToCloudThrowsExceptionOnInvalidFormat() { } // Data for SubmissionCsv - public function dataGetSubmissionsData() { + public static function dataGetSubmissionsData() { return [ 'two-basic-submissions' => [ // Questions @@ -729,7 +729,7 @@ private function setUpCsvTest(array $questions, array $submissions, string $csvT } // Data for validation of Submissions - public function dataValidateSubmission() { + public static function dataValidateSubmission() { return [ 'required-not-answered' => [ // Questions diff --git a/tests/phpunit.integration.xml b/tests/phpunit.integration.xml index cccf71d11..5138bb23a 100644 --- a/tests/phpunit.integration.xml +++ b/tests/phpunit.integration.xml @@ -1,19 +1,19 @@ - - - ./Integration - - - - - ../lib - - - - - - - + + + ./Integration + + + + + + + + + + ../lib + + + \ No newline at end of file From 524ab0aab2ab31fbf02f3242af0275d4201e5cf8 Mon Sep 17 00:00:00 2001 From: Ferdinand Thiessen Date: Sun, 19 Apr 2026 23:05:29 +0200 Subject: [PATCH 3/3] ci: adjust dependabot config to update all vendor-bin Signed-off-by: Ferdinand Thiessen --- .github/dependabot.yml | 98 ++++++++---------------------------------- 1 file changed, 18 insertions(+), 80 deletions(-) diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 0b12bc53c..432c944c9 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -4,51 +4,16 @@ version: 2 updates: - package-ecosystem: composer target-branch: 'main' - directory: '/' - schedule: - interval: weekly - day: saturday - time: '03:00' - timezone: Europe/Paris - open-pull-requests-limit: 10 - labels: - - 3. to review - - dependencies - - - package-ecosystem: composer - target-branch: 'main' - directory: '/vendor-bin/cs-fixer/' - schedule: - interval: weekly - day: saturday - time: '03:00' - timezone: Europe/Paris - open-pull-requests-limit: 10 - labels: - - 3. to review - - dependencies - - - package-ecosystem: composer - target-branch: 'main' - directory: '/vendor-bin/openapi-extractor/' - schedule: - interval: weekly - day: saturday - time: '03:00' - timezone: Europe/Paris - open-pull-requests-limit: 10 - labels: - - 3. to review - - dependencies - - - package-ecosystem: composer - target-branch: 'main' - directory: '/vendor-bin/psalm/' + directories: + - '/' + - '/vendor-bin/*/' schedule: interval: weekly day: saturday time: '03:00' timezone: Europe/Paris + cooldown: + default-days: 4 open-pull-requests-limit: 10 labels: - 3. to review @@ -62,6 +27,9 @@ updates: day: saturday time: '03:00' timezone: Europe/Paris + cooldown: + default-days: 4 + semver-major-days: 8 open-pull-requests-limit: 10 labels: - 3. to review @@ -75,6 +43,8 @@ updates: day: saturday time: '03:00' timezone: Europe/Paris + cooldown: + default-days: 4 open-pull-requests-limit: 10 labels: - 3. to review @@ -82,51 +52,16 @@ updates: - package-ecosystem: composer target-branch: 'stable5.2' - directory: '/' - schedule: - interval: weekly - day: saturday - time: '03:00' - timezone: Europe/Paris - open-pull-requests-limit: 10 - labels: - - 3. to review - - dependencies - - - package-ecosystem: composer - target-branch: 'stable5.2' - directory: '/vendor-bin/cs-fixer/' - schedule: - interval: weekly - day: saturday - time: '03:00' - timezone: Europe/Paris - open-pull-requests-limit: 10 - labels: - - 3. to review - - dependencies - - - package-ecosystem: composer - target-branch: 'stable5.2' - directory: '/vendor-bin/openapi-extractor/' - schedule: - interval: weekly - day: saturday - time: '03:00' - timezone: Europe/Paris - open-pull-requests-limit: 10 - labels: - - 3. to review - - dependencies - - - package-ecosystem: composer - target-branch: 'stable5.2' - directory: '/vendor-bin/psalm/' + directories: + - '/' + - '/vendor-bin/*/' schedule: interval: weekly day: saturday time: '03:00' timezone: Europe/Paris + cooldown: + default-days: 4 open-pull-requests-limit: 10 labels: - 3. to review @@ -140,6 +75,9 @@ updates: day: saturday time: '03:00' timezone: Europe/Paris + cooldown: + default-days: 4 + semver-major-days: 8 open-pull-requests-limit: 10 labels: - 3. to review