cache-extensions
cache-extensions copied to clipboard
:package: Cache PHP extensions in GitHub Actions
Cache PHP extensions in GitHub Actions
Cache PHP extensions in GitHub Actions. This action has to be used along with shivammathur/setup-php and actions/cache GitHub Actions. It configures the environment required to cache PHP extensions. Refer to Usage section for details and example workflow.
Contents
- PHP Support
- OS/Platform Support
- Usage
- Inputs
- Workflow
- Thread Safe Setup
- License
- Contributions
- Support This Project
- Dependencies
:tada: PHP Support
| PHP Version | Stability | Release Support |
|---|---|---|
| 5.3 | Stable |
End of life |
| 5.4 | Stable |
End of life |
| 5.5 | Stable |
End of life |
| 5.6 | Stable |
End of life |
| 7.0 | Stable |
End of life |
| 7.1 | Stable |
End of life |
| 7.2 | Stable |
End of life |
| 7.3 | Stable |
End of life |
| 7.4 | Stable |
Security fixes only |
| 8.0 | Stable |
Active |
| 8.1 | Stable |
Active |
| 8.2 | Nightly |
In development |
:cloud: OS/Platform Support
| Virtual environment | YAML workflow label |
|---|---|
| Ubuntu 22.04 | ubuntu-22.04 |
| Ubuntu 20.04 | ubuntu-latest or ubuntu-20.04 |
| Ubuntu 18.04 | ubuntu-18.04 |
| Windows Server 2022 | windows-2022 |
| Windows Server 2019 | windows-latest or windows-2019 |
| macOS Big Sur 12.x | macOS-12 |
| macOS Big Sur 11.x | macos-latest or macOS-11 |
| macOS Catalina 10.15 | macOS-10.15 |
:memo: Usage
Use this GitHub Action when the extensions you are adding in setup-php are installed and take a long time to set up. If you are using extensions which have the result Installed and enabled in the logs like pecl extensions on Ubuntu or extensions which have custom support, it is recommended to use this action to cache your extensions.
Inputs
php-version (required)
- Specify the PHP version you want to set up.
- Accepts a
string. For example'8.1'. - Accepts
latestto set up the latest stable PHP version. - Accepts
nightlyto set up a nightly build from the master branch of PHP. - Accepts the format
d.x, wheredis the major version. For example5.x,7.xand8.x. - See PHP support for supported PHP versions.
extensions (required)
- Specify the extensions you want to set up.
- Accepts a
stringin csv-format. For examplembstring, xdebug, :opcache. - Extensions prefixed with
:are ignored in output cache key.
key (required)
- Specify the key to identify the cache version.
- Accepts any
string. For examplecache-v1. - Changing this would reset the cache.
See action.yml and usage below for more info.
Workflow
Cache extensions in a PHP workflow
jobs:
run:
runs-on: ${{ matrix.operating-system }}
strategy:
matrix:
operating-system: [ubuntu-latest, windows-latest, macos-latest]
php-versions: ['7.4', '8.0', '8.1']
name: PHP ${{ matrix.php-versions }} Test on ${{ matrix.operating-system }}
env:
extensions: intl, pcov
key: cache-v1 # can be any string, change to clear the extension cache.
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup cache environment
id: extcache
uses: shivammathur/cache-extensions@v1
with:
php-version: ${{ matrix.php-versions }}
extensions: ${{ env.extensions }}
key: ${{ env.key }}
- name: Cache extensions
uses: actions/cache@v2
with:
path: ${{ steps.extcache.outputs.dir }}
key: ${{ steps.extcache.outputs.key }}
restore-keys: ${{ steps.extcache.outputs.key }}
- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php-versions }}
extensions: ${{ env.extensions }}
Thread Safe Setup
If you set up both TS and NTS PHP versions on Windows in your workflow, please add ${{ env.phpts }} to key and restore-keys inputs in actions/cache step in the above workflow to avoid a conflicting cache.
- name: Cache extensions
uses: actions/cache@v2
with:
path: ${{ steps.extcache.outputs.dir }}
key: ${{ steps.extcache.outputs.key }}-${{ env.phpts }}
restore-keys: ${{ steps.extcache.outputs.key }}-${{ env.phpts }}
:scroll: License
The code and documentation in this project are under the MIT License. This project has multiple dependencies. Their licenses can be found in their respective repositories.
:+1: Contributions
Contributions are welcome! See Contributor's Guide. If you face any issues while using this or want to suggest a feature/improvement, create an issue here.
:sparkling_heart: Support This Project
If this action helped you.
- Please star the project and share it. If you blog, please share your experience of using this action.
- Please support our work by sponsoring using GitHub sponsors.