Phpstan Phpstorm

  



Skip to end of metadataGo to start of metadata

  1. Phpstan Phpstorm Docker
  2. Phpstan For Phpstorm
  1. PHPStan plugin for PhpStorm This plugin adds dedicated functionality for PHPStanto PhpStorm. The plugin is under active development and will be bundled into PhpStorm.
  2. In PhpStorm, we’ve already annotated some internal PHP functions like parseurl with # ArrayShape, so you can benefit from the attributes right away. Fortunately, the syntax of one-line attributes is backward-compatible.
PHPFeatureWI-56627ArrayShape for params: add completion for keys in function/method calls
BugWI-52799Advanced Metadata: class::traitMethod in expectedArguments(functionFQN,...) not working
BugWI-57386Wrong string concatenation with PHP 8
UsabilityWI-57392Resolve PhpStorm attributes only to vendor folder in case of both stubs+vendor packages installed
PHP InspectionsExceptionWI-57502Dead code: CCE when processing promoted properties
PHP InterpretersExceptionWI-57965NPE on attempt to add remote interpreter using ssh connection
PHP Quality ToolsBugWI-57853Inspections not working via dockerized phpstan when project is in subdirectory
Plugin: PHPStanBugWI-57015Inspect code with enabled PHPStan inspection spawns many PHP processes, seems never to finish
Core. DebuggerBugIDEA-255769Inline watches: inline hint may stuck with Collecting Data
Core. DiagramsBugIDEA-257774'Show usages' on module dependencies diagram always shows 'No matches found'
Core. File SystemBugIDEA-256953File chooser: show WSL UNC roots with backslashes
Core. Image ViewerBugIDEA-258686No preview for WebP images in the IDE on Apple Silicon
Core. LicensingBugIDEA-253899Missing icons for disabled paid plugins in the license dialog
BugIDEA-256058I can't register my license and open plugin market place
Core. Platform APIBugIDEA-255566Collisions across Search Everywhere contributors' weights aren't detected
Core. Project SettingsBugIDEA-258722Reopening project removes 'Android' and 'Android-Gradle' facets from 'app' module
BugIDEA-257495Last facet removed from module restores after reopen
BugIDEA-257867Workspace model should survive broken cache
BugIDEA-257045Adding module groups are not working anymore
Core. Run. ConfigurationsBugIDEA-256792New run configuration show red error for Main class comes from libraries (when enabling 'Include non-project items')
BugIDEA-253019[new run config UI] Run Configuration is missing 'Use module path' checkbox after upgrade to 2020.3
Core. Run. TargetsFeatureIDEA-252713Support wizard-based SSH target creation
BugIDEA-253239Run Targets: the remote java is shown in the Application Run Configuration when the remote target is selected, but not in the Spring Boot Run Configuration
BugIDEA-257608Make Project path on target browsable in SSH target wizard
BugIDEA-257136Run Targets: Introspection for SSH target during wizard completed with errors
BugIDEA-258081Run Targets: the Next button remains disabled in the New Target: SSH dialog if the existing connection is selected using the SSH Configurations dialog invoked by browse button
BugIDEA-257610Changes in Project path and JDK path in SSH wizard are not applied
BugIDEA-256133Run Targets: new maven configuration with docker run target have duplicated name to existed configuration
BugIDEA-258066Run Targets: SSH: all maven run configurations fail on resources copying stage trying to access /project folder
BugIDEA-255466Run Targets: When create new project and new ssh target on attempt to browse jdk get 'failed to find ssh settings'
BugIDEA-258863SSH: Rsync upload fails on local/remote paths with spaces
ExceptionIDEA-257536NPE at com.jetbrains.plugins.remotesdk.target.ssh.target.wizard.SshTargetLanguageStep._init
Core. SSHCosmeticsIDEA-258310Log throwables from wrapBlockingSshCall at most once
Lang. XPath and XSLTExceptionIDEA-259818Running XSLT debugger with Saxon engine fails with exception
User InterfaceBugIDEA-257931Big Sur: Empty grey bar appears above the tool bar if opening a third project in full screen
BugIDEA-236086Find field: second line appears if a search string does not fit the filed size
BugIDEA-257810Big Sur: Empty grey line remains a project window after drag-and-drop a project tab out of the window
BugIDEA-257811Big Sur: Toolbar hides after opening a project in a separate tab
User Interface. FocusBugIDEA-244511IDE steals focus when dragging a file over its window
Version ControlUsabilityIDEA-235910Double-click behavior in Local Changes could be optional
Version Control. GitBugIDEA-253948Git Merge Dialog: manually entered branch name is not used in some cases
BugIDEA-256372Git Merge dialog: the dialog doesn't remember last used branch
BugIDEA-258364Committing a file in the ignored directory via staging area fails.
PerformanceIDEA-254138Git Rebase dialog opening takes a very long time for big project
UsabilityIDEA-256325Git Rebase: Rebase dialog clears the base field if dialog was closed without performing rebase
UsabilityIDEA-254606[Regression] Degrated expirience when working with remote branches in online and offline mode.
Version Control. GitHubBugIDEA-228590GitHub PullRequests: timeline width does not allow to see all content
BugIDEA-254431'Add Account' using OAuth shows 'Your connection is not private' error if HSTS is configured for 'localhost' for some reason
UsabilityIDEA-255031Thread reply field is too wide in timeline
TaskIDEA-244516'Share Project on GitHub' action shows old 'password or token' dialog if no GH accounts configured
TaskIDEA-244514'Create Gist' action shows old 'password or token' dialog if no GH accounts configured
Version Control. LogCosmeticsIDEA-258478Incorrect background color for file history progress
DB ConnectivityFeatureDBE-10828Do not include password to data source name for 'Data sources from URL' action
PerformanceDBE-12398Test Connection allocates memory but never frees it, when encountering UnknownHostException
UsabilityDBE-11884Make data source URL field expandable
DB DiffBugDBE-12384Problem with some schema comparisons
BugDBE-12351'Set Do nothing' option does not affect on result migration script
DB IntrospectionBugDBE-12367Athena introspection does not work after latest update
DB RefactoringFeatureDBE-12357Additional option 'purge' in drop confirmation dialog for Oracle
Data ViewsBugDBE-12255SQL Server - Wrong hierarchyid values representation
UsabilityDBE-11774Table is read-only when there is no schema qualifier (unresolved table references)
UsabilityDBE-12168No 'Submit changes immediately' option on IDEA 2020.3 ,so you must manually submit a data change.
SQL GenerationBugDBE-12303Invalid sql script in modify object for Oracle materialized view
No subsystemBugWEB-48777JavaScript 'forof' template: unstable order of elements in completion / suggestion
BugWEB-48856Highlights with ERROR severity cancels SYMBOL_TYPE syntax highlighting in injections
TaskWEB-49047Updated the Getting Started link under the Learn WebStorm tab
CSSBugWEB-48210Valid value 'break-spaces' of CSS property 'white-space' is highlighted as error.
BugWEB-49011TailwindCSS completion/css-preview on hover doesn't work when using breakpoint prefixes with utilities
BugWEB-48207CSS parsing error when using negative function arguments in min()/max() functions
BugWEB-48695Don't report 'Redundant measure unit' error for css-grid 'fr'
BugWEB-45868Parsing error when using DOM element selectors CSS injection if CSS dialect is set to 'PostCSS'
DartFeatureWEB-25687Add 'VM Options' field to the Dart Test run configuration editor.
BugWEB-43142Contents of typed_data does not show up in the debugger
UsabilityWEB-48264'Dart Command Line App' and 'Dart Test' run configurations should start Observatory only when debugging
DebuggerBugWEB-48918Mocha: Debugger doesn't stop on breakpoints when use WSL interpreter
BugWEB-46619WSL debugging is not working while using npm run configuration
BugWEB-48816Chrome custom user data gets cleared on IDE restart
HTMLBugWEB-49051Adding a new JSX tag causes simultaneous editing of non-related closing tag
JavaScriptBugWEB-48606Incorrect type definition in 2020.3
BugWEB-49037RejectedExecutionException when comment a piece of code
BugWEB-49003Deadlock in JSResolvedTypeIdCache
BugWEB-48976Comma expression without parentheses inside a string interpolation expression marked as a syntax error
BugWEB-42605JSX fragment closing tag with a space breaks syntax highlighting
BugWEB-48719Having a colon in JSX results in a syntax error
JavaScript. FrameworksFeatureWEB-43318No code completion in dynamically evaluated classname attribute value
FeatureWEB-44150Vue: support type inference for component props within template
BugWEB-48837Nuxt: Issue auto-importing components from paths ending with '/'
BugWEB-48899webpack config analysis is infinite if node_modules were deleted
JavaScript. RefactoringTaskWEB-48813Support `RefactoringEventListener` in JS refactorings
TypeScriptBugWEB-48741'a module cannot have multiple default exports' with overloaded default function
BugWEB-48114When changing a method signature in TypeScript, the caller code is not updated
BugWEB-48675TS 4.1 template string literal type isn't being fully computed for switch statements ('Possibly infinite type substitution' error)
Unit TestsBugWEB-48835.../null error when trying to run cucumber tests
BugWEB-48931Running cucumber-js 7.0 test generates error 'formatter.finished is not a function'/

PhpStorm is a fast and exceptionally smart IDE tailored for PHP developers. PhpStorm truly understands your code. It provides intelligent coding assistance and refactoring capabilities, highlights and fixes errors on the fly, and allows you to debug and test your code easily. But that’s not all!

In addition to built-in coding assistance, PhpStorm provides checking the source code through integration with the PHP CS Fixer tool, which detects coding standards problems in your code.

To use PHP CS Fixer from PhpStorm instead of command line, you need to register it in PhpStorm and configure it as a PhpStorm code inspection. Once installed and enabled in PhpStorm, the tool is available in any opened PHP file, and no additional steps are required to launch it. The on-the-fly code check is activated upon every update in the file thus making it easy to get rid of discovered problems.

Errors and warnings reported by PHP CS Fixer on-the-fly are displayed as popup messages. When the tool is run in the batch mode, the errors and warnings are displayed in the Inspection Results tool window. Each message has the PHP CS Fixer prefix to distinguish it from PhpStorm internal inspections.

Phpstan Phpstorm Docker

Phpstan for phpstorm

You can have predefined rules applied or define your own custom set of rules.

Prerequisites

Prior to integrating PHP CS Fixer in PhpStorm, make sure the following prerequisites are met:

  • You are working with PHP CS Fixer version 2.8.0 and later.

  • The directory containing the PHP engine executable must be added to the system path. This allows code quality tool scripts execute calls to the system-wide PHP engine.

  • For Docker Compose-based remote interpreters, make sure to use exec mode to avoid spawning additional containers.

    1. In the Settings/Preferences dialog Ctrl+Alt+S, go to PHP.

    2. On the PHP page that opens, click next to the CLI Interpreter list.

    3. In the CLI Interpreters dialog that opens, set the Lifecycle mode for the selected interpreter to Connect to existing container ('docker-compose exec').

Install and configure PHP CS Fixer

PHP CS Fixer scripts can be used as local scripts, the scripts associated with PHP interpreters, or scripts declared as project dependencies and installed via Composer, which is the preferable and recommended way.

Install PHP CS Fixer with Composer

Before you start, make sure Composer is installed on your machine and initialized in the current project as described in Composer dependency manager.

When you install PHP CS Fixer with Composer, PhpStorm automatically downloads the necessary scripts, registers them in the IDE, and, optionally, enables and configures the corresponding code inspection.

  1. Inside composer.json, add the friendsofphp/php-cs-fixer dependency record to the require or require-dev section. Press Ctrl+Space to get code completion for the package name and version.

  2. Do one of the following:

    • Click the Install shortcut link on top of the editor panel.

    • If the Non-installed Composer packages inspection is enabled, PhpStorm will highlight the declared dependencies that are not currently installed. Press Alt+Enter and select whether you want to install a specific dependency or all dependencies at once.

Click next to the package record in the composer.json editor gutter to jump to the corresponding Settings/Preferences page and configure PHP CS Fixer manually.

Reset PHP CS Fixer configuration

After PHP CS Fixer is initially configured, further modifications in composer.json will not affect the inspection configuration. To apply newer changes, reset the PHP CS Fixer configuration.

Phpstorm
  1. In the Settings/Preferences dialog Ctrl+Alt+S, navigate to PHP | Quality Tools.

  2. On the Quality Tools page that opens, expand the PHP CS Fixer area and click next to the Configuration list.

  3. In the PHP CS Fixer dialog that opens, empty the PHP CS Fixer path field.

  4. Update the project Composer dependencies by clicking Update on top of the composer.json editor panel. See Update dependencies for details.

PhpStorm will perform the PHP CS Fixer configuration anew and thus apply the changes in composer.json.

Configure PHP CS Fixer manually

You can use the manually downloaded local PHP code quality tool scripts or scripts associated with PHP interpreters. There can be a number of local and remote PHP interpreters, the one specified on the PHP page of the Settings/Preferences dialog is considered Project Default. Learn more about configuring PHP interpreters in Configure remote PHP interpreters or in Configure local PHP interpreters.

Choose a PHP CS Fixer script to use

  1. In the Settings/Preferences dialog Ctrl+Alt+S, navigate to PHP | Quality Tools.

  2. On the Quality Tools page that opens, expand the PHP CS Fixer area. From the Configuration list, choose the PHP CS Fixer script:

    • To use the script associated with a specific remote PHP interpreter, choose the name of this interpreter.

    • To use a local script, choose Local. In this case the local PHP CS Fixer will be executed no matter which PHP interpreter - local or remote - is used in the project. Note that there can be only one Local configuration for PHP CS Fixer because PhpStorm runs a script (php-cs-fixer.bat for Windows or php-cs-fixer for Linux and macOS) that contains a path to a PHP engine.

    • To use the script associated with the default project interpreter, that is, the one chosen on the PHP page of the Settings/Preferences dialog, choose By default project interpreter.

Configure a local PHP CS Fixer script

  1. Download and install the PHP CS Fixer scripts.

    To check the PHP CS Fixer installation, switch to the installation directory and run the following command:

    If the tool is available, you will get a message in the following format:

    PHP CS Fixer 2.13.0 Yogi's BBQ by Fabien Potencier and Dariusz Ruminski

    To have code checked against your own custom coding standard, create it. Store the rules and the .php_cs or php_cs.dist file that points to them in the rulesets root directory.

  2. Register the local PHP CS Fixer script in PhpStorm:

    • In the Settings/Preferences dialog Ctrl+Alt+S, navigate to PHP | Quality Tools.

    • On the Quality Tools page that opens, expand the PHP CS Fixer area and click next to the Configuration list.

    • In the PHP CS Fixer dialog that opens, specify the location of the php-cs-fixer.bat or php-cs-fixer PHP CS Fixer executable in the PHP CS Fixer path field. Type the path manually or click and select the relevant folder in the dialog that opens.

      To check that the specified path to php-cs-fixer.bat or php-cs-fixer ensures interaction between PhpStorm and PHP CS Fixer, that is, the tool can be launched from PhpStorm and PhpStorm will receive problem reports from it, click the Validate button. This validation is equal to running the php-cs-fixer --version command. If validation passes successfully, PhpStorm displays the information on the detected PHP CS Fixer version.

  3. If necessary, in the Tool process timeout field, specify how long you want PhpStorm to wait for a result from PHP CS Fixer, whereupon the process is terminated to prevent excessive CPU and memory usage.

Configure a PHP CS Fixer script associated with a PHP interpreter

  1. In the Settings/Preferences dialog Ctrl+Alt+S, navigate to PHP | Quality Tools.

  2. On the Quality Tools page that opens, expand the PHP CS Fixer area and click next to the Configuration list. The PHP CS Fixer dialog opens showing the list of all the configured PHP CS Fixer scripts in the left-hand pane, one of them is of the type Local and others are named after the PHP interpreters with which the scripts are associated.

  3. Click on the toolbar. In the PHP CS Fixer by Remote Interpreter dialog that opens, choose the remote PHP interpreter to use the associated script from. If the list does not contain a relevant interpreter, click and configure a remote interpreter in the CLI Interpreters dialog as described in Configure remote PHP interpreters.

    When you click OK, PhpStorm brings you back to the PHP CS Fixer dialog where the new PHP CS Fixer configuration is added to the list and the right-hand pane shows the chosen remote PHP interpreter, the path to the PHP CS Fixer associated with it, and the advanced PHP CS Fixer options.

  4. If necessary, in the Tool process timeout field, specify how long you want PhpStorm to wait for a result from PHP CS Fixer, whereupon the process is terminated to prevent excessive CPU and memory usage.

Configure PHP CS Fixer as a PhpStorm inspection

Configure the PHP CS Fixer inspection with Composer

You can include the information on the default and custom PHP CS Fixer rulesets inside the scripts section of composer.json. When you install or update project dependencies, the specified rulesets will be detected and the PHP CS Fixer validation inspection will be enabled automatically.

If no ruleset is specified in the scripts section of composer.json, PhpStorm will additionally check the project root to locate the ruleset with the .php_cs or .php_cs.dist default name. If the file is present, it will be automatically selected as the inspection's Custom ruleset.

  • In the scripts section of composer.json, add the php-cs-fixer PHP CS Fixer launch command into one of the leaf elements.

    Provide the --rules argument to denote the coding standard used. For example, adding the following record will set the coding standard to PSR1:

    'scripts': { 'php-cs-fixer': 'php-cs-fixer --rules=@PSR1' }

    Alternatively, provide the --config argument and the path to the ruleset file, which will set the coding standard to Custom:

    'scripts': { 'php-cs-fixer': 'php-cs-fixer --config=./.php_cs' }

After PHP CS Fixer is initially configured, further modifications in composer.json will not affect the inspection configuration. To apply newer changes, reset the PHP CS Fixer configuration on the PHP | Quality Tools page of the Settings/Preferences dialog Ctrl+Alt+S and update project dependencies.

Configure the PHP CS Fixer inspection manually

  1. In the Settings/Preferences dialog Ctrl+Alt+S, click Inspections under Editor.

  2. On the Inspections page that opens, expand the PHP | Quality Tools node and select the checkbox next to PHP CS Fixer validation.

    If you have installed PHP CS Fixer with Composer but the corresponding inspection is currently disabled, PhpStorm highlights its record in composer.json. Press Alt+Enter and use the provided Enable inspection quick-fix to enable the inspection and open the Inspections page.

  3. On the right-hand pane of the page, configure the PHP CS Fixer tool using the controls in the Options area:

    1. From the Severity list, choose the severity degree for the PHP CS Fixer inspection. The selected value determines how serious the detected discrepancies will be treated by PhpStorm and presented in the inspection results.

    2. From the Scope list, choose the scope to limit the inspection application to.

    3. To allow risky rules, that is, the rules that can change code behavior, select the Allow risky rules for built-in rulesets checkbox. By default, risky rules are not allowed.

    4. Appoint the coding standard to apply.

      • To use one of the predefined coding standards, select it the Coding standard list, appoint the coding style to check your code against. The list contains all the coding standards declared inside the main php-cs-fixer directory structure.

      • To have your code checked against your own previously defined coding standard, choose Custom. Click Browse and in the Custom Coding Standard dialog that opens, specify the path to the .php_cs or .php_cs.dist file for your own coding standard in the Path to ruleset field. Type the path manually or click Browse and choose the relevant folder in the dialog that opens.

Share a custom coding style with the team

  1. Put the root directory of your coding standard under the project root.

  2. Configure PHP CS Fixer as a PhpStorm inspection.

  3. Appoint your coding standard.

  4. Make sure that a project profile is selected at the top of the Inspections page. Such profiles are saved in a particular project's .idea directory (for example, $PROJECT_DIR$/.idea/inspectionProfiles ). See Configure profiles for details.

  5. On the Version Control page of the Settings/Preferences dialog, make sure that the .idea directory is put under version control.

Run PHP CS Fixer in the batch mode

Rules

Phpstan For Phpstorm

  1. From the main menu, select Code | Inspect code.

  2. Select the inspection profile from the list, or click to configure a new profile in the Inspections dialog that opens. You can also click to check, which fixes will be applied and make sure that the PHP CS Fixer validation inspection is enabled.

  3. View the inspection results in the Inspection results tool window. Errors and warnings reported by PHP CS Fixer are prefixed with PHP CS Fixer to distinguish them from PhpStorm internal inspections.

Exclude files from PHP CS Fixer inspection

When waiting for PHP CS Fixer response exceeds the limit specified in the Tool process timeout field in the PHP CS Fixer dialog, PhpStorm suggests adding the file to the ignore list.

  1. In the Settings/Preferences dialog Ctrl+Alt+S, navigate to PHP | Quality Tools.

  2. On the Quality Tools page that opens, expand the PHP CS Fixer area and click the Show ignored files link.

    • To add a file, click and locate the desired file in the dialog that opens.

    • To delete a file from the list and have PHP CS Fixer process it again, select the file and click .

    • To remove all the files from the list, click .