-
-
Notifications
You must be signed in to change notification settings - Fork 9.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Composer warning when installing Codeception: "Adding phpunit/phpunit as a dependency is discouraged in favor of Symfony's PHPUnit Bridge" #27289
Comments
I have the same problem but using Behat |
We could solve this by allowing codeception/behat/etc. to be added on top of the phpunit that is built by the bridge. |
I think we have a compatability problem here now because of $ composer create-project symfony/skeleton .
$ composer require phpunit
$ bin/phpunit
# OK
$ composer require codeception/codeception
$ bin/phpunit
# We get:
PHP Fatal error: Declaration of Symfony\Bridge\PhpUnit\Legacy\SymfonyTestsListenerForV7::addError(PHPUnit\Framework\Test $test, Throwable $t, float $time): void must be compatible with PHPUnit\Framework\TestListener::addError(PHPUnit\Framework\Test $test, Exception $e, $time) in /Users/robert.akhmerov/git/gitlab.fun.co/backend/ssss/vendor/symfony/phpunit-bridge/Legacy/SymfonyTestsListenerForV7.php on line 27 |
can you show the output of |
I've got the exact same issue as @ThomasLandauer but with a different package. In my case I try to require https://github.com/martin-helmich/phpunit-json-assert which in their composer.json they have "require": {
"flow/jsonpath": "^0.3.1",
"phpunit/phpunit": ">=6.0",
"justinrainbow/json-schema": "^5.0",
"php": ">=7.0"
}, When I do
But it's only a warning as the tests work as expected. Cheers |
@stof Same problem here. This is my composer show output: behat/gherkin v4.5.1 Gherkin DSL parser for PHP 5.3
codeception/codeception 2.4.2 BDD-style testing framework
codeception/phpunit-wrapper 7.1.4 PHPUnit classes used by Codeception
codeception/stub 2.0.1 Flexible Stub wrapper for PHPUnit's Mock Builder
doctrine/annotations v1.6.0 Docblock Annotations Parser
doctrine/cache v1.7.1 Caching library offering an object-oriented API for many cache backends
doctrine/collections v1.5.0 Collections Abstraction library
doctrine/common v2.8.1 Common Library for Doctrine projects
doctrine/dbal v2.7.1 Database Abstraction Layer
doctrine/doctrine-bundle 1.9.1 Symfony DoctrineBundle
doctrine/doctrine-cache-bundle 1.3.3 Symfony Bundle for Doctrine Cache
doctrine/doctrine-migrations-bundle v1.3.1 Symfony DoctrineMigrationsBundle
doctrine/inflector v1.3.0 Common String Manipulations with regard to casing and singular/plural rules.
doctrine/instantiator 1.1.0 A small, lightweight utility to instantiate objects in PHP without invoking their constructors
doctrine/lexer v1.0.1 Base library for a lexer that can be used in Top-Down, Recursive Descent Parsers.
doctrine/migrations v1.8.1 Database Schema migrations using Doctrine DBAL
doctrine/orm v2.6.1 Object-Relational-Mapper for PHP
facebook/webdriver 1.6.0 A PHP client for Selenium WebDriver
guzzlehttp/guzzle 6.3.3 Guzzle is a PHP HTTP client library
guzzlehttp/promises v1.3.1 Guzzle promises library
guzzlehttp/psr7 1.4.2 PSR-7 message implementation that also provides common utility methods
jdorn/sql-formatter v1.2.17 a PHP SQL highlighting library
league/tactician v1.0.3 A small, flexible command bus. Handy for building service layers.
league/tactician-bundle v1.1.5 Bundle to integrate Tactician with Symfony projects
league/tactician-container 2.0.0 Tactician integration for any container implementing PSR-11
league/tactician-logger v0.10.0 Adds PSR-3 logging support to the Tactician command bus
myclabs/deep-copy 1.8.1 Create deep copies (clones) of your objects
ocramius/package-versions 1.3.0 Composer plugin that provides efficient querying for installed package versions (no runtime IO)
ocramius/proxy-manager 2.1.1 A library providing utilities to generate, instantiate and generally operate with Object Proxies
paragonie/random_compat v2.0.15 PHP 5.x polyfill for random_bytes() and random_int() from PHP 7
phar-io/manifest 1.0.1 Component for reading phar.io manifest information from a PHP Archive (PHAR)
phar-io/version 1.0.1 Library for handling version information and constraints
phpdocumentor/reflection-common 1.0.1 Common reflection classes used by phpdocumentor to reflect the code structure
phpdocumentor/reflection-docblock 4.3.0 With this component, a library can provide support for annotations via DocBlocks or otherwise retrieve information that is embedded in a DocBlock.
phpdocumentor/type-resolver 0.4.0
phpspec/prophecy 1.7.6 Highly opinionated mocking framework for PHP 5.3+
phpunit/php-code-coverage 6.0.5 Library that provides collection, processing, and rendering functionality for PHP code coverage information.
phpunit/php-file-iterator 1.4.5 FilterIterator implementation that filters files based on a list of suffixes.
phpunit/php-text-template 1.2.1 Simple template engine.
phpunit/php-timer 2.0.0 Utility class for timing
phpunit/php-token-stream 3.0.0 Wrapper around PHP's tokenizer extension.
phpunit/phpunit 7.1.5 The PHP Unit Testing framework.
phpunit/phpunit-mock-objects 6.1.2 Mock Object library for PHPUnit
psr/cache 1.0.1 Common interface for caching libraries
psr/container 1.0.0 Common Container Interface (PHP FIG PSR-11)
psr/http-message 1.0.1 Common interface for HTTP messages
psr/log 1.0.2 Common interface for logging libraries
psr/simple-cache 1.0.1 Common interfaces for simple caching
ramsey/uuid 3.7.3 Formerly rhumsaa/uuid. A PHP 5.4+ library for generating RFC 4122 version 1, 3, 4, and 5 universally unique identifiers (UUID).
sebastian/code-unit-reverse-lookup 1.0.1 Looks up which function or method a line of code belongs to
sebastian/comparator 3.0.1 Provides the functionality to compare PHP values for equality
sebastian/diff 3.0.1 Diff implementation
sebastian/environment 3.1.0 Provides functionality to handle HHVM/PHP environments
sebastian/exporter 3.1.0 Provides the functionality to export PHP variables for visualization
sebastian/global-state 2.0.0 Snapshotting of global state
sebastian/object-enumerator 3.0.3 Traverses array structures and object graphs to enumerate all referenced objects
sebastian/object-reflector 1.1.1 Allows reflection of object attributes, including inherited and non-public ones
sebastian/recursion-context 3.0.0 Provides functionality to recursively process PHP variables
sebastian/resource-operations 1.0.0 Provides a list of PHP built-in functions that operate on resources
sebastian/version 2.0.1 Library that helps with managing the version number of Git-hosted PHP projects
symfony/browser-kit v4.1.0 Symfony BrowserKit Component
symfony/cache v4.1.0 Symfony Cache component with PSR-6, PSR-16, and tags
symfony/config v4.1.0 Symfony Config Component
symfony/console v4.1.0 Symfony Console Component
symfony/css-selector v4.1.0 Symfony CssSelector Component
symfony/debug v4.1.0 Symfony Debug Component
symfony/dependency-injection v4.1.0 Symfony DependencyInjection Component
symfony/doctrine-bridge v4.1.0 Symfony Doctrine Bridge
symfony/dom-crawler v4.1.0 Symfony DomCrawler Component
symfony/dotenv v4.1.0 Registers environment variables from a .env file
symfony/event-dispatcher v4.1.0 Symfony EventDispatcher Component
symfony/filesystem v4.1.0 Symfony Filesystem Component
symfony/finder v4.1.0 Symfony Finder Component
symfony/flex v1.0.80
symfony/framework-bundle v4.1.0 Symfony FrameworkBundle
symfony/http-foundation v4.1.0 Symfony HttpFoundation Component
symfony/http-kernel v4.1.0 Symfony HttpKernel Component
symfony/lts dev-master 6de50b2 Enforces Long Term Supported versions of Symfony components
symfony/orm-pack v1.0.5 A pack for the Doctrine ORM
symfony/phpunit-bridge v4.1.0 Symfony PHPUnit Bridge
symfony/polyfill-mbstring v1.8.0 Symfony polyfill for the Mbstring extension
symfony/process v4.1.0 Symfony Process Component
symfony/routing v4.1.0 Symfony Routing Component
symfony/yaml v4.1.0 Symfony Yaml Component
theseer/tokenizer 1.1.0 A small library for converting tokenized PHP source code into XML and potentially other formats
webmozart/assert 1.3.0 Assertions to validate method input/output with nice error messages.
zendframework/zend-code 3.3.0 provides facilities to generate arbitrary code using an object oriented interface
zendframework/zend-eventmanager 3.2.1 Trigger and listen to events within a PHP application
And the composer.json: {
"require": {
"php": "^7.1.3",
"ext-ctype": "*",
"ext-iconv": "*",
"league/tactician-bundle": "^1.1",
"ramsey/uuid": "^3.7",
"symfony/console": "^4.1",
"symfony/flex": "^1.0",
"symfony/framework-bundle": "^4.1",
"symfony/lts": "^4@dev",
"symfony/orm-pack": "^1.0",
"symfony/yaml": "^4.1"
},
"require-dev": {
"codeception/codeception": "^2.4",
"symfony/dotenv": "^4.1",
"symfony/phpunit-bridge": "^4.1"
}
} |
Hi, we have the same problem here:
Here is the
And this is what we have in
Looking forward to some help on that topic. |
You need to use the real phpunit script instead, which is at |
Is there anything we need to do here? |
Well yes, this issue is about composer triggering the message when requiring libs relying on phpunit. @nicolas-grekas's comment solves different issue. |
The message is legit: tools should not mess up with your deps. The issue is that there is no alternative right now. At least using the real phpunit works around the incompatibility which triggers the fatal error. |
Message isn't legit: it suggests to use phpunit bridge when installing codeception, which is nonsense. Bridge isn't replacement for codeception. |
The message should be tweaked to suggest using |
We have the same issue, so the solution is to not use the phpunit bridge script but instead the normal bin/phpunit one? :) |
for me, tests are also my own code and my tests are based on phpunit. so, in my opinion, phpunit should be added in composer.json. tools are for me php-cs-fixer, phpstan, phpmd and so on. my two cents. |
If someone want, this solved me the problem.
Then execute
|
Does this stays in the won't fix or did you fix this with @greg0ire @nicolas-grekas ? |
I didn't continue working on that tool, but might if there is still a need, but apparently phpunit is starting to integrate with phpscoper: sebastianbergmann/phpunit#2015 (comment) this should fix autoloading conflict issues |
phpunit is just one tool. The general issue remains: deps of tool should not mangle one deps. phpscoper won't really help here as ppl will still continue to use composer to control the version of their tools that their apps need. |
@nicolas-grekas Any news about this "require-tool" you're talking about ? I'm hitting the same issue with Rector and investigating into the state of this issue in the PHP community. |
I have the same deprecation:
|
Hey, thanks for your report! |
@carsonbot :-) The issue is still relevant. The message was reworded in symfony/recipes#811 to:
|
I'd appreciate a solution that allows to add custom dependencies on top of the phpunit installed by |
I created composer/composer#9636 as a follow up of this issue. I'm closing here as there is nothing specific to do in Symfony. All happens at the recipe level. It'd suggest opening a PR on the recipe repo if one wants to remove the warning. I don't know if/when we'll merge it, but at least that could be the tracker. I really hope something like composer/composer#9636 will exist in the future to free us from a range of related issues. |
Symfony version(s) affected: 4
Description
When installing Codeception in Symfony 4 with
composer require "codeception/codeception" --dev
(as recommended at https://codeception.com/quickstart ), I'm getting this warning from composer:Plus this hint:
I already reported this as a possible Codeception issue, but received the answer that it's more a Symfony issue: Codeception/Codeception#4974
The text was updated successfully, but these errors were encountered: