Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/brianhenryie/composer-phpstorm

Auto-creates PhpStorm Run Configurations for PHP Unit and marks folders as excluded.
https://github.com/brianhenryie/composer-phpstorm

composer phpstorm phpunit

Last synced: 3 months ago
JSON representation

Auto-creates PhpStorm Run Configurations for PHP Unit and marks folders as excluded.

Awesome Lists containing this project

README

        

[![PHPCS PSR12](https://img.shields.io/badge/PHPCS-PSR%2012-f09f47.svg)](https://www.php-fig.org/psr/psr-12/)

# Composer-PhpStorm

Auto-creates PhpStorm Run Configurations for PHP Unit, marks folders as excluded, and configures WordPress integration.

*Tested from PhpStorm 2019.3 to 2024.1.2*

## Overview

* **ExcludeFolders** marks specified folders, symlinked folders and [Mozart](https://github.com/coenjacobs/mozart) managed packages as excluded from PhpStorm code navigation and completion, by adding entries to the project's `.iml` configuration file
* **PHPUnitRunConfigurations** creates a [Run Configuration](https://www.jetbrains.com/help/phpstorm/creating-run-debug-configuration-for-tests.html) for every `phpunit.xml` found in the project (ignoring `/vendor` and `/wp-content`), by adding entries to `workspace.xml`
* **WordPress** searches for a WordPress install and enables WordPress support.

## Installation

```
composer config allow-plugins.brianhenryie/composer-phpstorm true
composer require --dev brianhenryie/composer-phpstorm
```

Optionally:

```
"extra": {
"phpstorm": {
"exclude_folders": {
"folders": [
"path/to/folder_one/from/project/base",
"path/to/folder_two/from/project/base"
],
"include_folders": [
"path/to/folder_one/from/project/base",
],
"composer-symlinks": false
}
}
}

```

## Operation

### ExcludeFolders

Folders to exclude can be specified under `extras/phpstorm/exclude_folders/folders`. These are assumed to be relative from the project root.

PhpStorm automatically adds project folders inside the vendor folder to its excluded folders list, so adding them to the `folders` list doesn't achieve the desired effect. Instead, the `vendor/vendor-name/project/src` folder should be added to the `exculde_folders/folders` list and, counter-intuitively, `vendor/vendor-name/project/src` should be added to the `exculde_folders/include_folders` list.

The Composer tool [coenjacobs/mozart](https://github.com/coenjacobs/mozart), for prefixing package namespaces, results in each class being copied, thus each classname::function having multiple implementations in PhpStorm's code completion. This tool reads the Mozart Composer configuration and excludes source folders of packages managed by Mozart.

The file source of symlinks created by [kporras07/composer-symlinks](https://github.com/kporras07/composer-symlinks) are excluded if in the project directory. This can be disabled by setting `extras/phpstorm/exclude_folders/folders` to `false` in your `composer.json`. The file souce of a symlink is not excluded if it is in the root of the project.

Inside `/.idea/project-name.iml`'s ` ` adds:

```

```

### PHPUnitRunConfigurations

The script searches the project directory for `phpunit.xml` and creates a PhpStorm Run Configuration for each one found (ignoring those under `/vendor/`), using the name `phpunit` when found in the project root folder and the folder name otherwise.

Inside `/.idea/workspace.xml`'s `` adds:

```


```

## Why?

WordPress. [I write many small plugins](https://github.com/BrianHenryIE/WordPress-Plugin-Boilerplate), this will click a few buttons for me that I don't much care for.

## TODO

* Symlinks could be searched for, then checked if they were pointing inside the project directory, rather than reading from composer.json
* Set Default Interpreter (PHP Language Level/CLI Interpreter)
* Configuration to allow excluding autodiscovered `phpunit.xml`s
* Should find subpackages of those processed by Mozart
* Set PHP language level
* Set PHPCS, CBF, ~~WordPress path~~
* Allow disabling Mozart integration
* Automatically handle `vendor-name/project` folders in exclusion list but including that folder and excluding their `src` folder.
* Should be one script and conditionally run parts based on config.
* Consider [geecu/phpstorm-configurator](https://github.com/geecu/phpstorm-configurator/)

## See Also

* [BrianHenryIE/composer-fallback-to-git](https://github.com/BrianHenryIE/composer-fallback-to-git)
* [BrianHenryIE/composer-prefer-local](https://github.com/BrianHenryIE/composer-prefer-local)

## Acknowledgements

I was waiting for MacOS Catalina to download and install. I learned how to write the Composer extension from reading [kporras07/composer-symlinks](https://github.com/kporras07/composer-symlinks).