setup-php/README.md

193 lines
7.4 KiB
Markdown
Raw Normal View History

<p align="center">
<a href="https://github.com/marketplace/actions/setup-php-action" target="_blank">
<img src="https://repository-images.githubusercontent.com/206578964/e0a18480-dc65-11e9-8dd3-b9ffbf5575fe" alt="Setup PHP in GitHub Actions" width="400">
</a>
</p>
# Setup PHP in GitHub Actions
2019-09-06 07:18:51 +07:00
<p align="left">
<a href="https://github.com/shivammathur/setup-php"><img alt="GitHub Actions status" src="https://github.com/shivammathur/setup-php/workflows/Main%20workflow/badge.svg"></a>
2019-10-05 08:14:08 +07:00
<a href="https://codecov.io/gh/shivammathur/setup-php"><img alt="Codecov Code Coverage" src="https://codecov.io/gh/shivammathur/setup-php/branch/master/graph/badge.svg"></a>
<a href="https://github.com/shivammathur/setup-php/blob/master/LICENSE"><img alt="LICENSE" src="https://img.shields.io/badge/license-MIT-428f7e.svg"></a>
<a href="#tada-php-support"><img alt="PHP Versions Supported" src="https://img.shields.io/badge/php-%3E%3D%205.6-8892BF.svg"></a>
<a href="https://www.patreon.com/shivammathur"><img alt="Support me on Patreon" src="https://shivammathur.com/badges/patreon.svg"></a> <a href="https://www.paypal.me/shivammathur"><img alt="Support me on PayPal" src="https://shivammathur.com/badges/paypal.svg"></a>
<a href="https://www.codementor.io/shivammathur?utm_source=github&utm_medium=button&utm_term=shivammathur&utm_campaign=github"><img alt="Contact me on Codementor" src="https://cdn.codementor.io/badges/contact_me_github.svg"></a>
2019-09-06 07:18:51 +07:00
</p>
2019-10-08 19:42:54 +07:00
Setup PHP with required extensions, php.ini configuration and composer in [GitHub Actions](https://github.com/features/actions). This action can be added as a step in your action workflow and it will setup the PHP environment you need to test your application. Refer to [Usage](#memo-usage) section and [examples](#examples) to see how to use this.
## :tada: PHP Support
2019-09-06 07:18:51 +07:00
|PHP Version|Stability|Release Support|
|--- |--- |--- |
|5.6|`Stable`|`End of life`|
|7.0|`Stable`|`End of life`|
|7.1|`Stable`|`Security fixes only`|
|7.2|`Stable`|`Active`|
|7.3|`Stable`|`Active`|
2019-10-08 19:42:54 +07:00
|7.4|`RC3`|`Active`|
2019-09-09 07:11:17 +07:00
**Note:** PHP 7.4 is currently in development, do not use in production/release branches.
2019-09-06 07:40:52 +07:00
## :cloud: OS/Platform Support
|Virtual environment|matrix.operating-system|
|--- |--- |
|Windows Server 2019|`windows-latest` or `windows-2019`|
|Windows Server 2016 R2|`windows-2016`|
|Ubuntu 18.04|`ubuntu-latest` or `ubuntu-18.04`|
|Ubuntu 16.04|`ubuntu-16.04`|
|macOS X Mojave 10.14|`macOS-latest` or `macOS-10.14`|
## :wrench: PHP Extension Support
- On `ubuntu` extensions which have the package in apt are installed.
- On `windows` and `macOS` PECL extensions are installed.
2019-09-07 19:31:50 +07:00
- Extensions which are installed along with PHP if specified are enabled.
- Extensions which cannot be installed gracefully leave an error message in the logs, the action is not interrupted.
2019-09-07 19:31:50 +07:00
## :signal_strength: Coverage support
2019-10-05 16:30:00 +07:00
### Xdebug
Specify `coverage: xdebug` to use `Xdebug`.
Runs on all [PHP versions supported](#tada-php-support)
2019-10-08 19:42:54 +07:00
```yaml
uses: shivammathur/setup-php@master
with:
2019-10-08 19:42:54 +07:00
php-version: '7.3'
coverage: xdebug
```
2019-10-05 16:30:00 +07:00
### PCOV
Specify `coverage: pcov` to use `PCOV`. `PCOV` is way faster than `Xdebug`.
For `pcov.directory` to be other than `src`, `lib` or, `app`, specify it using the `ini-values-csv` input.
`PCOV` needs `PHPUnit >= 8.0` and `PHP >= 7.1`, `PHPUnit` needs `PHP >= 7.2`. So use `PHP >= 7.2` with `PCOV`
2019-10-08 19:42:54 +07:00
```yaml
uses: shivammathur/setup-php@master
with:
2019-10-08 19:42:54 +07:00
php-version: '7.3'
ini-values-csv: pcov.directory=api #optional, see above for usage.
coverage: pcov
```
2019-10-05 16:30:00 +07:00
### Disable coverage
Specify `coverage: none` to disable both `Xdebug` and `PCOV`.
2019-10-08 19:42:54 +07:00
```yaml
2019-10-05 16:30:00 +07:00
uses: shivammathur/setup-php@master
with:
2019-10-08 19:42:54 +07:00
php-version: '7.3'
2019-10-05 16:30:00 +07:00
coverage: none
```
## :memo: Usage
2019-09-06 07:18:51 +07:00
Inputs supported by this GitHub Action.
2019-09-06 07:18:51 +07:00
- php-version `required`
- extension-csv `optional`
- ini-values-csv `optional`
- coverage `optional`
2019-10-08 19:42:54 +07:00
See [action.yml](action.yml) and usage below for more info.
### Basic Usage
2019-09-06 07:18:51 +07:00
```yaml
steps:
- name: Checkout
uses: actions/checkout@master
- name: Installing PHP
uses: shivammathur/setup-php@master
with:
2019-10-08 19:42:54 +07:00
php-version: '7.3'
extension-csv: mbstring, xdebug #optional
2019-10-08 19:42:54 +07:00
ini-values-csv: post_max_size=256M, short_open_tag=On #optional
coverage: xdebug #optional
2019-09-06 07:18:51 +07:00
- name: Check PHP Version
run: php -v
- name: Check Composer Version
run: composer -V
2019-09-07 19:31:50 +07:00
- name: Check PHP Extensions
run: php -m
2019-09-06 07:18:51 +07:00
```
### Matrix Testing
2019-09-06 07:18:51 +07:00
```yaml
jobs:
run:
runs-on: ${{ matrix.operating-system }}
strategy:
max-parallel: 15
matrix:
operating-system: [ubuntu-latest, windows-latest, macOS-latest]
php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3']
2019-09-06 08:52:50 +07:00
name: PHP ${{ matrix.php-versions }} Test on ${{ matrix.operating-system }}
2019-09-06 07:18:51 +07:00
steps:
- name: Checkout
uses: actions/checkout@master
- name: Install PHP
uses: shivammathur/setup-php@master
2019-09-06 07:18:51 +07:00
with:
php-version: ${{ matrix.php-versions }}
extension-csv: mbstring, xdebug #optional
2019-10-08 19:42:54 +07:00
ini-values-csv: post_max_size=256M, short_open_tag=On #optional
coverage: xdebug #optional
2019-09-06 07:18:51 +07:00
- name: Check PHP Version
run: php -v
2019-09-07 19:31:50 +07:00
- name: Check Composer Version
2019-09-08 10:56:13 +07:00
run: composer -V
2019-09-07 19:31:50 +07:00
- name: Check PHP Extensions
run: php -m
2019-09-06 07:18:51 +07:00
```
2019-10-03 17:43:34 +07:00
### Examples
Examples for setting up this GitHub Action with different PHP Frameworks/Packages.
2019-10-03 17:43:34 +07:00
2019-10-08 19:42:54 +07:00
|Framework/Package|Workflow|
|--- |--- |
|CodeIgniter|[codeigniter.yml](./examples/codeigniter.yml)|
|Laravel `MySQL` `Redis`|[laravel-mysql.yml](./examples/laravel-mysql.yml)|
|Laravel `PostgreSQL` `Redis`|[laravel-postgres.yml](./examples/laravel-postgres.yml)|
|Laravel|[laravel.yml](./examples/laravel.yml)|
|Slim Framework|[slim-framework.yml](./examples/slim-framework.yml)|
|Symfony `MySQL`|[symfony-mysql.yml](./examples/symfony-mysql.yml)|
|Symfony `PostgreSQL`|[symfony-postgres.yml](./examples/symfony-postgres.yml)|
|Yii2 Starter Kit `MySQL`|[yii2-mysql.yml](./examples/yii2-mysql.yml)|
|Yii2 Starter Kit `PostgreSQL`|[yii2-postgres.yml](./examples/yii2-postgres.yml)|
|Zend Framework|[zend-framework.yml](./examples/zend-framework.yml)|
2019-10-03 17:43:34 +07:00
## :scroll: License
The scripts and documentation in this project are released under the [MIT License](LICENSE). This project has multiple [dependencies](https://github.com/shivammathur/setup-php/network/dependencies) and their licenses can be found in their respective repositories.
## :+1: Contributions
2019-09-06 07:18:51 +07:00
2019-09-24 17:43:22 +07:00
Contributions are welcome! See [Contributor's Guide](.github/CONTRIBUTING.md).
2019-09-06 07:18:51 +07:00
## :sparkling_heart: Support this project
- Please star the project and share it among your developer friends.
- Consider supporting on <a href="https://www.patreon.com/shivammathur"><img alt="Support me on Patreon" src="https://shivammathur.com/badges/patreon.svg"></a> and <a href="https://www.paypal.me/shivammathur"><img alt="Support me on Paypal" src="https://shivammathur.com/badges/paypal.svg"></a>.
## :bookmark: This action uses the following works
- [powershell-phpmanager](https://github.com/mlocati/powershell-phpmanager)
- [Homebrew](https://brew.sh/)
- [ppa:ondrej/php](https://launchpad.net/~ondrej/+archive/ubuntu/php)
- [exolnet/homebrew-deprecated](https://github.com/eXolnet/homebrew-deprecated)
2019-09-09 07:11:17 +07:00
- [phpbrew](https://github.com/phpbrew/phpbrew)
## :bookmark_tabs: Further Reading
2019-09-06 07:18:51 +07:00
- [About GitHub Actions](https://github.com/features/actions)
- [GitHub Actions Syntax](https://help.github.com/en/articles/workflow-syntax-for-github-actions)
- [Other Awesome Actions](https://github.com/sdras/awesome-actions)