mirror of
https://github.com/shivammathur/setup-php.git
synced 2025-07-04 22:23:16 +07:00
Compare commits
95 Commits
Author | SHA1 | Date | |
---|---|---|---|
4c5c122aa6 | |||
bee5abe269 | |||
220d0c24c7 | |||
2f5c2edb22 | |||
721e4c3367 | |||
2f2a90e464 | |||
81a06ff6ed | |||
dfc02c42d9 | |||
ac7d3d7f84 | |||
874e5099b0 | |||
4a3337d069 | |||
123f6df529 | |||
341cf69e13 | |||
f7b503e36b | |||
beaceb0089 | |||
03509eca9b | |||
2c9c274411 | |||
1c85db7f9e | |||
d259dd49a2 | |||
ea20ae1fbd | |||
383c74bb06 | |||
b4593b7df0 | |||
9b92c9db92 | |||
a357b6a054 | |||
0bc2f7ce96 | |||
e2e76ea34f | |||
719018955c | |||
4c903565c9 | |||
fc60088a95 | |||
a7f90656b3 | |||
0cd4af837e | |||
96e47f9be7 | |||
eca40cad4d | |||
4e864eae3b | |||
49a0bad962 | |||
b971d8f4ad | |||
fca0924fa9 | |||
8dfe214356 | |||
f2d6820ca2 | |||
705c2a5785 | |||
5e33fdb0d9 | |||
dab978c436 | |||
2cc925b655 | |||
4ce6f3c3df | |||
b3bf0f3990 | |||
8426bf89fd | |||
d7c3e33a96 | |||
17ef667e04 | |||
295b5da700 | |||
e820a5d75b | |||
2c8682d5e6 | |||
87993cd853 | |||
e0dd9c9560 | |||
28853c9f3b | |||
608ad1a0cf | |||
257e4c088d | |||
7b145b5fae | |||
253459691c | |||
cb5db3f888 | |||
52d2b3b70b | |||
fa5fbefff9 | |||
256b466cc4 | |||
57f4a60e24 | |||
2e289f30e2 | |||
bc0d607611 | |||
1fa3ba1b16 | |||
d8d1da5d6d | |||
094bc8ae17 | |||
48aac87d46 | |||
31971c78cd | |||
13760f5b16 | |||
c644f654ce | |||
9adda12e86 | |||
6db8a6c378 | |||
a34eeedd37 | |||
35bc046b26 | |||
64e9bb0e79 | |||
19a01870e7 | |||
c4560dd084 | |||
0313f578ce | |||
d068c17d9e | |||
8eebeae48a | |||
da9dadf09c | |||
e06e40278f | |||
6473b1c04c | |||
7694412cb0 | |||
e990e98a54 | |||
b2d037d560 | |||
4beeea41b4 | |||
8e80635955 | |||
c8837583fc | |||
bb36513e49 | |||
5402397d9f | |||
f6b4601c63 | |||
ed62711289 |
6
.github/FUNDING.yml
vendored
6
.github/FUNDING.yml
vendored
@ -1,7 +1,3 @@
|
|||||||
# These are supported funding model platforms
|
# These are supported funding model platforms
|
||||||
|
|
||||||
open_collective: setup-php
|
github: shivammathur
|
||||||
tidelift: "npm/setup-php"
|
|
||||||
community_bridge: setup-php
|
|
||||||
patreon: shivammathur
|
|
||||||
custom: https://www.paypal.me/shivammathur
|
|
||||||
|
3
.github/SECURITY.md
vendored
3
.github/SECURITY.md
vendored
@ -7,7 +7,7 @@ The following versions of this project are supported for security updates.
|
|||||||
| Version | Supported |
|
| Version | Supported |
|
||||||
| ------- | ------------------ |
|
| ------- | ------------------ |
|
||||||
| 1.11.x | :white_check_mark: |
|
| 1.11.x | :white_check_mark: |
|
||||||
| 2.11.x | :white_check_mark: |
|
| 2.14.x | :white_check_mark: |
|
||||||
|
|
||||||
## Supported PHP Versions
|
## Supported PHP Versions
|
||||||
|
|
||||||
@ -18,6 +18,7 @@ This security policy only applies to the latest patches of the following PHP ver
|
|||||||
| 7.3 | :white_check_mark: |
|
| 7.3 | :white_check_mark: |
|
||||||
| 7.4 | :white_check_mark: |
|
| 7.4 | :white_check_mark: |
|
||||||
| 8.0 | :white_check_mark: |
|
| 8.0 | :white_check_mark: |
|
||||||
|
| 8.1 | :white_check_mark: |
|
||||||
|
|
||||||
## Reporting a Vulnerability
|
## Reporting a Vulnerability
|
||||||
|
|
||||||
|
4
.github/workflows/docs.yml
vendored
4
.github/workflows/docs.yml
vendored
@ -11,7 +11,7 @@ jobs:
|
|||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
operating-system: [ubuntu-20.04, ubuntu-18.04, windows-2019, macos-10.15]
|
operating-system: [ubuntu-20.04, ubuntu-18.04, windows-2019, macos-10.15]
|
||||||
php-versions: ['5.3', '5.4', '5.5', '5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1']
|
php-versions: ['5.3', '5.4', '5.5', '5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1', '8.2']
|
||||||
steps:
|
steps:
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
@ -61,7 +61,7 @@ jobs:
|
|||||||
git config --local user.name "${{ github.repository_owner }}"
|
git config --local user.name "${{ github.repository_owner }}"
|
||||||
for os in ubuntu-20.04 ubuntu-18.04 windows-2019 macos-10.15 macos-11; do
|
for os in ubuntu-20.04 ubuntu-18.04 windows-2019 macos-10.15 macos-11; do
|
||||||
echo "These are extensions which are loaded by default on the following PHP versions. More extensions which are available as packages and available on pecl are supported by setup-php. Refer to [php extension support](https://github.com/shivammathur/setup-php#heavy_plus_sign-php-extension-support) for more details." > Php-extensions-loaded-on-"$os".md
|
echo "These are extensions which are loaded by default on the following PHP versions. More extensions which are available as packages and available on pecl are supported by setup-php. Refer to [php extension support](https://github.com/shivammathur/setup-php#heavy_plus_sign-php-extension-support) for more details." > Php-extensions-loaded-on-"$os".md
|
||||||
for version in 5.3 5.4 5.5 5.6 7.0 7.1 7.2 7.3 7.4 8.0 8.1; do
|
for version in 5.3 5.4 5.5 5.6 7.0 7.1 7.2 7.3 7.4 8.0 8.1 8.2; do
|
||||||
if [ "$os" = "macos-11" ]; then
|
if [ "$os" = "macos-11" ]; then
|
||||||
cat lists/php"$version"-macos-10.15.md >> Php-extensions-loaded-on-"$os".md
|
cat lists/php"$version"-macos-10.15.md >> Php-extensions-loaded-on-"$os".md
|
||||||
else
|
else
|
||||||
|
62
.github/workflows/node-release.yml
vendored
Normal file
62
.github/workflows/node-release.yml
vendored
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
name: Publish Package
|
||||||
|
on:
|
||||||
|
release:
|
||||||
|
types: [created]
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
skip:
|
||||||
|
description: Skip release to repository
|
||||||
|
required: false
|
||||||
|
tag:
|
||||||
|
description: Tag name
|
||||||
|
required: true
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
packages: write
|
||||||
|
steps:
|
||||||
|
- name: Harden Runner
|
||||||
|
uses: step-security/harden-runner@main
|
||||||
|
|
||||||
|
- name: Checkout release
|
||||||
|
if: github.event_name != 'workflow_dispatch'
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Checkout tag
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
if: github.event_name == 'workflow_dispatch'
|
||||||
|
with:
|
||||||
|
ref: ${{ github.event.inputs.tag }}
|
||||||
|
|
||||||
|
- name: Setup Node.js
|
||||||
|
uses: actions/setup-node@v2
|
||||||
|
with:
|
||||||
|
node-version: '14.x'
|
||||||
|
registry-url: https://registry.npmjs.org
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: npm install
|
||||||
|
|
||||||
|
- name: Publish to NPM
|
||||||
|
if: "!contains(github.event.inputs.skip, 'skip-npm')"
|
||||||
|
run: npm publish --access public
|
||||||
|
env:
|
||||||
|
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
|
||||||
|
|
||||||
|
- name: Change to GitHub Packages registry
|
||||||
|
uses: actions/setup-node@v2
|
||||||
|
with:
|
||||||
|
registry-url: https://npm.pkg.github.com
|
||||||
|
scope: '@shivammathur'
|
||||||
|
|
||||||
|
- name: Patch package.json
|
||||||
|
run: |
|
||||||
|
sed -i 's#"name": "#"name": "@shivammathur/#' package.json
|
||||||
|
|
||||||
|
- name: Publish to GitHub Packages
|
||||||
|
if: "!contains(github.event.inputs.skip, 'skip-github-packages')"
|
||||||
|
run: npm publish
|
||||||
|
env:
|
||||||
|
NODE_AUTH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
14
.github/workflows/node-workflow.yml
vendored
14
.github/workflows/node-workflow.yml
vendored
@ -25,6 +25,20 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
operating-system: [ubuntu-latest, windows-latest, macos-latest]
|
operating-system: [ubuntu-latest, windows-latest, macos-latest]
|
||||||
steps:
|
steps:
|
||||||
|
- name: Harden Runner
|
||||||
|
if: runner.os == 'Linux'
|
||||||
|
uses: step-security/harden-runner@main
|
||||||
|
with:
|
||||||
|
allowed-endpoints:
|
||||||
|
beta.api.stepsecurity.io.:443
|
||||||
|
codecov.io.:443
|
||||||
|
github.com.:443
|
||||||
|
nodejs.org.:443
|
||||||
|
raw.githubusercontent.com.:443
|
||||||
|
registry.npmjs.org.:443
|
||||||
|
setup-php.com.:443
|
||||||
|
storage.googleapis.com.:443
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
4
.github/workflows/workflow.yml
vendored
4
.github/workflows/workflow.yml
vendored
@ -25,10 +25,10 @@ jobs:
|
|||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
operating-system: [ubuntu-20.04, ubuntu-18.04, windows-latest, macos-latest]
|
operating-system: [ubuntu-20.04, ubuntu-18.04, windows-latest, macos-latest]
|
||||||
php-versions: ['5.3', '5.4', '5.5', '5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1']
|
php-versions: ['5.3', '5.4', '5.5', '5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0', '8.1', '8.2']
|
||||||
env:
|
env:
|
||||||
extensions: xml, opcache, xdebug, pcov
|
extensions: xml, opcache, xdebug, pcov
|
||||||
key: cache-v3
|
key: cache-v5
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
|
147
README.md
147
README.md
@ -10,7 +10,8 @@
|
|||||||
<a href="https://github.com/shivammathur/setup-php" title="GitHub action to setup PHP"><img alt="GitHub Actions status" src="https://github.com/shivammathur/setup-php/workflows/Main%20workflow/badge.svg"></a>
|
<a href="https://github.com/shivammathur/setup-php" title="GitHub action to setup PHP"><img alt="GitHub Actions status" src="https://github.com/shivammathur/setup-php/workflows/Main%20workflow/badge.svg"></a>
|
||||||
<a href="https://codecov.io/gh/shivammathur/setup-php" title="Code coverage"><img alt="Codecov Code Coverage" src="https://img.shields.io/codecov/c/github/shivammathur/setup-php?logo=codecov"></a>
|
<a href="https://codecov.io/gh/shivammathur/setup-php" title="Code coverage"><img alt="Codecov Code Coverage" src="https://img.shields.io/codecov/c/github/shivammathur/setup-php?logo=codecov"></a>
|
||||||
<a href="https://github.com/shivammathur/setup-php/blob/master/LICENSE" title="license"><img alt="LICENSE" src="https://img.shields.io/badge/license-MIT-428f7e.svg?logo=open%20source%20initiative&logoColor=white&labelColor=555555"></a>
|
<a href="https://github.com/shivammathur/setup-php/blob/master/LICENSE" title="license"><img alt="LICENSE" src="https://img.shields.io/badge/license-MIT-428f7e.svg?logo=open%20source%20initiative&logoColor=white&labelColor=555555"></a>
|
||||||
<a href="#tada-php-support" title="PHP Versions Supported"><img alt="PHP Versions Supported" src="https://img.shields.io/badge/php-5.3%20to%208.1-777bb3.svg?logo=php&logoColor=white&labelColor=555555"></a>
|
<a href="#tada-php-support" title="PHP Versions Supported"><img alt="PHP Versions Supported" src="https://img.shields.io/badge/php-5.3%20to%208.2-777bb3.svg?logo=php&logoColor=white&labelColor=555555"></a>
|
||||||
|
<a href="https://beta.stepsecurity.io/npm/setup-php"><img alt="release verified" src="https://img.shields.io/endpoint?url=https://beta.api.stepsecurity.io/v1/npm/setup-php/badge?q=1"></a>
|
||||||
</p>
|
</p>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://reddit.com/r/setup_php" title="setup-php reddit"><img alt="setup-php reddit" src="https://img.shields.io/badge/reddit-join-FF5700?logo=reddit&logoColor=FF5700&labelColor=555555"></a>
|
<a href="https://reddit.com/r/setup_php" title="setup-php reddit"><img alt="setup-php reddit" src="https://img.shields.io/badge/reddit-join-FF5700?logo=reddit&logoColor=FF5700&labelColor=555555"></a>
|
||||||
@ -97,8 +98,8 @@ Both `GitHub-hosted` and `self-hosted` runners are suppported by `setup-php` on
|
|||||||
|
|
||||||
On all supported OS/Platforms the following PHP versions are supported as per the runner.
|
On all supported OS/Platforms the following PHP versions are supported as per the runner.
|
||||||
|
|
||||||
- PHP 5.3 to PHP 8.1 on GitHub-hosted runners.
|
- PHP 5.3 to PHP 8.2 on GitHub-hosted runners.
|
||||||
- PHP 5.6 to PHP 8.1 on self-hosted runners.
|
- PHP 5.6 to PHP 8.2 on self-hosted runners.
|
||||||
|
|
||||||
|PHP Version|Stability|Release Support|Runner Support|
|
|PHP Version|Stability|Release Support|Runner Support|
|
||||||
|--- |--- |--- |--- |
|
|--- |--- |--- |--- |
|
||||||
@ -112,11 +113,12 @@ On all supported OS/Platforms the following PHP versions are supported as per th
|
|||||||
|`7.3`|`Stable`|`Security fixes only`|`GitHub-hosted`, `self-hosted`|
|
|`7.3`|`Stable`|`Security fixes only`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`7.4`|`Stable`|`Active`|`GitHub-hosted`, `self-hosted`|
|
|`7.4`|`Stable`|`Active`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`8.0`|`Stable`|`Active`|`GitHub-hosted`, `self-hosted`|
|
|`8.0`|`Stable`|`Active`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`8.1`|`Nightly`|`In development`|`GitHub-hosted`, `self-hosted`|
|
|`8.1`|`Stable`|`Active`|`GitHub-hosted`, `self-hosted`|
|
||||||
|
|`8.2`|`Nightly`|`In development`|`GitHub-hosted`, `self-hosted`|
|
||||||
|
|
||||||
**Notes:**
|
**Notes:**
|
||||||
- Specifying `8.1` in `php-version` input installs a nightly build of `PHP 8.1.0-dev`. See [nightly build setup](#nightly-build-setup) for more information.
|
- Specifying `8.2` in `php-version` input installs a nightly build of `PHP 8.2.0-dev`. See [nightly build setup](#nightly-build-setup) for more information.
|
||||||
- To use JIT on `PHP 8.0` and `PHP 8.1` refer to the [JIT configuration](#jit-configuration) section.
|
- To use JIT on `PHP 8.0` and above, refer to the [JIT configuration](#jit-configuration) section.
|
||||||
|
|
||||||
## :heavy_plus_sign: PHP Extension Support
|
## :heavy_plus_sign: PHP Extension Support
|
||||||
|
|
||||||
@ -160,16 +162,28 @@ PHP extensions can be set up using the `extensions` input. It accepts a `string`
|
|||||||
extensions: xdebug-beta
|
extensions: xdebug-beta
|
||||||
```
|
```
|
||||||
|
|
||||||
- Shared extensions can be removed by prefixing them with a `:`.
|
- Shared extensions can be disabled by prefixing them with a `:`. All extensions depending on the specified extension will also be disabled.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP and remove shared extension
|
- name: Setup PHP and disable opcache
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '8.0'
|
||||||
extensions: :opcache
|
extensions: :opcache
|
||||||
```
|
```
|
||||||
|
|
||||||
|
- All shared extensions can be disabled by specifying `none`. When `none` is specified along with other extensions, it is hoisted to the start of the input. So, all the shared extensions will be disabled first, then rest of the extensions in the input will be processed.
|
||||||
|
|
||||||
|
**Note:** This disables all core and third-party shared extensions and thus, can break some tools which need them. So, make sure you add the required extensions after `none` in the `extensions` input.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- name: Setup PHP without any shared extensions except mbstring
|
||||||
|
uses: shivammathur/setup-php@v2
|
||||||
|
with:
|
||||||
|
php-version: '8.0'
|
||||||
|
extensions: none, mbstring
|
||||||
|
```
|
||||||
|
|
||||||
- Extension `intl` can be set up with specific `ICU` version for `PHP 5.6` and above in `Ubuntu` workflows by suffixing `intl` with the `ICU` version. `ICU 50.2` and newer versions are supported. Refer to [`ICU builds`](https://github.com/shivammathur/icu-intl#icu4c-builds) for the specific versions supported.
|
- Extension `intl` can be set up with specific `ICU` version for `PHP 5.6` and above in `Ubuntu` workflows by suffixing `intl` with the `ICU` version. `ICU 50.2` and newer versions are supported. Refer to [`ICU builds`](https://github.com/shivammathur/icu-intl#icu4c-builds) for the specific versions supported.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@ -187,7 +201,7 @@ PHP extensions can be set up using the `extensions` input. It accepts a `string`
|
|||||||
- `geos` on `Ubuntu` and `macOS`.
|
- `geos` on `Ubuntu` and `macOS`.
|
||||||
- `blackfire`, `couchbase`, `ioncube`, `oci8`, `pdo_firebird`, `pdo_oci`, `pecl_http`, `phalcon3` and `phalcon4` on all supported OS.
|
- `blackfire`, `couchbase`, `ioncube`, `oci8`, `pdo_firebird`, `pdo_oci`, `pecl_http`, `phalcon3` and `phalcon4` on all supported OS.
|
||||||
|
|
||||||
- By default, extensions which cannot be added or removed gracefully leave an error message in the logs, the action is not interrupted. To change this behaviour you can set `fail-fast` flag to `true`.
|
- By default, extensions which cannot be added or disabled gracefully leave an error message in the logs, the action is not interrupted. To change this behaviour you can set `fail-fast` flag to `true`.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with fail-fast
|
- name: Setup PHP with fail-fast
|
||||||
@ -203,7 +217,7 @@ PHP extensions can be set up using the `extensions` input. It accepts a `string`
|
|||||||
|
|
||||||
These tools can be set up globally using the `tools` input. It accepts a string in csv-format.
|
These tools can be set up globally using the `tools` input. It accepts a string in csv-format.
|
||||||
|
|
||||||
`behat`, `blackfire`, `blackfire-player`, `codeception`, `composer`, `composer-normalize`, `composer-prefetcher`, `composer-require-checker`, `composer-unused`, `cs2pr`, `deployer`, `flex`, `grpc_php_plugin`, `infection`, `pecl`, `phan`, `phing`, `phinx`, `phive`, `php-config`, `php-cs-fixer`, `phpcbf`, `phpcpd`, `phpcs`, `phpize`, `phplint`, `phpmd`, `phpspec`, `phpstan`, `phpunit`, `phpunit-bridge`, `prestissimo`, `protoc`, `psalm`, `symfony` or `symfony-cli`, `vapor` or `vapor-cli`, `wp` or `wp-cli`
|
[`behat`], [`blackfire`], [`blackfire-player`], [`codeception`], [`composer`], [`composer-normalize`], [`composer-prefetcher`], [`composer-require-checker`], [`composer-unused`], [`cs2pr`], [`deployer`], [`flex`], [`grpc_php_plugin`], [`infection`], [`parallel-lint`], [`pecl`], [`phan`], [`phing`], [`phinx`], [`phive`], [`php-config`], [`php-cs-fixer`], [`phpcbf`], [`phpcpd`], [`phpcs`], [`phpdoc`] or [`phpDocumentor`], [`phpize`], [`phplint`], [`phpmd`], [`phpspec`], [`phpstan`], [`phpunit`], [`phpunit-bridge`], [`phpunit-polyfills`], [`prestissimo`], [`protoc`], [`psalm`], [`symfony`] or [`symfony-cli`], [`vapor`] or [`vapor-cli`], [`wp`] or [`wp-cli`]
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with tools
|
- name: Setup PHP with tools
|
||||||
@ -341,12 +355,12 @@ Runs on PHP 7.1 and newer PHP versions.
|
|||||||
|
|
||||||
### Disable Coverage
|
### Disable Coverage
|
||||||
|
|
||||||
Specify `coverage: none` to remove both `Xdebug` and `PCOV`.
|
Specify `coverage: none` to disable both `Xdebug` and `PCOV`.
|
||||||
|
|
||||||
Disable coverage for these reasons:
|
Disable coverage for these reasons:
|
||||||
|
|
||||||
- You are not generating coverage reports while testing.
|
- You are not generating coverage reports while testing.
|
||||||
- It will remove `Xdebug`, which will have a positive impact on PHP performance.
|
- It will disable `Xdebug`, which will have a positive impact on PHP performance.
|
||||||
- You are using `phpdbg` for running your tests.
|
- You are using `phpdbg` for running your tests.
|
||||||
- You are profiling your code using `blackfire`.
|
- You are profiling your code using `blackfire`.
|
||||||
- You are using PHP in JIT mode. Please refer to [JIT configuration](#jit-configuration) section for more details.
|
- You are using PHP in JIT mode. Please refer to [JIT configuration](#jit-configuration) section for more details.
|
||||||
@ -370,14 +384,16 @@ Disable coverage for these reasons:
|
|||||||
- Specify the PHP version you want to set up.
|
- Specify the PHP version you want to set up.
|
||||||
- Accepts a `string`. For example `'8.0'`.
|
- Accepts a `string`. For example `'8.0'`.
|
||||||
- Accepts `latest` to set up the latest stable PHP version.
|
- Accepts `latest` to set up the latest stable PHP version.
|
||||||
|
- Accepts `nightly` to set up a nightly build from the master branch of PHP.
|
||||||
- Accepts the format `d.x`, where `d` is the major version. For example `5.x`, `7.x` and `8.x`.
|
- Accepts the format `d.x`, where `d` is the major version. For example `5.x`, `7.x` and `8.x`.
|
||||||
- See [PHP support](#tada-php-support) for supported PHP versions.
|
- See [PHP support](#tada-php-support) for supported PHP versions.
|
||||||
|
|
||||||
#### `extensions` (optional)
|
#### `extensions` (optional)
|
||||||
|
|
||||||
- Specify the extensions you want to add or remove.
|
- Specify the extensions you want to add or disable.
|
||||||
- Accepts a `string` in csv-format. For example `mbstring, :opcache`.
|
- Accepts a `string` in csv-format. For example `mbstring, :opcache`.
|
||||||
- Non-default extensions prefixed with `:` are removed.
|
- Accepts `none` to disable all shared extensions.
|
||||||
|
- Shared extensions prefixed with `:` are disabled.
|
||||||
- See [PHP extension support](#heavy_plus_sign-php-extension-support) for more info.
|
- See [PHP extension support](#heavy_plus_sign-php-extension-support) for more info.
|
||||||
|
|
||||||
#### `ini-values` (optional)
|
#### `ini-values` (optional)
|
||||||
@ -388,7 +404,7 @@ Disable coverage for these reasons:
|
|||||||
|
|
||||||
#### `coverage` (optional)
|
#### `coverage` (optional)
|
||||||
|
|
||||||
- Specify the code coverage driver you want to set up.
|
- Specify the code-coverage driver you want to set up.
|
||||||
- Accepts `xdebug`, `pcov` or `none`.
|
- Accepts `xdebug`, `pcov` or `none`.
|
||||||
- See [coverage support](#signal_strength-coverage-support) for more info.
|
- See [coverage support](#signal_strength-coverage-support) for more info.
|
||||||
|
|
||||||
@ -456,7 +472,7 @@ steps:
|
|||||||
php-version: '8.0'
|
php-version: '8.0'
|
||||||
extensions: mbstring, intl
|
extensions: mbstring, intl
|
||||||
ini-values: post_max_size=256M, max_execution_time=180
|
ini-values: post_max_size=256M, max_execution_time=180
|
||||||
coverage: xdebug
|
coverage: xdebug
|
||||||
tools: php-cs-fixer, phpunit
|
tools: php-cs-fixer, phpunit
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -476,7 +492,7 @@ jobs:
|
|||||||
include:
|
include:
|
||||||
- operating-system: 'ubuntu-latest'
|
- operating-system: 'ubuntu-latest'
|
||||||
php-versions: '7.2'
|
php-versions: '7.2'
|
||||||
phpunit-versions: '8.5.19'
|
phpunit-versions: '8.5.21'
|
||||||
steps:
|
steps:
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
@ -484,13 +500,13 @@ jobs:
|
|||||||
php-version: ${{ matrix.php-versions }}
|
php-version: ${{ matrix.php-versions }}
|
||||||
extensions: mbstring, intl
|
extensions: mbstring, intl
|
||||||
ini-values: post_max_size=256M, max_execution_time=180
|
ini-values: post_max_size=256M, max_execution_time=180
|
||||||
coverage: xdebug
|
coverage: xdebug
|
||||||
tools: php-cs-fixer, phpunit:${{ matrix.phpunit-versions }}
|
tools: php-cs-fixer, phpunit:${{ matrix.phpunit-versions }}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Nightly Build Setup
|
### Nightly Build Setup
|
||||||
|
|
||||||
> Setup a nightly build of `PHP 8.1`.
|
> Setup a nightly build of `PHP 8.2`.
|
||||||
|
|
||||||
- This version is currently in development.
|
- This version is currently in development.
|
||||||
- Some user space extensions might not support this version currently.
|
- Some user space extensions might not support this version currently.
|
||||||
@ -500,7 +516,7 @@ steps:
|
|||||||
- name: Setup nightly PHP
|
- name: Setup nightly PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.1'
|
php-version: '8.2'
|
||||||
extensions: mbstring
|
extensions: mbstring
|
||||||
ini-values: post_max_size=256M, max_execution_time=180
|
ini-values: post_max_size=256M, max_execution_time=180
|
||||||
coverage: xdebug
|
coverage: xdebug
|
||||||
@ -599,13 +615,10 @@ jobs:
|
|||||||
run:
|
run:
|
||||||
runs-on: self-hosted
|
runs-on: self-hosted
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0']
|
php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0']
|
||||||
name: PHP ${{ matrix.php-versions }}
|
name: PHP ${{ matrix.php-versions }}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
@ -651,10 +664,10 @@ act -P ubuntu-18.04=shivammathur/node:1804
|
|||||||
|
|
||||||
### JIT Configuration
|
### JIT Configuration
|
||||||
|
|
||||||
> Enable Just-in-time(JIT) on PHP 8.0 and PHP 8.1.
|
> Enable Just-in-time(JIT) on PHP 8.0 and above.
|
||||||
|
|
||||||
- To enable JIT, enable `opcache` in cli mode by setting `opcache.enable_cli=1`.
|
- To enable JIT, enable `opcache` in cli mode by setting `opcache.enable_cli=1`.
|
||||||
- JIT conflicts with `Xdebug`, `PCOV`, and other extensions which override `zend_execute_ex` function, so set `coverage: none` and remove any such extension if added.
|
- JIT conflicts with `Xdebug`, `PCOV`, and other extensions which override `zend_execute_ex` function, so set `coverage: none` and disable any such extension if added.
|
||||||
- By default, `opcache.jit=1235` and `opcache.jit_buffer_size=256M` are set which can be changed using `ini-values` input.
|
- By default, `opcache.jit=1235` and `opcache.jit_buffer_size=256M` are set which can be changed using `ini-values` input.
|
||||||
- For detailed information about JIT related directives refer to the [`official PHP documentation`](https://www.php.net/manual/en/opcache.configuration.php#ini.opcache.jit "opcache.jit documentation").
|
- For detailed information about JIT related directives refer to the [`official PHP documentation`](https://www.php.net/manual/en/opcache.configuration.php#ini.opcache.jit "opcache.jit documentation").
|
||||||
|
|
||||||
@ -871,31 +884,26 @@ Examples of using `setup-php` with various PHP Frameworks and Packages.
|
|||||||
|
|
||||||
## :sparkling_heart: Support This Project
|
## :sparkling_heart: Support This Project
|
||||||
|
|
||||||
- This project is provided as Free and Open-Source software. We need funds to maintain and do future improvements. Please sponsor setup-php using the below options:
|
|
||||||
- [Open Collective](https://opencollective.com/setup-php "setup-php Open Collective")
|
|
||||||
- [Paypal](https://www.paypal.me/shivammathur "Shivam Mathur PayPal")
|
|
||||||
- [Patreon](https://www.patreon.com/shivammathur "Shivam Mathur Patreon")
|
|
||||||
- Please [reach out](mailto:contact@setup-php.com) if you have any questions about sponsoring setup-php.
|
|
||||||
- Please star the project and share it. If you blog, please share your experience of using this action.
|
- Please star the project and share it. If you blog, please share your experience of using this action.
|
||||||
|
- Please sponsor setup-php using [GitHub sponsors](https://github.com/sponsors/shivammathur).
|
||||||
|
- Please [reach out](mailto:contact@setup-php.com) if you have any questions about sponsoring setup-php.
|
||||||
|
|
||||||
*`setup-php` is generously supported by*
|
[](https://github.com/sponsors/shivammathur)
|
||||||
|
|
||||||
<p>
|
### Corporate Sponsors
|
||||||
<a href="https://www.jetbrains.com/?from=setup-php">
|
|
||||||
<img src="https://setup-php.com/sponsors/jetbrains.svg" alt="JetBrains" width="106" height="60">
|
<p align="center">
|
||||||
|
<a href="https://setup-php.com/sponsors-corp/?">
|
||||||
|
<img src="https://setup-php.com/sponsors-corp/?" alt="Corporate sponsors of setup-php and related projects" width="100%">
|
||||||
</a>
|
</a>
|
||||||
|
</p>
|
||||||
<a href="https://blackfire.io/?utm_source=setup-php">
|
|
||||||
<img src="https://setup-php.com/sponsors//blackfire.svg" alt="Blackfire" width="212" height="60">
|
### Individual Sponsors
|
||||||
|
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://setup-php.com/sponsors/?">
|
||||||
|
<img src="https://setup-php.com/sponsors/?" alt="Individual sponsors of setup-php and related projects" width="100%">
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<a href="https://www.macstadium.com/?source=setup-php">
|
|
||||||
<img src="https://setup-php.com/sponsors//macstadium.png" alt="Mac Stadium" width="148" height="60">
|
|
||||||
</a>
|
|
||||||
|
|
||||||
<a href="https://tidelift.com/subscription/pkg/npm-setup-php">
|
|
||||||
<img src="https://setup-php.com/sponsors//tidelift.png" alt="Tidelift" width="70" height="60">
|
|
||||||
</a>
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
## :package: Dependencies
|
## :package: Dependencies
|
||||||
@ -920,3 +928,50 @@ Examples of using `setup-php` with various PHP Frameworks and Packages.
|
|||||||
- [About GitHub Actions](https://github.com/features/actions "GitHub Actions")
|
- [About GitHub Actions](https://github.com/features/actions "GitHub Actions")
|
||||||
- [GitHub Actions Syntax](https://help.github.com/en/articles/workflow-syntax-for-github-actions "GitHub Actions Syntax")
|
- [GitHub Actions Syntax](https://help.github.com/en/articles/workflow-syntax-for-github-actions "GitHub Actions Syntax")
|
||||||
- [Other Awesome Actions](https://github.com/sdras/awesome-actions "List of Awesome GitHub Actions")
|
- [Other Awesome Actions](https://github.com/sdras/awesome-actions "List of Awesome GitHub Actions")
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Links to tools -->
|
||||||
|
[`behat`]: https://docs.behat.org/en/latest/
|
||||||
|
[`blackfire`]: https://blackfire.io/docs/php/index
|
||||||
|
[`blackfire-player`]: https://blackfire.io/docs/builds-cookbooks/player
|
||||||
|
[`codeception`]: https://codeception.com/
|
||||||
|
[`composer`]: https://getcomposer.org/
|
||||||
|
[`composer-normalize`]: https://github.com/ergebnis/composer-normalize
|
||||||
|
[`composer-prefetcher`]: https://github.com/narrowspark/automatic-composer-prefetcher
|
||||||
|
[`composer-require-checker`]: https://github.com/maglnet/ComposerRequireChecker
|
||||||
|
[`composer-unused`]: https://github.com/composer-unused/composer-unused
|
||||||
|
[`cs2pr`]: https://github.com/staabm/annotate-pull-request-from-checkstyle
|
||||||
|
[`deployer`]: https://deployer.org/
|
||||||
|
[`flex`]: https://flex.symfony.com/
|
||||||
|
[`grpc_php_plugin`]: https://grpc.io/
|
||||||
|
[`infection`]: https://infection.github.io/
|
||||||
|
[`parallel-lint`]: https://github.com/php-parallel-lint/PHP-Parallel-Lint
|
||||||
|
[`pecl`]: https://pecl.php.net/
|
||||||
|
[`phan`]: https://github.com/phan/phan/wiki
|
||||||
|
[`phing`]: https://www.phing.info/
|
||||||
|
[`phinx`]: https://phinx.org/
|
||||||
|
[`phive`]: https://phar.io/
|
||||||
|
[`php-config`]: https://www.php.net/manual/en/install.pecl.php-config.php
|
||||||
|
[`php-cs-fixer`]: https://cs.symfony.com/
|
||||||
|
[`phpcbf`]: https://github.com/squizlabs/php_codesniffer
|
||||||
|
[`phpcpd`]: https://github.com/sebastianbergmann/phpcpd
|
||||||
|
[`phpcs`]: https://github.com/squizlabs/php_codesniffer
|
||||||
|
[`phpdoc`]: https://phpdoc.org/
|
||||||
|
[`phpDocumentor`]: https://phpdoc.org/
|
||||||
|
[`phpize`]: https://www.php.net/manual/en/install.pecl.phpize.php
|
||||||
|
[`phplint`]: https://github.com/overtrue/phplint
|
||||||
|
[`phpmd`]: https://phpmd.org/
|
||||||
|
[`phpspec`]: https://www.phpspec.net/
|
||||||
|
[`phpstan`]: https://phpstan.org/
|
||||||
|
[`phpunit`]: https://phpunit.de/
|
||||||
|
[`phpunit-bridge`]: https://symfony.com/doc/current/components/phpunit_bridge.html
|
||||||
|
[`phpunit-polyfills`]: https://github.com/Yoast/PHPUnit-Polyfills
|
||||||
|
[`prestissimo`]: https://github.com/hirak/prestissimo
|
||||||
|
[`protoc`]: https://developers.google.com/protocol-buffers/
|
||||||
|
[`psalm`]: https://psalm.dev/
|
||||||
|
[`symfony`]: https://symfony.com/download
|
||||||
|
[`symfony-cli`]: https://symfony.com/download
|
||||||
|
[`vapor`]: https://docs.vapor.build/
|
||||||
|
[`vapor-cli`]: https://docs.vapor.build/
|
||||||
|
[`wp`]: https://wp-cli.org/
|
||||||
|
[`wp-cli`]: https://wp-cli.org/
|
||||||
|
@ -1,52 +1,21 @@
|
|||||||
import * as config from '../src/config';
|
import * as config from '../src/config';
|
||||||
|
|
||||||
describe('Config tests', () => {
|
describe('Config tests', () => {
|
||||||
it('checking addINIValuesOnWindows', async () => {
|
it.each`
|
||||||
let win32: string = await config.addINIValues(
|
ini_values | os_version | output
|
||||||
'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata',
|
${'a=b, c=d'} | ${'win32'} | ${'Add-Content "$php_dir\\php.ini" "a=b\nc=d"'}
|
||||||
'win32'
|
${'a=b, c=d'} | ${'linux'} | ${'echo "a=b\nc=d" | sudo tee -a "${pecl_file:-${ini_file[@]}}"'}
|
||||||
);
|
${'a=b, c=d'} | ${'darwin'} | ${'echo "a=b\nc=d" | sudo tee -a "${pecl_file:-${ini_file[@]}}"'}
|
||||||
expect(win32).toContain(
|
${'a=b & ~c'} | ${'win32'} | ${'Add-Content "$php_dir\\php.ini" "a=\'b & ~c\'"'}
|
||||||
'Add-Content "$php_dir\\php.ini" "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata"'
|
${'a="~(b)"'} | ${'win32'} | ${'Add-Content "$php_dir\\php.ini" "a=\'~(b)\'"'}
|
||||||
);
|
${'a="b, c"'} | ${'win32'} | ${'Add-Content "$php_dir\\php.ini" "a=b, c"'}
|
||||||
|
${'a=b, c=d'} | ${'openbsd'} | ${'Platform openbsd is not supported'}
|
||||||
win32 = await config.addINIValues(
|
`(
|
||||||
'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata',
|
'checking addINIValues on $os_version',
|
||||||
'openbsd'
|
async ({ini_values, os_version, output}) => {
|
||||||
);
|
expect(await config.addINIValues(ini_values, os_version)).toContain(
|
||||||
expect(win32).toContain('Platform openbsd is not supported');
|
output
|
||||||
});
|
);
|
||||||
|
}
|
||||||
it('checking addINIValuesOnLinux', async () => {
|
);
|
||||||
let linux: string = await config.addINIValues(
|
|
||||||
'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata',
|
|
||||||
'linux',
|
|
||||||
true
|
|
||||||
);
|
|
||||||
expect(linux).toContain(
|
|
||||||
'echo "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata" | sudo tee -a "${pecl_file:-${ini_file[@]}}"'
|
|
||||||
);
|
|
||||||
|
|
||||||
linux = await config.addINIValues(
|
|
||||||
'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata',
|
|
||||||
'openbsd'
|
|
||||||
);
|
|
||||||
expect(linux).toContain('Platform openbsd is not supported');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addINIValuesOnDarwin', async () => {
|
|
||||||
let darwin: string = await config.addINIValues(
|
|
||||||
'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata',
|
|
||||||
'darwin'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain(
|
|
||||||
'echo "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata" | sudo tee -a "${pecl_file:-${ini_file[@]}}"'
|
|
||||||
);
|
|
||||||
|
|
||||||
darwin = await config.addINIValues(
|
|
||||||
'post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata',
|
|
||||||
'openbsd'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain('Platform openbsd is not supported');
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
@ -1,110 +1,39 @@
|
|||||||
import * as coverage from '../src/coverage';
|
import * as coverage from '../src/coverage';
|
||||||
|
|
||||||
describe('Config tests', () => {
|
describe('Config tests', () => {
|
||||||
it('checking addCoverage with PCOV on windows', async () => {
|
it.each`
|
||||||
let win32: string = await coverage.addCoverage('PCOV', '7.4', 'win32');
|
driver | php | os | output
|
||||||
expect(win32).toContain('Add-Extension pcov');
|
${'PCOV'} | ${'7.4'} | ${'win32'} | ${'Add-Extension pcov,Disable-Extension xdebug false'}
|
||||||
expect(win32).toContain('Remove-Extension xdebug');
|
${'pcov'} | ${'7.0'} | ${'win32'} | ${'PHP 7.1 or newer is required'}
|
||||||
|
${'pcov'} | ${'5.6'} | ${'win32'} | ${'PHP 7.1 or newer is required'}
|
||||||
win32 = await coverage.addCoverage('pcov', '7.0', 'win32');
|
${'pcov'} | ${'7.4'} | ${'win32'} | ${'Add-Extension pcov,Disable-Extension xdebug false'}
|
||||||
expect(win32).toContain('PHP 7.1 or newer is required');
|
${'pcov'} | ${'7.4'} | ${'linux'} | ${'add_extension pcov,disable_extension xdebug false'}
|
||||||
|
${'pcov'} | ${'7.4'} | ${'darwin'} | ${'add_brew_extension pcov,disable_extension xdebug false'}
|
||||||
win32 = await coverage.addCoverage('pcov', '5.6', 'win32');
|
${'xdebug'} | ${'7.4'} | ${'win32'} | ${'Add-Extension xdebug'}
|
||||||
expect(win32).toContain('PHP 7.1 or newer is required');
|
${'xdebug3'} | ${'7.4'} | ${'win32'} | ${'Add-Extension xdebug'}
|
||||||
});
|
${'xdebug2'} | ${'7.4'} | ${'win32'} | ${'Add-Extension xdebug stable 2.9.8'}
|
||||||
|
${'xdebug'} | ${'8.0'} | ${'linux'} | ${'add_extension xdebug'}
|
||||||
it('checking addCoverage with PCOV on linux', async () => {
|
${'xdebug3'} | ${'8.0'} | ${'linux'} | ${'add_extension xdebug'}
|
||||||
const linux: string = await coverage.addCoverage('pcov', '7.4', 'linux');
|
${'xdebug2'} | ${'7.4'} | ${'linux'} | ${'add_pecl_extension xdebug 2.9.8 zend_extension'}
|
||||||
expect(linux).toContain('add_extension pcov');
|
${'xdebug'} | ${'7.4'} | ${'darwin'} | ${'add_brew_extension xdebug'}
|
||||||
expect(linux).toContain('remove_extension xdebug');
|
${'xdebug3'} | ${'7.4'} | ${'darwin'} | ${'add_brew_extension xdebug'}
|
||||||
});
|
${'xdebug2'} | ${'7.4'} | ${'darwin'} | ${'add_brew_extension xdebug2'}
|
||||||
|
${'none'} | ${'7.4'} | ${'win32'} | ${'Disable-Extension xdebug false,Disable-Extension pcov false'}
|
||||||
it('checking addCoverage with PCOV on darwin', async () => {
|
${'none'} | ${'7.4'} | ${'linux'} | ${'disable_extension xdebug false,disable_extension pcov false'}
|
||||||
const darwin: string = await coverage.addCoverage('pcov', '7.4', 'darwin');
|
${'none'} | ${'7.4'} | ${'darwin'} | ${'disable_extension xdebug false,disable_extension pcov false'}
|
||||||
expect(darwin).toContain('add_brew_extension pcov');
|
${'nocov'} | ${'7.x'} | ${'any'} | ${''}
|
||||||
expect(darwin).toContain('remove_extension xdebug');
|
${''} | ${'7.x'} | ${'any'} | ${''}
|
||||||
});
|
`(
|
||||||
|
'checking addCoverage with $driver on $os',
|
||||||
it('checking addCoverage with Xdebug on windows', async () => {
|
async ({driver, php, os, output}) => {
|
||||||
const win32: string = await coverage.addCoverage('xdebug', '7.4', 'win32');
|
const script: string = await coverage.addCoverage(driver, php, os);
|
||||||
expect(win32).toContain('Add-Extension xdebug');
|
if (output) {
|
||||||
});
|
output.split(',').forEach((command: string) => {
|
||||||
|
expect(script).toContain(command);
|
||||||
it('checking addCoverage with Xdebug3 on windows', async () => {
|
});
|
||||||
const win32: string = await coverage.addCoverage('xdebug3', '7.4', 'win32');
|
} else {
|
||||||
expect(win32).toContain('Add-Extension xdebug');
|
expect(script).toEqual(output);
|
||||||
});
|
}
|
||||||
|
}
|
||||||
it('checking addCoverage with Xdebug2 on windows', async () => {
|
);
|
||||||
const win32: string = await coverage.addCoverage('xdebug2', '7.4', 'win32');
|
|
||||||
expect(win32).toContain('Add-Extension xdebug stable 2.9.8');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug on linux', async () => {
|
|
||||||
const linux: string = await coverage.addCoverage('xdebug', '8.0', 'linux');
|
|
||||||
expect(linux).toContain('add_extension xdebug');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug3 on linux', async () => {
|
|
||||||
const linux: string = await coverage.addCoverage('xdebug3', '8.0', 'linux');
|
|
||||||
expect(linux).toContain('add_extension xdebug');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug2 on linux', async () => {
|
|
||||||
const linux: string = await coverage.addCoverage('xdebug2', '7.4', 'linux');
|
|
||||||
expect(linux).toContain('add_pecl_extension xdebug 2.9.8 zend_extension');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug on darwin', async () => {
|
|
||||||
const darwin: string = await coverage.addCoverage(
|
|
||||||
'xdebug',
|
|
||||||
'7.4',
|
|
||||||
'darwin'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug3 on darwin', async () => {
|
|
||||||
const darwin: string = await coverage.addCoverage(
|
|
||||||
'xdebug3',
|
|
||||||
'7.4',
|
|
||||||
'darwin'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug2 on darwin', async () => {
|
|
||||||
const darwin: string = await coverage.addCoverage(
|
|
||||||
'xdebug2',
|
|
||||||
'7.4',
|
|
||||||
'darwin'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug2');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking disableCoverage windows', async () => {
|
|
||||||
const win32 = await coverage.addCoverage('none', '7.4', 'win32');
|
|
||||||
expect(win32).toContain('Remove-Extension xdebug');
|
|
||||||
expect(win32).toContain('Remove-Extension pcov');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking disableCoverage on linux', async () => {
|
|
||||||
const linux: string = await coverage.addCoverage('none', '7.4', 'linux');
|
|
||||||
expect(linux).toContain('remove_extension xdebug');
|
|
||||||
expect(linux).toContain('remove_extension pcov');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking disableCoverage on darwin', async () => {
|
|
||||||
const darwin: string = await coverage.addCoverage('none', '7.4', 'darwin');
|
|
||||||
expect(darwin).toContain('remove_extension xdebug');
|
|
||||||
expect(darwin).toContain('remove_extension pcov');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking no or invalid coverage driver', async () => {
|
|
||||||
let nocov: string = await coverage.addCoverage('nocov', '7.x', 'any');
|
|
||||||
expect(nocov).toEqual('');
|
|
||||||
|
|
||||||
nocov = await coverage.addCoverage('', '7.x', 'any');
|
|
||||||
expect(nocov).toEqual('');
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
@ -1,263 +1,138 @@
|
|||||||
|
import * as fs from 'fs';
|
||||||
import * as extensions from '../src/extensions';
|
import * as extensions from '../src/extensions';
|
||||||
|
|
||||||
describe('Extension tests', () => {
|
describe('Extension tests', () => {
|
||||||
it('checking addExtensionOnWindows', async () => {
|
it.each`
|
||||||
let win32: string = await extensions.addExtension(
|
extension | version | output
|
||||||
'Xdebug, pcov, sqlite, :intl, phalcon4, pecl_http, ioncube, oci8, pdo_oci, ast-beta, grpc-1.2.3, inotify-1.2.3alpha2, sqlsrv-1.2.3preview1',
|
${'none'} | ${'7.4'} | ${'Disable-AllShared'}
|
||||||
'7.4',
|
${':intl'} | ${'7.4'} | ${'Disable-Extension intl'}
|
||||||
'win32'
|
${'ast-beta'} | ${'7.4'} | ${'Add-Extension ast beta'}
|
||||||
);
|
${'blackfire'} | ${'7.3'} | ${'Add-Blackfire blackfire'}
|
||||||
expect(win32).toContain('Add-Extension xdebug');
|
${'blackfire-1.31.0'} | ${'7.3'} | ${'Add-Blackfire blackfire-1.31.0'}
|
||||||
expect(win32).toContain('Add-Extension pcov');
|
${'grpc-1.2.3'} | ${'7.4'} | ${'Add-Extension grpc stable 1.2.3'}
|
||||||
expect(win32).toContain('Add-Extension sqlite3');
|
${'inotify-1.2.3alpha2'} | ${'7.4'} | ${'Add-Extension inotify alpha 1.2.3'}
|
||||||
expect(win32).toContain('Remove-Extension intl');
|
${'ioncube'} | ${'7.4'} | ${'Add-Ioncube'}
|
||||||
expect(win32).toContain('Add-Phalcon phalcon4');
|
${'mongodb-mongodb/mongo-php-driver@master'} | ${'7.3'} | ${'Add-Log "$cross" "mongodb-mongodb/mongo-php-driver@master" "mongodb-mongodb/mongo-php-driver@master is not supported on PHP 7.3"'}
|
||||||
expect(win32).toContain('Add-Http');
|
${'mysql'} | ${'7.4'} | ${'Add-Extension mysqli\nAdd-Extension mysqlnd'}
|
||||||
expect(win32).toContain('Add-Ioncube');
|
${'mysql'} | ${'5.5'} | ${'Add-Extension mysql\nAdd-Extension mysqli\nAdd-Extension mysqlnd'}
|
||||||
expect(win32).toContain('Add-Oci oci8');
|
${'oci8'} | ${'7.4'} | ${'Add-Oci oci8'}
|
||||||
expect(win32).toContain('Add-Oci pdo_oci');
|
${'pcov'} | ${'5.6'} | ${'Add-Log "$cross" "pcov" "pcov is not supported on PHP 5.6"'}
|
||||||
expect(win32).toContain('Add-Extension ast beta');
|
${'pdo_oci'} | ${'7.4'} | ${'Add-Oci pdo_oci'}
|
||||||
expect(win32).toContain('Add-Extension grpc stable 1.2.3');
|
${'pecl_http'} | ${'7.4'} | ${'Add-Http'}
|
||||||
expect(win32).toContain('Add-Extension inotify alpha 1.2.3');
|
${'phalcon3'} | ${'7.2'} | ${'Add-Phalcon phalcon3'}
|
||||||
expect(win32).toContain('Add-Extension sqlsrv devel 1.2.3');
|
${'phalcon4'} | ${'7.4'} | ${'Add-Phalcon phalcon4'}
|
||||||
|
${'sqlite'} | ${'7.4'} | ${'Add-Extension sqlite3'}
|
||||||
|
${'sqlsrv-1.2.3preview1'} | ${'7.4'} | ${'Add-Extension sqlsrv devel 1.2.3'}
|
||||||
|
${'Xdebug'} | ${'7.4'} | ${'Add-Extension xdebug'}
|
||||||
|
${'xdebug2'} | ${'7.2'} | ${'Add-Extension xdebug stable 2.9.8'}
|
||||||
|
`(
|
||||||
|
'checking addExtensionOnWindows for extension $extension on version $version',
|
||||||
|
async ({extension, version, output}) => {
|
||||||
|
expect(
|
||||||
|
await extensions.addExtension(extension, version, 'win32')
|
||||||
|
).toContain(output);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
win32 = await extensions.addExtension('pcov', '5.6', 'win32');
|
it.each`
|
||||||
expect(win32).toContain(
|
extension | version | output
|
||||||
'Add-Log "$cross" "pcov" "pcov is not supported on PHP 5.6"'
|
${'none'} | ${'7.4'} | ${'disable_all_shared'}
|
||||||
);
|
${':intl'} | ${'7.4'} | ${'disable_extension intl'}
|
||||||
|
${'ast-beta'} | ${'7.4'} | ${'add_unstable_extension ast beta extension'}
|
||||||
|
${'blackfire'} | ${'7.3'} | ${'add_blackfire blackfire'}
|
||||||
|
${'blackfire-1.31.0'} | ${'7.3'} | ${'add_blackfire blackfire-1.31.0'}
|
||||||
|
${'couchbase'} | ${'7.4'} | ${'add_couchbase'}
|
||||||
|
${'gearman'} | ${'5.6'} | ${'add_gearman'}
|
||||||
|
${'geos'} | ${'7.3'} | ${'add_geos'}
|
||||||
|
${'grpc-1.2.3'} | ${'7.4'} | ${'add_pecl_extension grpc 1.2.3 extension'}
|
||||||
|
${'http-1.2.3'} | ${'7.3'} | ${'add_http http-1.2.3'}
|
||||||
|
${'intl-65.1'} | ${'5.6'} | ${'add_intl intl-65.1'}
|
||||||
|
${'ioncube'} | ${'7.3'} | ${'add_ioncube'}
|
||||||
|
${'mongodb-mongodb/mongo-php-driver@master'} | ${'7.3'} | ${'add_extension_from_source mongodb https://github.com mongodb mongo-php-driver master extension'}
|
||||||
|
${'oci8'} | ${'7.3'} | ${'add_oci oci8'}
|
||||||
|
${'pcov'} | ${'5.6'} | ${'add_log "$cross" "pcov" "pcov is not supported on PHP 5.6'}
|
||||||
|
${'pdo-odbc'} | ${'7.4'} | ${'add_pdo_extension odbc'}
|
||||||
|
${'pdo_cubrid'} | ${'7.0'} | ${'add_cubrid pdo_cubrid'}
|
||||||
|
${'pdo_cubrid'} | ${'7.4'} | ${'add_pdo_extension cubrid'}
|
||||||
|
${'pdo_mysql'} | ${'7.4'} | ${'add_pdo_extension mysql'}
|
||||||
|
${'pdo_oci'} | ${'7.3'} | ${'add_oci pdo_oci'}
|
||||||
|
${'pecl_http'} | ${'7.3'} | ${'add_http'}
|
||||||
|
${'phalcon3'} | ${'7.3'} | ${'add_phalcon phalcon3'}
|
||||||
|
${'sqlite'} | ${'7.4'} | ${'add_extension sqlite3'}
|
||||||
|
${'Xdebug'} | ${'7.4'} | ${'add_extension xdebug'}
|
||||||
|
${'xdebug-alpha'} | ${'7.4'} | ${'add_unstable_extension xdebug alpha zend_extension'}
|
||||||
|
${'xdebug2'} | ${'7.2'} | ${'add_pecl_extension xdebug 2.9.8 zend_extension'}
|
||||||
|
`(
|
||||||
|
'checking addExtensionOnLinux for extension $extension on version $version',
|
||||||
|
async ({extension, version, output}) => {
|
||||||
|
expect(
|
||||||
|
await extensions.addExtension(extension, version, 'linux')
|
||||||
|
).toContain(output);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
win32 = await extensions.addExtension('xdebug2', '7.2', 'win32');
|
it.each`
|
||||||
expect(win32).toContain('Add-Extension xdebug stable 2.9.8');
|
extension | version | output
|
||||||
|
${'none'} | ${'7.2'} | ${'disable_all_shared'}
|
||||||
|
${':intl'} | ${'7.2'} | ${'disable_extension intl'}
|
||||||
|
${'ast-beta'} | ${'7.2'} | ${'add_unstable_extension ast beta extension'}
|
||||||
|
${'blackfire'} | ${'7.3'} | ${'add_blackfire blackfire'}
|
||||||
|
${'blackfire-1.31.0'} | ${'7.3'} | ${'add_blackfire blackfire-1.31.0'}
|
||||||
|
${'couchbase'} | ${'5.6'} | ${'add_couchbase'}
|
||||||
|
${'does_not_exist'} | ${'7.2'} | ${'add_extension does_not_exist'}
|
||||||
|
${'geos'} | ${'7.3'} | ${'add_geos'}
|
||||||
|
${'grpc-1.2.3'} | ${'7.2'} | ${'add_pecl_extension grpc 1.2.3 extension'}
|
||||||
|
${'http-1.2.3'} | ${'7.3'} | ${'add_http http-1.2.3'}
|
||||||
|
${'imagick'} | ${'5.5'} | ${'add_extension imagick'}
|
||||||
|
${'ioncube'} | ${'7.3'} | ${'add_ioncube'}
|
||||||
|
${'mongodb-mongodb/mongo-php-driver@master'} | ${'7.2'} | ${'add_extension_from_source mongodb https://github.com mongodb mongo-php-driver master extension'}
|
||||||
|
${'oci8'} | ${'7.3'} | ${'add_oci oci8'}
|
||||||
|
${'pcov'} | ${'5.6'} | ${'add_log "$cross" "pcov" "pcov is not supported on PHP 5.6"'}
|
||||||
|
${'pdo_oci'} | ${'7.3'} | ${'add_oci pdo_oci'}
|
||||||
|
${'pecl_http'} | ${'7.3'} | ${'add_http'}
|
||||||
|
${'sqlite'} | ${'7.2'} | ${'add_extension sqlite3'}
|
||||||
|
`(
|
||||||
|
'checking addExtensionOnDarwin for extension $extension on version $version',
|
||||||
|
async ({extension, version, output}) => {
|
||||||
|
expect(
|
||||||
|
await extensions.addExtension(extension, version, 'darwin')
|
||||||
|
).toContain(output);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
win32 = await extensions.addExtension('mysql', '7.4', 'win32');
|
const data: string[][] = fs
|
||||||
expect(win32).toContain('Add-Extension mysqli');
|
.readFileSync('src/configs/brew_extensions')
|
||||||
expect(win32).toContain('Add-Extension mysqlnd');
|
.toString()
|
||||||
|
.split(/\r?\n/)
|
||||||
|
.filter(Boolean)
|
||||||
|
.map(line => {
|
||||||
|
const [formula, extension]: string[] = line.split('=');
|
||||||
|
const prefix: string =
|
||||||
|
extension == 'xdebug' ? 'zend_extension' : 'extension';
|
||||||
|
const output: string = fs.existsSync(`src/scripts/ext/${extension}.sh`)
|
||||||
|
? `add_${extension}`
|
||||||
|
: `add_brew_extension ${formula} ${prefix}`;
|
||||||
|
return [formula, '7.3', output];
|
||||||
|
});
|
||||||
|
|
||||||
win32 = await extensions.addExtension('mysql', '8.0', 'win32');
|
it.each(data)(
|
||||||
expect(win32).toContain('Add-Extension mysqli');
|
'checking addExtensionOnDarwin for brew extension %s',
|
||||||
expect(win32).toContain('Add-Extension mysqlnd');
|
async (extension, version, output) => {
|
||||||
|
expect(
|
||||||
|
await extensions.addExtension(extension, version, 'darwin')
|
||||||
|
).toContain(output);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
win32 = await extensions.addExtension('mysql', '5.5', 'win32');
|
it.each`
|
||||||
expect(win32).toContain('Add-Extension mysql');
|
extension | version | output
|
||||||
expect(win32).toContain('Add-Extension mysqli');
|
${'xdebug'} | ${'7.2'} | ${'Platform openbsd is not supported'}
|
||||||
expect(win32).toContain('Add-Extension mysqlnd');
|
`(
|
||||||
|
'checking addExtension on openbsd for extension $extension on version $version',
|
||||||
win32 = await extensions.addExtension(
|
async ({extension, version, output}) => {
|
||||||
'phalcon3, does_not_exist',
|
expect(
|
||||||
'7.2',
|
await extensions.addExtension(extension, version, 'openbsd')
|
||||||
'win32',
|
).toContain(output);
|
||||||
true
|
}
|
||||||
);
|
);
|
||||||
expect(win32).toContain('Add-Phalcon phalcon3');
|
|
||||||
expect(win32).toContain('Add-Extension does_not_exist');
|
|
||||||
|
|
||||||
win32 = await extensions.addExtension('xdebug', '7.2', 'openbsd');
|
|
||||||
expect(win32).toContain('Platform openbsd is not supported');
|
|
||||||
|
|
||||||
win32 = await extensions.addExtension('blackfire', '7.3', 'win32');
|
|
||||||
expect(win32).toContain('Add-Blackfire blackfire');
|
|
||||||
|
|
||||||
win32 = await extensions.addExtension('blackfire-1.31.0', '7.3', 'win32');
|
|
||||||
expect(win32).toContain('Add-Blackfire blackfire-1.31.0');
|
|
||||||
|
|
||||||
win32 = await extensions.addExtension(
|
|
||||||
'mongodb-mongodb/mongo-php-driver@master',
|
|
||||||
'7.3',
|
|
||||||
'win32'
|
|
||||||
);
|
|
||||||
expect(win32).toContain(
|
|
||||||
'Add-Log "$cross" "mongodb-mongodb/mongo-php-driver@master" "mongodb-mongodb/mongo-php-driver@master is not supported on PHP 7.3"'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addExtensionOnLinux', async () => {
|
|
||||||
let linux: string = await extensions.addExtension(
|
|
||||||
'Xdebug, pcov, sqlite, :intl, ast, ast-beta, pdo_mysql, pdo-odbc, xdebug-alpha, grpc-1.2.3',
|
|
||||||
'7.4',
|
|
||||||
'linux'
|
|
||||||
);
|
|
||||||
expect(linux).toContain('add_extension xdebug');
|
|
||||||
expect(linux).toContain('add_extension sqlite3');
|
|
||||||
expect(linux).toContain('remove_extension intl');
|
|
||||||
expect(linux).toContain('add_unstable_extension ast beta extension');
|
|
||||||
expect(linux).toContain('add_pdo_extension mysql');
|
|
||||||
expect(linux).toContain('add_pdo_extension odbc');
|
|
||||||
expect(linux).toContain('add_pecl_extension grpc 1.2.3 extension');
|
|
||||||
expect(linux).toContain(
|
|
||||||
'add_unstable_extension xdebug alpha zend_extension'
|
|
||||||
);
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('pcov', '5.6', 'linux');
|
|
||||||
expect(linux).toContain(
|
|
||||||
'add_log "$cross" "pcov" "pcov is not supported on PHP 5.6"'
|
|
||||||
);
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('gearman', '5.6', 'linux');
|
|
||||||
expect(linux).toContain('add_gearman');
|
|
||||||
linux = await extensions.addExtension('gearman', '7.4', 'linux');
|
|
||||||
expect(linux).toContain('add_gearman');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('couchbase', '5.6', 'linux');
|
|
||||||
expect(linux).toContain('add_couchbase');
|
|
||||||
linux = await extensions.addExtension('couchbase', '7.4', 'linux');
|
|
||||||
expect(linux).toContain('add_couchbase');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('pdo_cubrid', '7.0', 'linux');
|
|
||||||
expect(linux).toContain('add_cubrid pdo_cubrid');
|
|
||||||
linux = await extensions.addExtension('cubrid', '7.4', 'linux');
|
|
||||||
expect(linux).toContain('add_cubrid cubrid');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('xdebug2', '7.2', 'linux');
|
|
||||||
expect(linux).toContain('add_pecl_extension xdebug 2.9.8 zend_extension');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('xdebug', '7.2', 'openbsd');
|
|
||||||
expect(linux).toContain('Platform openbsd is not supported');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('phalcon3, phalcon4', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_phalcon phalcon3');
|
|
||||||
expect(linux).toContain('add_phalcon phalcon4');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('ioncube', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_ioncube');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('geos', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_geos');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('pecl_http', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_http');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('http-1.2.3', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_http http-1.2.3');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('oci8, pdo_oci', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_oci oci8');
|
|
||||||
expect(linux).toContain('add_oci pdo_oci');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('blackfire', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_blackfire blackfire');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('blackfire-1.31.0', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_blackfire blackfire-1.31.0');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('intl-65.1', '5.6', 'linux');
|
|
||||||
expect(linux).toContain('add_intl intl-65.1');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('intl-67.1', '7.3', 'linux');
|
|
||||||
expect(linux).toContain('add_intl intl-67.1');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension('intl-68.2', '8.0', 'linux');
|
|
||||||
expect(linux).toContain('add_intl intl-68.2');
|
|
||||||
|
|
||||||
linux = await extensions.addExtension(
|
|
||||||
'mongodb-mongodb/mongo-php-driver@master',
|
|
||||||
'7.3',
|
|
||||||
'linux'
|
|
||||||
);
|
|
||||||
expect(linux).toContain(
|
|
||||||
'add_extension_from_source mongodb https://github.com mongodb mongo-php-driver master extension'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking addExtensionOnDarwin', async () => {
|
|
||||||
let darwin: string = await extensions.addExtension(
|
|
||||||
'amqp, apcu, Xdebug, pcov, grpc, igbinary, imagick, imap, memcache, memcached, mongodb, msgpack, phalcon3, phalcon4, protobuf, psr, rdkafka, redis, swoole, yaml, sqlite, oci8, pdo_oci, :intl, ast-beta, grpc-1.2.3',
|
|
||||||
'7.2',
|
|
||||||
'darwin'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain('add_brew_extension amqp extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension apcu extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug zend_extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension pcov extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension grpc extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension igbinary extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension imagick extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension imap extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension memcache extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension memcached extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension mongodb extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension msgpack extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension phalcon3 extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension phalcon4 extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension protobuf extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension psr extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension rdkafka extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension redis extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension swoole extension');
|
|
||||||
expect(darwin).toContain('add_brew_extension yaml extension');
|
|
||||||
expect(darwin).toContain('add_extension sqlite3');
|
|
||||||
expect(darwin).toContain('remove_extension intl');
|
|
||||||
expect(darwin).toContain('add_unstable_extension ast beta extension');
|
|
||||||
expect(darwin).toContain('add_pecl_extension grpc 1.2.3 extension');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('couchbase', '5.6', 'darwin');
|
|
||||||
expect(darwin).toContain('add_couchbase');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('couchbase', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_couchbase');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('ioncube', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_ioncube');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('geos', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_geos');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('pecl_http', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_http');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('http-1.2.3', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_http http-1.2.3');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('oci8, pdo_oci', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_oci oci8');
|
|
||||||
expect(darwin).toContain('add_oci pdo_oci');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('pcov', '5.6', 'darwin');
|
|
||||||
expect(darwin).toContain(
|
|
||||||
'add_log "$cross" "pcov" "pcov is not supported on PHP 5.6"'
|
|
||||||
);
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('pcov', '7.2', 'darwin');
|
|
||||||
expect(darwin).toContain('add_brew_extension pcov');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug', '5.6', 'darwin');
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug', '7.0', 'darwin');
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug', '7.2', 'darwin');
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug2', '7.2', 'darwin');
|
|
||||||
expect(darwin).toContain('add_brew_extension xdebug2');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('imagick', '5.5', 'darwin');
|
|
||||||
expect(darwin).toContain('add_extension imagick');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('blackfire', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_blackfire blackfire');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('blackfire-1.31.0', '7.3', 'darwin');
|
|
||||||
expect(darwin).toContain('add_blackfire blackfire-1.31.0');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension(
|
|
||||||
'does_not_exist',
|
|
||||||
'7.2',
|
|
||||||
'darwin',
|
|
||||||
false
|
|
||||||
);
|
|
||||||
expect(darwin).toContain('add_extension does_not_exist');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug', '7.2', 'openbsd');
|
|
||||||
expect(darwin).toContain('Platform openbsd is not supported');
|
|
||||||
|
|
||||||
darwin = await extensions.addExtension(
|
|
||||||
'mongodb-mongodb/mongo-php-driver@master',
|
|
||||||
'7.3',
|
|
||||||
'darwin'
|
|
||||||
);
|
|
||||||
expect(darwin).toContain(
|
|
||||||
'add_extension_from_source mongodb https://github.com mongodb mongo-php-driver master extension'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
@ -5,40 +5,18 @@ import * as utils from '../src/utils';
|
|||||||
* Mock install.ts
|
* Mock install.ts
|
||||||
*/
|
*/
|
||||||
jest.mock('../src/install', () => ({
|
jest.mock('../src/install', () => ({
|
||||||
getScript: jest
|
getScript: jest.fn().mockImplementation(async (): Promise<string> => {
|
||||||
.fn()
|
const extension_csv: string = process.env['extensions'] || '';
|
||||||
.mockImplementation(
|
const ini_values_csv: string = process.env['ini-values'] || '';
|
||||||
async (
|
const coverage_driver: string = process.env['coverage'] || '';
|
||||||
filename: string,
|
const tools_csv: string = process.env['tools'] || '';
|
||||||
version: string,
|
let script = 'initial script';
|
||||||
os_version: string
|
script += tools_csv ? ' add_tool' : '';
|
||||||
): Promise<string> => {
|
script += extension_csv ? ' install extensions' : '';
|
||||||
const extension_csv: string = process.env['extensions'] || '';
|
script += coverage_driver ? ' set coverage driver' : '';
|
||||||
const ini_values_csv: string = process.env['ini-values'] || '';
|
script += ini_values_csv ? ' edit php.ini' : '';
|
||||||
const coverage_driver: string = process.env['coverage'] || '';
|
return script;
|
||||||
let tools_csv: string = process.env['tools'] || '';
|
}),
|
||||||
const pecl: string = process.env['pecl'] || '';
|
|
||||||
if (pecl == 'true') {
|
|
||||||
tools_csv = 'pecl, ' + tools_csv;
|
|
||||||
}
|
|
||||||
|
|
||||||
let script = 'initial script ' + filename + version + os_version;
|
|
||||||
if (tools_csv) {
|
|
||||||
script += 'add_tool';
|
|
||||||
}
|
|
||||||
if (extension_csv) {
|
|
||||||
script += 'install extensions';
|
|
||||||
}
|
|
||||||
if (coverage_driver) {
|
|
||||||
script += 'set coverage driver';
|
|
||||||
}
|
|
||||||
if (ini_values_csv) {
|
|
||||||
script += 'edit php.ini';
|
|
||||||
}
|
|
||||||
|
|
||||||
return script;
|
|
||||||
}
|
|
||||||
),
|
|
||||||
run: jest.fn().mockImplementation(async (): Promise<string> => {
|
run: jest.fn().mockImplementation(async (): Promise<string> => {
|
||||||
const os_version: string = process.env['RUNNER_OS'] || '';
|
const os_version: string = process.env['RUNNER_OS'] || '';
|
||||||
const version: string = await utils.parseVersion(
|
const version: string = await utils.parseVersion(
|
||||||
@ -83,93 +61,41 @@ function setEnv(
|
|||||||
}
|
}
|
||||||
|
|
||||||
describe('Install', () => {
|
describe('Install', () => {
|
||||||
it('Test install on windows', async () => {
|
it.each`
|
||||||
setEnv('7.0', 'win32', '', '', '', '');
|
version | os | extension_csv | ini_values_csv | coverage_driver | tools | output
|
||||||
|
${'7.3'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 7.3 ' + __dirname}
|
||||||
|
${'7.3'} | ${'darwin'} | ${'a, b'} | ${'a=b'} | ${'x'} | ${''} | ${'initial script install extensions set coverage driver edit php.ini bash darwin.sh 7.3 ' + __dirname}
|
||||||
|
${'7.4.1'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 7.4 ' + __dirname}
|
||||||
|
${'8'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.0 ' + __dirname}
|
||||||
|
${'8.0'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.0 ' + __dirname}
|
||||||
|
${'8.1'} | ${'darwin'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash darwin.sh 8.1 ' + __dirname}
|
||||||
|
${'7.3'} | ${'linux'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash linux.sh 7.3 ' + __dirname}
|
||||||
|
${'7.3'} | ${'linux'} | ${'a, b'} | ${'a=b'} | ${'x'} | ${'phpunit'} | ${'initial script add_tool install extensions set coverage driver edit php.ini bash linux.sh 7.3 ' + __dirname}
|
||||||
|
${'latest'} | ${'linux'} | ${''} | ${''} | ${''} | ${''} | ${'initial script bash linux.sh 8.1 ' + __dirname}
|
||||||
|
${'7.0'} | ${'win32'} | ${''} | ${''} | ${''} | ${''} | ${'initial script pwsh win32.ps1 7.0 ' + __dirname}
|
||||||
|
${'7.3'} | ${'win32'} | ${''} | ${''} | ${''} | ${''} | ${'initial script pwsh win32.ps1 7.3 ' + __dirname}
|
||||||
|
${'7.3'} | ${'win32'} | ${'a, b'} | ${'a=b'} | ${'x'} | ${''} | ${'initial script install extensions set coverage driver edit php.ini pwsh win32.ps1 7.3 ' + __dirname}
|
||||||
|
`(
|
||||||
|
'Test install on $os for $version with extensions=$extension_csv, ini_values=$ini_values_csv, coverage_driver=$coverage_driver, tools=$tools',
|
||||||
|
async ({
|
||||||
|
version,
|
||||||
|
os,
|
||||||
|
extension_csv,
|
||||||
|
ini_values_csv,
|
||||||
|
coverage_driver,
|
||||||
|
tools,
|
||||||
|
output
|
||||||
|
}) => {
|
||||||
|
setEnv(
|
||||||
|
version,
|
||||||
|
os,
|
||||||
|
extension_csv,
|
||||||
|
ini_values_csv,
|
||||||
|
coverage_driver,
|
||||||
|
tools
|
||||||
|
);
|
||||||
|
|
||||||
let script: string = '' + (await install.run());
|
expect(await install.run()).toBe(output);
|
||||||
expect(script).toContain('initial script');
|
}
|
||||||
expect(script).toContain('pwsh win32.ps1 7.0 ' + __dirname);
|
);
|
||||||
|
|
||||||
setEnv('7.3', 'win32', '', '', '', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('pwsh win32.ps1 7.3 ' + __dirname);
|
|
||||||
|
|
||||||
setEnv('7.3', 'win32', 'a, b', 'a=b', 'x', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('install extensions');
|
|
||||||
expect(script).toContain('edit php.ini');
|
|
||||||
expect(script).toContain('set coverage driver');
|
|
||||||
expect(script).toContain('pwsh win32.ps1 7.3 ' + __dirname);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('Test install on linux', async () => {
|
|
||||||
setEnv('7.3', 'linux', '', '', '', '');
|
|
||||||
|
|
||||||
let script: string = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash linux.sh 7.3 ');
|
|
||||||
|
|
||||||
setEnv('latest', 'linux', '', '', '', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash linux.sh 8.0 ');
|
|
||||||
|
|
||||||
setEnv('7.3', 'linux', 'a, b', 'a=b', 'x', 'phpunit');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('install extensions');
|
|
||||||
expect(script).toContain('edit php.ini');
|
|
||||||
expect(script).toContain('set coverage driver');
|
|
||||||
expect(script).toContain('bash linux.sh 7.3');
|
|
||||||
expect(script).toContain('add_tool');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('Test install on darwin', async () => {
|
|
||||||
setEnv('7.3', 'darwin', '', '', '', '');
|
|
||||||
|
|
||||||
let script: string = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash darwin.sh 7.3 ' + __dirname);
|
|
||||||
|
|
||||||
setEnv('7.3', 'darwin', 'a, b', 'a=b', 'x', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('install extensions');
|
|
||||||
expect(script).toContain('edit php.ini');
|
|
||||||
expect(script).toContain('set coverage driver');
|
|
||||||
expect(script).toContain('bash darwin.sh 7.3 ' + __dirname);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('Test malformed version inputs', async () => {
|
|
||||||
setEnv('7.4.1', 'darwin', '', '', '', '');
|
|
||||||
|
|
||||||
let script: string = '' + '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash darwin.sh 7.4 ' + __dirname);
|
|
||||||
|
|
||||||
setEnv(8.0, 'darwin', '', '', '', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash darwin.sh 8.0 ' + __dirname);
|
|
||||||
|
|
||||||
setEnv(8, 'darwin', '', '', '', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash darwin.sh 8.0 ' + __dirname);
|
|
||||||
|
|
||||||
setEnv(8.1, 'darwin', '', '', '', '');
|
|
||||||
|
|
||||||
script = '' + (await install.run());
|
|
||||||
expect(script).toContain('initial script');
|
|
||||||
expect(script).toContain('bash darwin.sh 8.1 ' + __dirname);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
@ -373,7 +373,7 @@ describe('Tools tests', () => {
|
|||||||
|
|
||||||
it.each([
|
it.each([
|
||||||
[
|
[
|
||||||
'blackfire, blackfire-player, cs2pr, flex, grpc_php_plugin, php-cs-fixer, phplint, phpstan, phpunit, pecl, phing, phinx, phinx:1.2.3, phive, phpunit-bridge, php-config, phpize, protoc, symfony, vapor, wp',
|
'blackfire, blackfire-player, cs2pr, flex, grpc_php_plugin, parallel-lint, php-cs-fixer, phpDocumentor, phplint, phpstan, phpunit, pecl, phing, phinx, phinx:1.2.3, phive, phpunit-bridge, phpunit-polyfills, php-config, phpize, protoc, symfony, vapor, wp',
|
||||||
[
|
[
|
||||||
'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-stable.phar,https://getcomposer.org/composer-stable.phar composer',
|
'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-stable.phar,https://getcomposer.org/composer-stable.phar composer',
|
||||||
'add_blackfire',
|
'add_blackfire',
|
||||||
@ -381,7 +381,9 @@ describe('Tools tests', () => {
|
|||||||
'add_tool https://github.com/staabm/annotate-pull-request-from-checkstyle/releases/latest/download/cs2pr cs2pr "-V"',
|
'add_tool https://github.com/staabm/annotate-pull-request-from-checkstyle/releases/latest/download/cs2pr cs2pr "-V"',
|
||||||
'add_composertool flex flex symfony/',
|
'add_composertool flex flex symfony/',
|
||||||
'add_grpc_php_plugin latest',
|
'add_grpc_php_plugin latest',
|
||||||
|
'add_tool https://github.com/php-parallel-lint/PHP-Parallel-Lint/releases/latest/download/parallel-lint.phar parallel-lint "--version"',
|
||||||
'add_tool https://github.com/FriendsOfPHP/PHP-CS-Fixer/releases/download/v3.2.1/php-cs-fixer.phar php-cs-fixer "-V"',
|
'add_tool https://github.com/FriendsOfPHP/PHP-CS-Fixer/releases/download/v3.2.1/php-cs-fixer.phar php-cs-fixer "-V"',
|
||||||
|
'add_tool https://github.com/phpDocumentor/phpDocumentor/releases/latest/download/phpDocumentor.phar phpDocumentor "--version"',
|
||||||
'add_composertool phplint phplint overtrue/',
|
'add_composertool phplint phplint overtrue/',
|
||||||
'add_tool https://github.com/phpstan/phpstan/releases/latest/download/phpstan.phar phpstan "-V"',
|
'add_tool https://github.com/phpstan/phpstan/releases/latest/download/phpstan.phar phpstan "-V"',
|
||||||
'add_tool https://phar.phpunit.de/phpunit.phar phpunit "--version"',
|
'add_tool https://phar.phpunit.de/phpunit.phar phpunit "--version"',
|
||||||
@ -391,6 +393,7 @@ describe('Tools tests', () => {
|
|||||||
'add_composertool phinx phinx:1.2.3 robmorgan/',
|
'add_composertool phinx phinx:1.2.3 robmorgan/',
|
||||||
'add_tool https://phar.io/releases/phive.phar phive "status"',
|
'add_tool https://phar.io/releases/phive.phar phive "status"',
|
||||||
'add_composertool phpunit-bridge phpunit-bridge symfony/',
|
'add_composertool phpunit-bridge phpunit-bridge symfony/',
|
||||||
|
'add_composertool phpunit-polyfills phpunit-polyfills yoast/',
|
||||||
'add_devtools php-config',
|
'add_devtools php-config',
|
||||||
'add_devtools phpize',
|
'add_devtools phpize',
|
||||||
'add_protoc latest',
|
'add_protoc latest',
|
||||||
@ -408,7 +411,7 @@ describe('Tools tests', () => {
|
|||||||
|
|
||||||
it.each([
|
it.each([
|
||||||
[
|
[
|
||||||
'behat, blackfire, blackfire-player, composer-normalize, composer-require-checker, composer-unused, cs2pr:1.2.3, flex, grpc_php_plugin:1.2.3, infection, phan, phan:1.2.3, phing:1.2.3, phinx, phive:1.2.3, php-config, phpcbf, phpcpd, phpcs, phpize, phpmd, phpspec, phpunit-bridge:5.6, protoc:v1.2.3, psalm, symfony-cli, symfony:1.2.3, vapor-cli, wp-cli',
|
'behat, blackfire, blackfire-player, composer-normalize, composer-require-checker, composer-unused, cs2pr:1.2.3, flex, grpc_php_plugin:1.2.3, infection, phan, phan:1.2.3, phing:1.2.3, phinx, phive:1.2.3, php-config, phpcbf, phpcpd, phpcs, phpdoc, phpize, phpmd, phpspec, phpunit-bridge:5.6, phpunit-polyfills:1.0.1, protoc:v1.2.3, psalm, symfony-cli, symfony:1.2.3, vapor-cli, wp-cli',
|
||||||
[
|
[
|
||||||
'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-stable.phar,https://getcomposer.org/composer-stable.phar composer',
|
'add_tool https://github.com/shivammathur/composer-cache/releases/latest/download/composer-stable.phar,https://getcomposer.org/composer-stable.phar composer',
|
||||||
'add_composertool behat behat behat/',
|
'add_composertool behat behat behat/',
|
||||||
@ -430,10 +433,12 @@ describe('Tools tests', () => {
|
|||||||
'add_tool https://github.com/squizlabs/PHP_CodeSniffer/releases/latest/download/phpcbf.phar phpcbf "--version"',
|
'add_tool https://github.com/squizlabs/PHP_CodeSniffer/releases/latest/download/phpcbf.phar phpcbf "--version"',
|
||||||
'add_tool https://phar.phpunit.de/phpcpd.phar phpcpd "--version"',
|
'add_tool https://phar.phpunit.de/phpcpd.phar phpcpd "--version"',
|
||||||
'add_tool https://github.com/squizlabs/PHP_CodeSniffer/releases/latest/download/phpcs.phar phpcs "--version"',
|
'add_tool https://github.com/squizlabs/PHP_CodeSniffer/releases/latest/download/phpcs.phar phpcs "--version"',
|
||||||
|
'add_tool https://github.com/phpDocumentor/phpDocumentor/releases/latest/download/phpDocumentor.phar phpDocumentor "--version"',
|
||||||
'add_devtools phpize',
|
'add_devtools phpize',
|
||||||
'add_tool https://github.com/phpmd/phpmd/releases/latest/download/phpmd.phar phpmd "--version"',
|
'add_tool https://github.com/phpmd/phpmd/releases/latest/download/phpmd.phar phpmd "--version"',
|
||||||
'add_composertool phpspec phpspec phpspec/',
|
'add_composertool phpspec phpspec phpspec/',
|
||||||
'add_composertool phpunit-bridge phpunit-bridge:5.6.* symfony/',
|
'add_composertool phpunit-bridge phpunit-bridge:5.6.* symfony/',
|
||||||
|
'add_composertool phpunit-polyfills phpunit-polyfills:1.0.1 yoast/',
|
||||||
'add_protoc 1.2.3',
|
'add_protoc 1.2.3',
|
||||||
'add_tool https://github.com/vimeo/psalm/releases/latest/download/psalm.phar psalm "-v"',
|
'add_tool https://github.com/vimeo/psalm/releases/latest/download/psalm.phar psalm "-v"',
|
||||||
'add_tool https://github.com/symfony/cli/releases/latest/download/symfony_darwin_amd64 symfony-cli "version"',
|
'add_tool https://github.com/symfony/cli/releases/latest/download/symfony_darwin_amd64 symfony-cli "version"',
|
||||||
|
@ -64,7 +64,7 @@ describe('Utils tests', () => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
expect(await utils.parseVersion('latest')).toBe('8.0');
|
expect(await utils.parseVersion('latest')).toBe('8.1');
|
||||||
expect(await utils.parseVersion('7')).toBe('7.0');
|
expect(await utils.parseVersion('7')).toBe('7.0');
|
||||||
expect(await utils.parseVersion('7.4')).toBe('7.4');
|
expect(await utils.parseVersion('7.4')).toBe('7.4');
|
||||||
expect(await utils.parseVersion('5.x')).toBe('5.6');
|
expect(await utils.parseVersion('5.x')).toBe('5.6');
|
||||||
@ -126,12 +126,9 @@ describe('Utils tests', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('checking extensionArray', async () => {
|
it('checking extensionArray', async () => {
|
||||||
expect(await utils.extensionArray('a, b, php_c, php-d')).toEqual([
|
expect(
|
||||||
'a',
|
await utils.extensionArray('a, :b, php_c, none, php-d, Zend e, :Zend f')
|
||||||
'b',
|
).toEqual(['none', 'a', ':b', 'c', 'd', 'e', ':f']);
|
||||||
'c',
|
|
||||||
'd'
|
|
||||||
]);
|
|
||||||
|
|
||||||
expect(await utils.extensionArray('')).toEqual([]);
|
expect(await utils.extensionArray('')).toEqual([]);
|
||||||
expect(await utils.extensionArray(' ')).toEqual([]);
|
expect(await utils.extensionArray(' ')).toEqual([]);
|
||||||
|
@ -7,7 +7,7 @@ branding:
|
|||||||
inputs:
|
inputs:
|
||||||
php-version:
|
php-version:
|
||||||
description: 'Setup PHP version.'
|
description: 'Setup PHP version.'
|
||||||
default: '8.0'
|
default: '8.1'
|
||||||
required: true
|
required: true
|
||||||
extensions:
|
extensions:
|
||||||
description: 'Setup PHP extensions.'
|
description: 'Setup PHP extensions.'
|
||||||
|
69
dist/index.js
vendored
69
dist/index.js
vendored
@ -111,7 +111,8 @@ const config = __importStar(__nccwpck_require__(88));
|
|||||||
async function addCoverageXdebug(extension, version, os_version, pipe) {
|
async function addCoverageXdebug(extension, version, os_version, pipe) {
|
||||||
let script = '\n';
|
let script = '\n';
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(':pcov', version, os_version, true)) + pipe;
|
(await extensions.addExtension(':pcov:false', version, os_version, true)) +
|
||||||
|
pipe;
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(extension, version, os_version, true)) +
|
(await extensions.addExtension(extension, version, os_version, true)) +
|
||||||
pipe;
|
pipe;
|
||||||
@ -124,8 +125,7 @@ async function addCoveragePCOV(version, os_version, pipe) {
|
|||||||
switch (true) {
|
switch (true) {
|
||||||
default:
|
default:
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(':xdebug', version, os_version, true)) +
|
(await extensions.addExtension(':xdebug:false', version, os_version, true)) + pipe;
|
||||||
pipe;
|
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension('pcov', version, os_version, true)) +
|
(await extensions.addExtension('pcov', version, os_version, true)) +
|
||||||
pipe;
|
pipe;
|
||||||
@ -143,10 +143,10 @@ exports.addCoveragePCOV = addCoveragePCOV;
|
|||||||
async function disableCoverage(version, os_version, pipe) {
|
async function disableCoverage(version, os_version, pipe) {
|
||||||
let script = '\n';
|
let script = '\n';
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(':pcov', version, os_version, true)) + pipe;
|
(await extensions.addExtension(':pcov:false', version, os_version, true)) +
|
||||||
script +=
|
|
||||||
(await extensions.addExtension(':xdebug', version, os_version, true)) +
|
|
||||||
pipe;
|
pipe;
|
||||||
|
script +=
|
||||||
|
(await extensions.addExtension(':xdebug:false', version, os_version, true)) + pipe;
|
||||||
script += await utils.addLog('$tick', 'none', 'Disabled Xdebug and PCOV', os_version);
|
script += await utils.addLog('$tick', 'none', 'Disabled Xdebug and PCOV', os_version);
|
||||||
return script;
|
return script;
|
||||||
}
|
}
|
||||||
@ -210,7 +210,10 @@ async function addExtensionDarwin(extension_csv, version) {
|
|||||||
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nremove_extension ' + ext_name.slice(1);
|
remove_script += '\ndisable_extension' + ext_name.replace(/:/g, ' ');
|
||||||
|
return;
|
||||||
|
case /^none$/.test(ext_name):
|
||||||
|
add_script += '\ndisable_all_shared';
|
||||||
return;
|
return;
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
case /.+-.+\/.+@.+/.test(extension):
|
||||||
add_script += await utils.parseExtensionSource(extension, ext_prefix);
|
add_script += await utils.parseExtensionSource(extension, ext_prefix);
|
||||||
@ -218,6 +221,7 @@ async function addExtensionDarwin(extension_csv, version) {
|
|||||||
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(version_extension):
|
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(version_extension):
|
||||||
case /^couchbase$|^geos$|^pdo_oci$|^oci8$|^(pecl_)?http|^pdo_firebird$/.test(extension):
|
case /^couchbase$|^geos$|^pdo_oci$|^oci8$|^(pecl_)?http|^pdo_firebird$/.test(extension):
|
||||||
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
||||||
|
case /(5\.6|7\.[0-3])phalcon3|7\.[2-4]phalcon4/.test(version_extension):
|
||||||
add_script += await utils.customPackage(ext_name, 'ext', extension, 'darwin');
|
add_script += await utils.customPackage(ext_name, 'ext', extension, 'darwin');
|
||||||
return;
|
return;
|
||||||
case /.+-(stable|beta|alpha|devel|snapshot|rc|preview)/.test(extension):
|
case /.+-(stable|beta|alpha|devel|snapshot|rc|preview)/.test(extension):
|
||||||
@ -229,10 +233,10 @@ async function addExtensionDarwin(extension_csv, version) {
|
|||||||
case /(5\.[3-6]|7\.0)pcov/.test(version_extension):
|
case /(5\.[3-6]|7\.0)pcov/.test(version_extension):
|
||||||
add_script += await utils.getUnsupportedLog('pcov', version, 'darwin');
|
add_script += await utils.getUnsupportedLog('pcov', version, 'darwin');
|
||||||
return;
|
return;
|
||||||
case /(?<!5\.[3-5])(amqp|apcu|grpc|igbinary|imagick|imap|memcache|memcached|mongodb|msgpack|protobuf|psr|raphf|rdkafka|redis|swoole|xdebug|xdebug2|yaml|zmq)/.test(version_extension):
|
case /(?<!5\.[3-5])(amqp|apcu|expect|grpc|igbinary|imagick|imap|memcache|memcached|mongodb|msgpack|protobuf|psr|raphf|rdkafka|redis|ssh2|swoole|xdebug|xdebug2|yaml|zmq)/.test(version_extension):
|
||||||
case /(5\.6|7\.[0-4])propro/.test(version_extension):
|
case /(5\.6|7\.[0-4])propro/.test(version_extension):
|
||||||
case /(?<!5\.[3-6]|7\.0)pcov/.test(version_extension):
|
case /(?<!5\.[3-6]|7\.0)pcov/.test(version_extension):
|
||||||
case /(5\.6|7\.[0-3])phalcon3|7\.[2-4]phalcon4/.test(version_extension):
|
case /(?<!5\.[3-6])(vips|xlswriter)/.test(version_extension):
|
||||||
add_script += await utils.joins('\nadd_brew_extension', ext_name, ext_prefix);
|
add_script += await utils.joins('\nadd_brew_extension', ext_name, ext_prefix);
|
||||||
return;
|
return;
|
||||||
case /^sqlite$/.test(extension):
|
case /^sqlite$/.test(extension):
|
||||||
@ -256,7 +260,10 @@ async function addExtensionWindows(extension_csv, version) {
|
|||||||
let matches;
|
let matches;
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nRemove-Extension ' + ext_name.slice(1);
|
remove_script += '\nDisable-Extension' + ext_name.replace(/:/g, ' ');
|
||||||
|
break;
|
||||||
|
case /^none$/.test(ext_name):
|
||||||
|
add_script += '\nDisable-AllShared';
|
||||||
break;
|
break;
|
||||||
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(version_extension):
|
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(version_extension):
|
||||||
case /^pdo_oci$|^oci8$|^pdo_firebird$/.test(extension):
|
case /^pdo_oci$|^oci8$|^pdo_firebird$/.test(extension):
|
||||||
@ -313,7 +320,10 @@ async function addExtensionLinux(extension_csv, version) {
|
|||||||
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nremove_extension ' + ext_name.slice(1);
|
remove_script += '\ndisable_extension' + ext_name.replace(/:/g, ' ');
|
||||||
|
return;
|
||||||
|
case /^none$/.test(ext_name):
|
||||||
|
add_script += '\ndisable_all_shared';
|
||||||
return;
|
return;
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
case /.+-.+\/.+@.+/.test(extension):
|
||||||
add_script += await utils.parseExtensionSource(extension, ext_prefix);
|
add_script += await utils.parseExtensionSource(extension, ext_prefix);
|
||||||
@ -414,8 +424,7 @@ const extensions = __importStar(__nccwpck_require__(390));
|
|||||||
const tools = __importStar(__nccwpck_require__(740));
|
const tools = __importStar(__nccwpck_require__(740));
|
||||||
const utils = __importStar(__nccwpck_require__(918));
|
const utils = __importStar(__nccwpck_require__(918));
|
||||||
async function getScript(filename, version, os_version) {
|
async function getScript(filename, version, os_version) {
|
||||||
const name = 'setup-php';
|
const url = 'https://setup-php.com/sponsor';
|
||||||
const url = 'https://setup-php.com/support';
|
|
||||||
process.env['fail_fast'] = await utils.getInput('fail-fast', false);
|
process.env['fail_fast'] = await utils.getInput('fail-fast', false);
|
||||||
const extension_csv = await utils.getInput('extensions', false);
|
const extension_csv = await utils.getInput('extensions', false);
|
||||||
const ini_values_csv = await utils.getInput('ini-values', false);
|
const ini_values_csv = await utils.getInput('ini-values', false);
|
||||||
@ -432,8 +441,8 @@ async function getScript(filename, version, os_version) {
|
|||||||
if (ini_values_csv) {
|
if (ini_values_csv) {
|
||||||
script += await config.addINIValues(ini_values_csv, os_version);
|
script += await config.addINIValues(ini_values_csv, os_version);
|
||||||
}
|
}
|
||||||
script += '\n' + (await utils.stepLog('Support this project', os_version));
|
script += '\n' + (await utils.stepLog(`Sponsor setup-php`, os_version));
|
||||||
script += '\n' + (await utils.addLog('$tick', name, url, os_version));
|
script += '\n' + (await utils.addLog('$tick', 'setup-php', url, os_version));
|
||||||
return await utils.writeScript(filename, script);
|
return await utils.writeScript(filename, script);
|
||||||
}
|
}
|
||||||
exports.getScript = getScript;
|
exports.getScript = getScript;
|
||||||
@ -449,7 +458,7 @@ async function run() {
|
|||||||
const tool = await utils.scriptTool(os_version);
|
const tool = await utils.scriptTool(os_version);
|
||||||
const script = os_version + (await utils.scriptExtension(os_version));
|
const script = os_version + (await utils.scriptExtension(os_version));
|
||||||
const location = await getScript(script, version, os_version);
|
const location = await getScript(script, version, os_version);
|
||||||
await exec_1.exec(await utils.joins(tool, location, version, __dirname));
|
await (0, exec_1.exec)(await utils.joins(tool, location, version, __dirname));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
core.setFailed('Unable to get the PHP version');
|
core.setFailed('Unable to get the PHP version');
|
||||||
@ -955,7 +964,7 @@ exports.getManifestURL = getManifestURL;
|
|||||||
async function parseVersion(version) {
|
async function parseVersion(version) {
|
||||||
const manifest = await getManifestURL();
|
const manifest = await getManifestURL();
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case /^(latest|\d+\.x)$/.test(version):
|
case /^(latest|nightly|\d+\.x)$/.test(version):
|
||||||
return JSON.parse((await fetch(manifest))['data'])[version];
|
return JSON.parse((await fetch(manifest))['data'])[version];
|
||||||
default:
|
default:
|
||||||
switch (true) {
|
switch (true) {
|
||||||
@ -1041,18 +1050,20 @@ async function extensionArray(extension_csv) {
|
|||||||
case ' ':
|
case ' ':
|
||||||
return [];
|
return [];
|
||||||
default:
|
default:
|
||||||
return extension_csv
|
return [
|
||||||
.split(',')
|
extension_csv.match(/(^|,\s?)none(\s?,|$)/) ? 'none' : '',
|
||||||
.map(function (extension) {
|
...extension_csv
|
||||||
if (/.+-.+\/.+@.+/.test(extension)) {
|
.split(',')
|
||||||
return extension;
|
.map(function (extension) {
|
||||||
}
|
if (/.+-.+\/.+@.+/.test(extension)) {
|
||||||
return extension
|
return extension;
|
||||||
.trim()
|
}
|
||||||
.toLowerCase()
|
return extension
|
||||||
.replace(/^php[-_]/, '');
|
.trim()
|
||||||
})
|
.toLowerCase()
|
||||||
.filter(Boolean);
|
.replace(/^(:)?(php[-_]|none|zend )/, '$1');
|
||||||
|
})
|
||||||
|
].filter(Boolean);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.extensionArray = extensionArray;
|
exports.extensionArray = extensionArray;
|
||||||
|
2716
package-lock.json
generated
2716
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
54
package.json
54
package.json
@ -1,14 +1,24 @@
|
|||||||
{
|
{
|
||||||
"name": "setup-php",
|
"name": "setup-php",
|
||||||
"version": "2.13.0",
|
"version": "2.15.0",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "Setup PHP for use with GitHub Actions",
|
"description": "Setup PHP for use with GitHub Actions",
|
||||||
"main": "lib/install.js",
|
"main": "lib/install.js",
|
||||||
|
"types": "lib/install.d.ts",
|
||||||
|
"directories": {
|
||||||
|
"lib": "lib",
|
||||||
|
"test": "__tests__",
|
||||||
|
"src": "src"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"lib",
|
||||||
|
"src"
|
||||||
|
],
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "tsc",
|
"build": "tsc",
|
||||||
"lint": "eslint **/*.ts --cache --fix",
|
"lint": "eslint **/src/*.ts --cache --fix",
|
||||||
"format": "prettier --write **/*.ts && git add .",
|
"format": "prettier --write **/src/*.ts && git add -f src/",
|
||||||
"format-check": "prettier --check **/*.ts",
|
"format-check": "prettier --check **/src/*.ts",
|
||||||
"release": "ncc build -o dist && git add -f dist/",
|
"release": "ncc build -o dist && git add -f dist/",
|
||||||
"test": "jest"
|
"test": "jest"
|
||||||
},
|
},
|
||||||
@ -30,27 +40,27 @@
|
|||||||
"fs": "0.0.1-security"
|
"fs": "0.0.1-security"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/jest": "^27.0.1",
|
"@types/jest": "^27.0.2",
|
||||||
"@types/node": "^16.7.1",
|
"@types/node": "^16.10.1",
|
||||||
"@typescript-eslint/eslint-plugin": "^4.29.2",
|
"@typescript-eslint/eslint-plugin": "^4.32.0",
|
||||||
"@typescript-eslint/parser": "^4.29.2",
|
"@typescript-eslint/parser": "^4.32.0",
|
||||||
"@vercel/ncc": "^0.29.2",
|
"@vercel/ncc": "^0.31.1",
|
||||||
"eslint": "^7.32.0",
|
"eslint": "^7.32.0",
|
||||||
"eslint-config-prettier": "^8.3.0",
|
"eslint-config-prettier": "^8.3.0",
|
||||||
"eslint-plugin-import": "^2.24.1",
|
"eslint-plugin-import": "^2.24.2",
|
||||||
"eslint-plugin-jest": "^24.4.0",
|
"eslint-plugin-jest": "^24.4.2",
|
||||||
"eslint-plugin-prettier": "^3.4.1",
|
"eslint-plugin-prettier": "^4.0.0",
|
||||||
"husky": "^4.3.8",
|
"jest": "^27.2.2",
|
||||||
"jest": "^27.0.6",
|
"jest-circus": "^27.2.2",
|
||||||
"jest-circus": "^27.0.6",
|
"prettier": "^2.4.1",
|
||||||
"prettier": "^2.3.2",
|
"simple-git-hooks": "^2.6.1",
|
||||||
"ts-jest": "^27.0.5",
|
"ts-jest": "^27.0.5",
|
||||||
"typescript": "^4.3.5"
|
"typescript": "^4.4.3"
|
||||||
},
|
},
|
||||||
"husky": {
|
"bugs": {
|
||||||
"skipCI": true,
|
"url": "https://github.com/shivammathur/setup-php/issues"
|
||||||
"hooks": {
|
},
|
||||||
"pre-commit": "npm run format && npm run lint && npm run test && npm run build && npm run release"
|
"simple-git-hooks": {
|
||||||
}
|
"pre-commit": "npm run format && npm run lint && npm run test && npm run build && npm run release"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
29
src/configs/brew_extensions
Normal file
29
src/configs/brew_extensions
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
amqp=amqp
|
||||||
|
apcu=apcu
|
||||||
|
expect=expect
|
||||||
|
grpc=grpc
|
||||||
|
igbinary=igbinary
|
||||||
|
imagick=imagick
|
||||||
|
imap=imap
|
||||||
|
memcache=memcache
|
||||||
|
memcached=memcached
|
||||||
|
mongodb=mongodb
|
||||||
|
msgpack=msgpack
|
||||||
|
pcov=pcov
|
||||||
|
pecl_http=http
|
||||||
|
phalcon3=phalcon
|
||||||
|
phalcon4=phalcon
|
||||||
|
propro=propro
|
||||||
|
protobuf=protobuf
|
||||||
|
psr=psr
|
||||||
|
raphf=raphf
|
||||||
|
rdkafka=rdkafka
|
||||||
|
redis=redis
|
||||||
|
ssh2=ssh2
|
||||||
|
swoole=swoole
|
||||||
|
vips=vips
|
||||||
|
xdebug=xdebug
|
||||||
|
xdebug2=xdebug
|
||||||
|
xlswriter=xlswriter
|
||||||
|
yaml=yaml
|
||||||
|
zmq=zmq
|
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"latest": "8.0",
|
"latest": "8.1",
|
||||||
|
"nightly": "8.2",
|
||||||
"5.x": "5.6",
|
"5.x": "5.6",
|
||||||
"7.x": "7.4",
|
"7.x": "7.4",
|
||||||
"8.x": "8.0"
|
"8.x": "8.1"
|
||||||
}
|
}
|
@ -31,6 +31,14 @@
|
|||||||
"version_prefix": "",
|
"version_prefix": "",
|
||||||
"version_parameter": "-v"
|
"version_parameter": "-v"
|
||||||
},
|
},
|
||||||
|
"parallel-lint": {
|
||||||
|
"type": "phar",
|
||||||
|
"repository": "php-parallel-lint/PHP-Parallel-Lint",
|
||||||
|
"extension": ".phar",
|
||||||
|
"domain": "https://github.com",
|
||||||
|
"version_prefix": "v",
|
||||||
|
"version_parameter": "--version"
|
||||||
|
},
|
||||||
"php-cs-fixer": {
|
"php-cs-fixer": {
|
||||||
"type": "phar",
|
"type": "phar",
|
||||||
"repository": "FriendsOfPHP/PHP-CS-Fixer",
|
"repository": "FriendsOfPHP/PHP-CS-Fixer",
|
||||||
@ -56,6 +64,15 @@
|
|||||||
"version_prefix": "",
|
"version_prefix": "",
|
||||||
"version_parameter": "--version"
|
"version_parameter": "--version"
|
||||||
},
|
},
|
||||||
|
"phpDocumentor": {
|
||||||
|
"type": "phar",
|
||||||
|
"repository": "phpDocumentor/phpDocumentor",
|
||||||
|
"extension": ".phar",
|
||||||
|
"domain": "https://github.com",
|
||||||
|
"alias": "phpdoc",
|
||||||
|
"version_prefix": "v",
|
||||||
|
"version_parameter": "--version"
|
||||||
|
},
|
||||||
"phpmd": {
|
"phpmd": {
|
||||||
"type": "phar",
|
"type": "phar",
|
||||||
"repository": "phpmd/phpmd",
|
"repository": "phpmd/phpmd",
|
||||||
@ -122,6 +139,10 @@
|
|||||||
"type": "composer",
|
"type": "composer",
|
||||||
"repository": "symfony/phpunit-bridge"
|
"repository": "symfony/phpunit-bridge"
|
||||||
},
|
},
|
||||||
|
"phpunit-polyfills": {
|
||||||
|
"type": "composer",
|
||||||
|
"repository": "yoast/phpunit-polyfills"
|
||||||
|
},
|
||||||
"prestissimo": {
|
"prestissimo": {
|
||||||
"type": "composer",
|
"type": "composer",
|
||||||
"repository": "hirak/prestissimo"
|
"repository": "hirak/prestissimo"
|
||||||
@ -201,7 +222,7 @@
|
|||||||
"type": "custom-function",
|
"type": "custom-function",
|
||||||
"repository": "sebastianbergmann/phpunit",
|
"repository": "sebastianbergmann/phpunit",
|
||||||
"domain": "https://phar.phpunit.de",
|
"domain": "https://phar.phpunit.de",
|
||||||
"function": "phpcpd",
|
"function": "phpunit",
|
||||||
"version_prefix": "",
|
"version_prefix": "",
|
||||||
"version_parameter": "--version"
|
"version_parameter": "--version"
|
||||||
},
|
},
|
||||||
|
@ -18,7 +18,8 @@ export async function addCoverageXdebug(
|
|||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
let script = '\n';
|
let script = '\n';
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(':pcov', version, os_version, true)) + pipe;
|
(await extensions.addExtension(':pcov:false', version, os_version, true)) +
|
||||||
|
pipe;
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(extension, version, os_version, true)) +
|
(await extensions.addExtension(extension, version, os_version, true)) +
|
||||||
pipe;
|
pipe;
|
||||||
@ -47,8 +48,12 @@ export async function addCoveragePCOV(
|
|||||||
switch (true) {
|
switch (true) {
|
||||||
default:
|
default:
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(':xdebug', version, os_version, true)) +
|
(await extensions.addExtension(
|
||||||
pipe;
|
':xdebug:false',
|
||||||
|
version,
|
||||||
|
os_version,
|
||||||
|
true
|
||||||
|
)) + pipe;
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension('pcov', version, os_version, true)) +
|
(await extensions.addExtension('pcov', version, os_version, true)) +
|
||||||
pipe;
|
pipe;
|
||||||
@ -92,10 +97,15 @@ export async function disableCoverage(
|
|||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
let script = '\n';
|
let script = '\n';
|
||||||
script +=
|
script +=
|
||||||
(await extensions.addExtension(':pcov', version, os_version, true)) + pipe;
|
(await extensions.addExtension(':pcov:false', version, os_version, true)) +
|
||||||
script +=
|
|
||||||
(await extensions.addExtension(':xdebug', version, os_version, true)) +
|
|
||||||
pipe;
|
pipe;
|
||||||
|
script +=
|
||||||
|
(await extensions.addExtension(
|
||||||
|
':xdebug:false',
|
||||||
|
version,
|
||||||
|
os_version,
|
||||||
|
true
|
||||||
|
)) + pipe;
|
||||||
script += await utils.addLog(
|
script += await utils.addLog(
|
||||||
'$tick',
|
'$tick',
|
||||||
'none',
|
'none',
|
||||||
|
@ -21,7 +21,11 @@ export async function addExtensionDarwin(
|
|||||||
switch (true) {
|
switch (true) {
|
||||||
// match :extension
|
// match :extension
|
||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nremove_extension ' + ext_name.slice(1);
|
remove_script += '\ndisable_extension' + ext_name.replace(/:/g, ' ');
|
||||||
|
return;
|
||||||
|
// Match none
|
||||||
|
case /^none$/.test(ext_name):
|
||||||
|
add_script += '\ndisable_all_shared';
|
||||||
return;
|
return;
|
||||||
// match extensions for compiling from source
|
// match extensions for compiling from source
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
case /.+-.+\/.+@.+/.test(extension):
|
||||||
@ -39,6 +43,7 @@ export async function addExtensionDarwin(
|
|||||||
extension
|
extension
|
||||||
):
|
):
|
||||||
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
||||||
|
case /(5\.6|7\.[0-3])phalcon3|7\.[2-4]phalcon4/.test(version_extension):
|
||||||
add_script += await utils.customPackage(
|
add_script += await utils.customPackage(
|
||||||
ext_name,
|
ext_name,
|
||||||
'ext',
|
'ext',
|
||||||
@ -68,15 +73,16 @@ export async function addExtensionDarwin(
|
|||||||
case /(5\.[3-6]|7\.0)pcov/.test(version_extension):
|
case /(5\.[3-6]|7\.0)pcov/.test(version_extension):
|
||||||
add_script += await utils.getUnsupportedLog('pcov', version, 'darwin');
|
add_script += await utils.getUnsupportedLog('pcov', version, 'darwin');
|
||||||
return;
|
return;
|
||||||
// match 5.6 and newer - amqp, apcu, grpc, igbinary, imagick, imap, memcache, memcached, mongodb, msgpack, protobuf, raphf, rdkafka, redis, swoole, xdebug, xdebug2, yaml, zmq
|
// match 5.6 and newer - amqp, apcu, expect, grpc, igbinary, imagick, imap, memcache, memcached, mongodb, msgpack, protobuf, raphf, rdkafka, redis, ssh2, swoole, xdebug, xdebug2, yaml, zmq
|
||||||
// match 7.1 and newer - pcov
|
// match 7.1 and newer - pcov
|
||||||
// match 5.6 to 7.4 - propro
|
// match 5.6 to 7.4 - propro
|
||||||
case /(?<!5\.[3-5])(amqp|apcu|grpc|igbinary|imagick|imap|memcache|memcached|mongodb|msgpack|protobuf|psr|raphf|rdkafka|redis|swoole|xdebug|xdebug2|yaml|zmq)/.test(
|
// match 7.0 and newer - vips, xlswriter
|
||||||
|
case /(?<!5\.[3-5])(amqp|apcu|expect|grpc|igbinary|imagick|imap|memcache|memcached|mongodb|msgpack|protobuf|psr|raphf|rdkafka|redis|ssh2|swoole|xdebug|xdebug2|yaml|zmq)/.test(
|
||||||
version_extension
|
version_extension
|
||||||
):
|
):
|
||||||
case /(5\.6|7\.[0-4])propro/.test(version_extension):
|
case /(5\.6|7\.[0-4])propro/.test(version_extension):
|
||||||
case /(?<!5\.[3-6]|7\.0)pcov/.test(version_extension):
|
case /(?<!5\.[3-6]|7\.0)pcov/.test(version_extension):
|
||||||
case /(5\.6|7\.[0-3])phalcon3|7\.[2-4]phalcon4/.test(version_extension):
|
case /(?<!5\.[3-6])(vips|xlswriter)/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nadd_brew_extension',
|
'\nadd_brew_extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
@ -115,7 +121,11 @@ export async function addExtensionWindows(
|
|||||||
switch (true) {
|
switch (true) {
|
||||||
// Match :extension
|
// Match :extension
|
||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nRemove-Extension ' + ext_name.slice(1);
|
remove_script += '\nDisable-Extension' + ext_name.replace(/:/g, ' ');
|
||||||
|
break;
|
||||||
|
// Match none
|
||||||
|
case /^none$/.test(ext_name):
|
||||||
|
add_script += '\nDisable-AllShared';
|
||||||
break;
|
break;
|
||||||
// match 5.3blackfire...8.0blackfire
|
// match 5.3blackfire...8.0blackfire
|
||||||
// match 5.3blackfire-(semver)...8.0blackfire-(semver)
|
// match 5.3blackfire-(semver)...8.0blackfire-(semver)
|
||||||
@ -227,7 +237,11 @@ export async function addExtensionLinux(
|
|||||||
switch (true) {
|
switch (true) {
|
||||||
// Match :extension
|
// Match :extension
|
||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nremove_extension ' + ext_name.slice(1);
|
remove_script += '\ndisable_extension' + ext_name.replace(/:/g, ' ');
|
||||||
|
return;
|
||||||
|
// Match none
|
||||||
|
case /^none$/.test(ext_name):
|
||||||
|
add_script += '\ndisable_all_shared';
|
||||||
return;
|
return;
|
||||||
// match extensions for compiling from source
|
// match extensions for compiling from source
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
case /.+-.+\/.+@.+/.test(extension):
|
||||||
|
@ -18,8 +18,7 @@ export async function getScript(
|
|||||||
version: string,
|
version: string,
|
||||||
os_version: string
|
os_version: string
|
||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
const name = 'setup-php';
|
const url = 'https://setup-php.com/sponsor';
|
||||||
const url = 'https://setup-php.com/support';
|
|
||||||
// taking inputs
|
// taking inputs
|
||||||
process.env['fail_fast'] = await utils.getInput('fail-fast', false);
|
process.env['fail_fast'] = await utils.getInput('fail-fast', false);
|
||||||
const extension_csv: string = await utils.getInput('extensions', false);
|
const extension_csv: string = await utils.getInput('extensions', false);
|
||||||
@ -29,7 +28,6 @@ export async function getScript(
|
|||||||
|
|
||||||
let script: string = await utils.readFile(filename, 'src/scripts');
|
let script: string = await utils.readFile(filename, 'src/scripts');
|
||||||
script += await tools.addTools(tools_csv, version, os_version);
|
script += await tools.addTools(tools_csv, version, os_version);
|
||||||
|
|
||||||
if (extension_csv) {
|
if (extension_csv) {
|
||||||
script += await extensions.addExtension(extension_csv, version, os_version);
|
script += await extensions.addExtension(extension_csv, version, os_version);
|
||||||
}
|
}
|
||||||
@ -39,9 +37,8 @@ export async function getScript(
|
|||||||
if (ini_values_csv) {
|
if (ini_values_csv) {
|
||||||
script += await config.addINIValues(ini_values_csv, os_version);
|
script += await config.addINIValues(ini_values_csv, os_version);
|
||||||
}
|
}
|
||||||
|
script += '\n' + (await utils.stepLog(`Sponsor setup-php`, os_version));
|
||||||
script += '\n' + (await utils.stepLog('Support this project', os_version));
|
script += '\n' + (await utils.addLog('$tick', 'setup-php', url, os_version));
|
||||||
script += '\n' + (await utils.addLog('$tick', name, url, os_version));
|
|
||||||
|
|
||||||
return await utils.writeScript(filename, script);
|
return await utils.writeScript(filename, script);
|
||||||
}
|
}
|
||||||
@ -70,7 +67,7 @@ export async function run(): Promise<void> {
|
|||||||
core.setFailed('Unable to get the PHP version');
|
core.setFailed('Unable to get the PHP version');
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message);
|
core.setFailed((error as Error).message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ self_hosted_setup() {
|
|||||||
|
|
||||||
# Function to test if extension is loaded.
|
# Function to test if extension is loaded.
|
||||||
check_extension() {
|
check_extension() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
if [ "$extension" != "mysql" ]; then
|
if [ "$extension" != "mysql" ]; then
|
||||||
php -m | grep -i -q -w "$extension"
|
php -m | grep -i -q -w "$extension"
|
||||||
else
|
else
|
||||||
@ -102,22 +102,23 @@ check_extension() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to enable cached extensions.
|
# Function to check if extension is shared
|
||||||
enable_cache_extension() {
|
shared_extension() {
|
||||||
deps=()
|
[ -e "${ext_dir:?}/$1.so" ]
|
||||||
for ext in /tmp/extcache/"$1"/*; do
|
}
|
||||||
deps+=("$(basename "$ext")")
|
|
||||||
done
|
# Function to enable cached extension's dependencies.
|
||||||
if [ "x${deps[*]}" = "x" ]; then
|
enable_cache_extension_dependencies() {
|
||||||
sudo rm -rf /tmp/extcache/"$1"
|
if [ -d /tmp/extcache ] && shared_extension "$1"; then
|
||||||
enable_extension "$1" "$2"
|
cache_dir=$(find /tmp/extcache -maxdepth 1 -type d -regex ".*$1[0-9]*")
|
||||||
else
|
if [[ -n "$cache_dir" ]]; then
|
||||||
deps+=("$1")
|
IFS=" " read -r -a deps <<<"$(find "$cache_dir" -maxdepth 1 -type f -name "*" -exec basename {} \; | tr '\n' ' ')"
|
||||||
if php "${deps[@]/#/-d ${2}=}" -m 2>/dev/null | grep -i -q "$1"; then
|
if [[ -n "${deps[*]}" ]] && php "${deps[@]/#/-d ${2}=}" -d "${2}=$1" -m 2>/dev/null | grep -i -q "$1"; then
|
||||||
for ext in "${deps[@]}"; do
|
for ext in "${deps[@]}"; do
|
||||||
sudo rm -rf /tmp/extcache/"$ext"
|
sudo rm -rf /tmp/extcache/"$ext"
|
||||||
enable_extension "$ext" "$2"
|
enable_extension "$ext" "$2"
|
||||||
done
|
done
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -126,13 +127,64 @@ enable_cache_extension() {
|
|||||||
enable_extension() {
|
enable_extension() {
|
||||||
modules_dir="/var/lib/php/modules/$version"
|
modules_dir="/var/lib/php/modules/$version"
|
||||||
[ -d "$modules_dir" ] && sudo find "$modules_dir" -path "*disabled*$1" -delete
|
[ -d "$modules_dir" ] && sudo find "$modules_dir" -path "*disabled*$1" -delete
|
||||||
if [ -d /tmp/extcache/"$1" ]; then
|
enable_extension_dependencies "$1" "$2"
|
||||||
enable_cache_extension "$1" "$2"
|
enable_cache_extension_dependencies "$1" "$2"
|
||||||
elif ! check_extension "$1" && [ -e "${ext_dir:?}/$1.so" ]; then
|
if ! check_extension "$1" && shared_extension "$1"; then
|
||||||
echo "$2=${ext_dir:?}/$1.so" | sudo tee -a "${pecl_file:-${ini_file[@]}}" >/dev/null
|
echo "$2=${ext_dir:?}/$1.so" | sudo tee -a "${pecl_file:-${ini_file[@]}}" >/dev/null
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to get a map of extensions and their dependent shared extensions.
|
||||||
|
get_extension_map() {
|
||||||
|
php -d'error_reporting=0' "${dist:?}"/../src/scripts/ext/extension_map.php
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to enable extension dependencies which are also extensions.
|
||||||
|
enable_extension_dependencies() {
|
||||||
|
local extension=$1
|
||||||
|
prefix=$2
|
||||||
|
if ! [ -e /tmp/map.orig ]; then
|
||||||
|
get_extension_map | sudo tee /tmp/map.orig >/dev/null
|
||||||
|
fi
|
||||||
|
for dependency in $(grep "$extension:" /tmp/map.orig | cut -d ':' -f 2 | tr '\n' ' '); do
|
||||||
|
enable_extension "$dependency" "$prefix"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to disable dependent extensions.
|
||||||
|
disable_extension_dependents() {
|
||||||
|
local extension=$1
|
||||||
|
for dependent in $(get_extension_map | grep -E ".*:.*\s$extension(\s|$)" | cut -d ':' -f 1 | tr '\n' ' '); do
|
||||||
|
disable_extension_helper "$dependent" true
|
||||||
|
add_log "${tick:?}" ":$extension" "Disabled $dependent as it depends on $extension"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to disable an extension.
|
||||||
|
disable_extension() {
|
||||||
|
local extension=$1
|
||||||
|
if check_extension "$extension"; then
|
||||||
|
if shared_extension "$extension"; then
|
||||||
|
disable_extension_helper "$extension" true
|
||||||
|
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Disabled") ||
|
||||||
|
add_log "${cross:?}" ":$extension" "Could not disable $extension on PHP ${semver:?}"
|
||||||
|
else
|
||||||
|
add_log "${cross:?}" ":$extension" "Could not disable $extension on PHP $semver as it not a shared extension"
|
||||||
|
fi
|
||||||
|
elif shared_extension "$extension"; then
|
||||||
|
add_log "${tick:?}" ":$extension" "Disabled"
|
||||||
|
else
|
||||||
|
add_log "${tick:?}" ":$extension" "Could not find $extension on PHP $semver"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to disable shared extensions.
|
||||||
|
disable_all_shared() {
|
||||||
|
sudo sed -i.orig -E -e "/^(zend_)?extension\s*=/d" "${ini_file[@]}" "$pecl_file" 2>/dev/null || true
|
||||||
|
sudo find "${ini_dir:-$scan_dir}"/.. -name "*.ini" -not -path "*php.ini" -not -path "*mods-available*" -delete >/dev/null 2>&1 || true
|
||||||
|
add_log "${tick:?}" "none" "Disabled all shared extensions"
|
||||||
|
}
|
||||||
|
|
||||||
# Function to configure PHP
|
# Function to configure PHP
|
||||||
configure_php() {
|
configure_php() {
|
||||||
(
|
(
|
||||||
@ -155,7 +207,7 @@ configure_pecl() {
|
|||||||
|
|
||||||
# Function to get the PECL version of an extension.
|
# Function to get the PECL version of an extension.
|
||||||
get_pecl_version() {
|
get_pecl_version() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
stability="$(echo "$2" | grep -m 1 -Eio "(stable|alpha|beta|rc|snapshot|preview)")"
|
stability="$(echo "$2" | grep -m 1 -Eio "(stable|alpha|beta|rc|snapshot|preview)")"
|
||||||
pecl_rest='https://pecl.php.net/rest/r/'
|
pecl_rest='https://pecl.php.net/rest/r/'
|
||||||
response=$(get -s -n "" "$pecl_rest$extension"/allreleases.xml)
|
response=$(get -s -n "" "$pecl_rest$extension"/allreleases.xml)
|
||||||
@ -175,7 +227,7 @@ pecl_install() {
|
|||||||
|
|
||||||
# Function to install a specific version of PECL extension.
|
# Function to install a specific version of PECL extension.
|
||||||
add_pecl_extension() {
|
add_pecl_extension() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
pecl_version=$2
|
pecl_version=$2
|
||||||
prefix=$3
|
prefix=$3
|
||||||
enable_extension "$extension" "$prefix"
|
enable_extension "$extension" "$prefix"
|
||||||
@ -186,8 +238,7 @@ add_pecl_extension() {
|
|||||||
if [ "$ext_version" = "$pecl_version" ]; then
|
if [ "$ext_version" = "$pecl_version" ]; then
|
||||||
add_log "${tick:?}" "$extension" "Enabled"
|
add_log "${tick:?}" "$extension" "Enabled"
|
||||||
else
|
else
|
||||||
disable_extension "$extension" >/dev/null 2>&1
|
disable_extension_helper "$extension" >/dev/null 2>&1
|
||||||
delete_extension "$extension" >/dev/null 2>&1
|
|
||||||
pecl_install "$extension-$pecl_version"
|
pecl_install "$extension-$pecl_version"
|
||||||
add_extension_log "$extension-$pecl_version" "Installed and enabled"
|
add_extension_log "$extension-$pecl_version" "Installed and enabled"
|
||||||
fi
|
fi
|
||||||
@ -195,7 +246,7 @@ add_pecl_extension() {
|
|||||||
|
|
||||||
# Function to setup pre-release extensions using PECL.
|
# Function to setup pre-release extensions using PECL.
|
||||||
add_unstable_extension() {
|
add_unstable_extension() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
stability=$2
|
stability=$2
|
||||||
prefix=$3
|
prefix=$3
|
||||||
pecl_version=$(get_pecl_version "$extension" "$stability")
|
pecl_version=$(get_pecl_version "$extension" "$stability")
|
||||||
@ -301,14 +352,15 @@ add_composertool() {
|
|||||||
|
|
||||||
# Function to get PHP version in semver format.
|
# Function to get PHP version in semver format.
|
||||||
php_semver() {
|
php_semver() {
|
||||||
php -v | grep -Eo -m 1 "[0-9]+\.[0-9]+\.[0-9]+(-[a-zA-Z]+([0-9]+)?)?" | head -n 1
|
php -v | grep -Eo -m 1 "[0-9]+\.[0-9]+\.[0-9]+((-?[a-zA-Z]+([0-9]+)?)?){2}" | head -n 1
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to get the tag for a php version.
|
# Function to get the tag for a php version.
|
||||||
php_src_tag() {
|
php_src_tag() {
|
||||||
php_src_tag='master'
|
commit=$(php_extra_version | grep -Eo "[0-9a-zA-Z]+")
|
||||||
if ! [[ ${version:?} =~ $nightly_versions ]]; then
|
if [[ -n "${commit}" ]]; then
|
||||||
php_src_tag="php-$semver"
|
echo "$commit"
|
||||||
|
else
|
||||||
|
echo "php-$semver"
|
||||||
fi
|
fi
|
||||||
echo "$php_src_tag"
|
|
||||||
}
|
}
|
||||||
|
@ -7,31 +7,29 @@ self_hosted_helper() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to delete extension.
|
# Disable dependency extensions
|
||||||
delete_extension() {
|
disable_dependency_extensions() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
sudo rm -rf "${scan_dir:?}"/*"$extension"* "${ext_dir:?}"/"$extension".so >/dev/null 2>&1
|
formula_file="$tap_dir/$ext_tap/Formula/$extension@${version:?}.rb"
|
||||||
}
|
if [ -e "$formula_file" ]; then
|
||||||
|
IFS=" " read -r -a dependency_extensions <<< "$(grep -Eo "shivammathur.*@" "$formula_file" | xargs -I {} -n 1 basename '{}' | cut -d '@' -f 1 | tr '\n' ' ')"
|
||||||
# Function to disable extension.
|
for dependency_extension in "${dependency_extensions[@]}"; do
|
||||||
disable_extension() {
|
sudo sed -Ei '' "/=(.*\/)?\"?$dependency_extension(.so)?$/d" "${ini_file:?}"
|
||||||
extension=$1
|
done
|
||||||
sudo sed -Ei '' "/=(.*\/)?\"?$extension(.so)?$/d" "${ini_file:?}"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to remove extensions.
|
|
||||||
remove_extension() {
|
|
||||||
extension=$1
|
|
||||||
if check_extension "$extension"; then
|
|
||||||
disable_extension "$extension"
|
|
||||||
delete_extension "$extension"
|
|
||||||
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Removed") ||
|
|
||||||
add_log "${cross:?}" ":$extension" "Could not remove $extension on PHP ${semver:?}"
|
|
||||||
else
|
|
||||||
add_log "${tick:?}" ":$extension" "Could not find $extension on PHP $semver"
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Helper function to disable an extension.
|
||||||
|
disable_extension_helper() {
|
||||||
|
local extension=$1
|
||||||
|
local disable_dependents=${2:-false}
|
||||||
|
if [ "$disable_dependents" = "true" ]; then
|
||||||
|
disable_extension_dependents "$extension"
|
||||||
|
fi
|
||||||
|
sudo sed -Ei '' "/=(.*\/)?\"?$extension(.so)?$/d" "${ini_file:?}"
|
||||||
|
sudo rm -rf "$scan_dir"/*"$extension"*
|
||||||
|
}
|
||||||
|
|
||||||
# Function to fetch a brew tap.
|
# Function to fetch a brew tap.
|
||||||
fetch_brew_tap() {
|
fetch_brew_tap() {
|
||||||
tap=$1
|
tap=$1
|
||||||
@ -63,15 +61,17 @@ add_brew_tap() {
|
|||||||
add_brew_extension() {
|
add_brew_extension() {
|
||||||
formula=$1
|
formula=$1
|
||||||
prefix=$2
|
prefix=$2
|
||||||
extension="$(echo "$formula" | sed -E "s/pecl_|[0-9]//g")"
|
extension=$(grep "$formula=" "$dist"/../src/configs/brew_extensions | cut -d '=' -f 2)
|
||||||
|
[[ -z "$extension" ]] && extension="$(echo "$formula" | sed -E "s/pecl_|[0-9]//g")"
|
||||||
enable_extension "$extension" "$prefix"
|
enable_extension "$extension" "$prefix"
|
||||||
if check_extension "$extension"; then
|
if check_extension "$extension"; then
|
||||||
add_log "${tick:?}" "$extension" "Enabled"
|
add_log "${tick:?}" "$extension" "Enabled"
|
||||||
else
|
else
|
||||||
add_brew_tap shivammathur/homebrew-php
|
add_brew_tap "$php_tap"
|
||||||
add_brew_tap shivammathur/homebrew-extensions
|
add_brew_tap "$ext_tap"
|
||||||
sudo mv "$tap_dir"/shivammathur/homebrew-extensions/.github/deps/"$formula"/* "$tap_dir/homebrew/homebrew-core/Formula/" 2>/dev/null || true
|
sudo mv "$tap_dir"/"$ext_tap"/.github/deps/"$formula"/* "$core_repo/Formula/" 2>/dev/null || true
|
||||||
update_dependencies >/dev/null 2>&1
|
update_dependencies >/dev/null 2>&1
|
||||||
|
disable_dependency_extensions "$extension" >/dev/null 2>&1
|
||||||
brew install -f "$formula@$version" >/dev/null 2>&1
|
brew install -f "$formula@$version" >/dev/null 2>&1
|
||||||
sudo cp "$brew_prefix/opt/$formula@$version/$extension.so" "$ext_dir"
|
sudo cp "$brew_prefix/opt/$formula@$version/$extension.so" "$ext_dir"
|
||||||
add_extension_log "$extension" "Installed and enabled"
|
add_extension_log "$extension" "Installed and enabled"
|
||||||
@ -80,7 +80,7 @@ add_brew_extension() {
|
|||||||
|
|
||||||
# Function to setup extensions.
|
# Function to setup extensions.
|
||||||
add_extension() {
|
add_extension() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
prefix=$2
|
prefix=$2
|
||||||
enable_extension "$extension" "$prefix"
|
enable_extension "$extension" "$prefix"
|
||||||
if check_extension "$extension"; then
|
if check_extension "$extension"; then
|
||||||
@ -105,8 +105,8 @@ add_devtools() {
|
|||||||
# Function to handle request to add PECL.
|
# Function to handle request to add PECL.
|
||||||
add_pecl() {
|
add_pecl() {
|
||||||
configure_pecl >/dev/null 2>&1
|
configure_pecl >/dev/null 2>&1
|
||||||
pecl_version=$(get_tool_version "pecl" "version")
|
pear_version=$(get_tool_version "pecl" "version")
|
||||||
add_log "${tick:?}" "PECL" "Found PECL $pecl_version"
|
add_log "${tick:?}" "PECL" "Found PECL $pear_version"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to link all libraries of a formula.
|
# Function to link all libraries of a formula.
|
||||||
@ -132,19 +132,23 @@ patch_brew() {
|
|||||||
# Helper function to update the dependencies.
|
# Helper function to update the dependencies.
|
||||||
update_dependencies_helper() {
|
update_dependencies_helper() {
|
||||||
dependency=$1
|
dependency=$1
|
||||||
get -q -n "$tap_dir/homebrew/homebrew-core/Formula/$dependency.rb" "https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/$dependency.rb"
|
get -q -n "$core_repo/Formula/$dependency.rb" "https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/$dependency.rb"
|
||||||
link_libraries "$dependency"
|
link_libraries "$dependency"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to update dependencies.
|
# Function to update dependencies.
|
||||||
update_dependencies() {
|
update_dependencies() {
|
||||||
if ! [ -e /tmp/update_dependencies ] && [ "${runner:?}" != "self-hosted" ] && [ "${ImageOS:-}" != "" ] && [ "${ImageVersion:-}" != "" ]; then
|
if ! [ -e /tmp/update_dependencies ]; then
|
||||||
patch_brew
|
if [ "${runner:?}" != "self-hosted" ] && [ "${ImageOS:-}" != "" ] && [ "${ImageVersion:-}" != "" ]; then
|
||||||
while read -r dependency; do
|
patch_brew
|
||||||
update_dependencies_helper "$dependency" &
|
while read -r dependency; do
|
||||||
to_wait+=($!)
|
update_dependencies_helper "$dependency" &
|
||||||
done <"$tap_dir/shivammathur/homebrew-php/.github/deps/${ImageOS:?}_${ImageVersion:?}"
|
to_wait+=($!)
|
||||||
wait "${to_wait[@]}"
|
done <"$tap_dir/$php_tap/.github/deps/${ImageOS:?}_${ImageVersion:?}"
|
||||||
|
wait "${to_wait[@]}"
|
||||||
|
else
|
||||||
|
git -C "$core_repo" fetch origin master && git -C "$core_repo" reset --hard origin/master
|
||||||
|
fi
|
||||||
echo '' | sudo tee /tmp/update_dependencies >/dev/null 2>&1
|
echo '' | sudo tee /tmp/update_dependencies >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -174,7 +178,7 @@ get_brewed_php() {
|
|||||||
add_php() {
|
add_php() {
|
||||||
action=$1
|
action=$1
|
||||||
existing_version=$2
|
existing_version=$2
|
||||||
add_brew_tap shivammathur/homebrew-php
|
add_brew_tap "$php_tap"
|
||||||
update_dependencies
|
update_dependencies
|
||||||
if [ "$existing_version" != "false" ]; then
|
if [ "$existing_version" != "false" ]; then
|
||||||
([ "$action" = "upgrade" ] && brew upgrade -f "$php_formula") || brew unlink "$php_formula"
|
([ "$action" = "upgrade" ] && brew upgrade -f "$php_formula") || brew unlink "$php_formula"
|
||||||
@ -186,8 +190,9 @@ add_php() {
|
|||||||
|
|
||||||
# Function to get extra version.
|
# Function to get extra version.
|
||||||
php_extra_version() {
|
php_extra_version() {
|
||||||
if [[ ${version:?} =~ ${nightly_versions:?} ]]; then
|
php_formula_file="$tap_dir"/"$php_tap"/Formula/php@"$version".rb
|
||||||
echo " ($(brew cat "$php_formula" | grep -Eo "commit=[0-9a-zA-Z]+" | cut -d'=' -f 2))"
|
if [ -e "$php_formula_file" ] && ! grep -q "deprecate!" "$php_formula_file" && grep -Eq "archive/[0-9a-zA-Z]+" "$php_formula_file"; then
|
||||||
|
echo " ($(grep -Eo "archive/[0-9a-zA-Z]+" "$php_formula_file" | cut -d'/' -f 2))"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -217,11 +222,11 @@ setup_php() {
|
|||||||
semver=$(php_semver)
|
semver=$(php_semver)
|
||||||
extra_version=$(php_extra_version)
|
extra_version=$(php_extra_version)
|
||||||
if [ "${semver%.*}" != "$version" ]; then
|
if [ "${semver%.*}" != "$version" ]; then
|
||||||
add_log "$cross" "PHP" "Could not setup PHP $version"
|
add_log "${cross:?}" "PHP" "Could not setup PHP $version"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sudo cp "$dist"/../src/configs/*.json "$RUNNER_TOOL_CACHE/"
|
sudo cp "$dist"/../src/configs/pm/*.json "$RUNNER_TOOL_CACHE/"
|
||||||
echo "::set-output name=php-version::$semver"
|
echo "::set-output name=php-version::$semver"
|
||||||
add_log "$tick" "PHP" "$status PHP $semver$extra_version"
|
add_log "$tick" "PHP" "$status PHP $semver$extra_version"
|
||||||
}
|
}
|
||||||
@ -233,7 +238,10 @@ php_formula=shivammathur/php/php@"$version"
|
|||||||
brew_prefix="$(brew --prefix)"
|
brew_prefix="$(brew --prefix)"
|
||||||
brew_repo="$(brew --repository)"
|
brew_repo="$(brew --repository)"
|
||||||
tap_dir="$brew_repo"/Library/Taps
|
tap_dir="$brew_repo"/Library/Taps
|
||||||
|
core_repo="$tap_dir"/homebrew/homebrew-core
|
||||||
scripts="${dist}"/../src/scripts
|
scripts="${dist}"/../src/scripts
|
||||||
|
ext_tap=shivammathur/homebrew-extensions
|
||||||
|
php_tap=shivammathur/homebrew-php
|
||||||
export HOMEBREW_CHANGE_ARCH_TO_ARM=1
|
export HOMEBREW_CHANGE_ARCH_TO_ARM=1
|
||||||
export HOMEBREW_DEVELOPER=1
|
export HOMEBREW_DEVELOPER=1
|
||||||
export HOMEBREW_NO_INSTALL_CLEANUP=1
|
export HOMEBREW_NO_INSTALL_CLEANUP=1
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
# Function to install blackfire extension.
|
# Function to install blackfire extension.
|
||||||
add_blackfire() {
|
add_blackfire() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
version=${version:?}
|
version=${version:?}
|
||||||
no_dot_version=${version/./}
|
no_dot_version=${version/./}
|
||||||
platform=$(uname -s | tr '[:upper:]' '[:lower:]')
|
platform=$(uname -s | tr '[:upper:]' '[:lower:]')
|
||||||
extension_version=$(echo "$extension" | cut -d '-' -f 2)
|
extension_version=$(echo "$extension" | cut -d '-' -f 2)
|
||||||
blackfire_ini_file="${pecl_file:-${ini_file[@]}}"
|
status='Enabled'
|
||||||
if [ ! -e "${ext_dir:?}/blackfire.so" ]; then
|
if ! shared_extension blackfire; then
|
||||||
|
status='Installed and enabled'
|
||||||
if [ "$extension_version" = "blackfire" ]; then
|
if [ "$extension_version" = "blackfire" ]; then
|
||||||
if [[ ${version:?} =~ 5.[3-6] ]]; then
|
if [[ ${version:?} =~ 5.[3-6] ]]; then
|
||||||
extension_version='1.50.0'
|
extension_version='1.50.0'
|
||||||
@ -16,6 +17,6 @@ add_blackfire() {
|
|||||||
fi
|
fi
|
||||||
get -q -n "${ext_dir:?}/blackfire.so" https://packages.blackfire.io/binaries/blackfire-php/"$extension_version"/blackfire-php-"$platform"_amd64-php-"$no_dot_version".so >/dev/null 2>&1
|
get -q -n "${ext_dir:?}/blackfire.so" https://packages.blackfire.io/binaries/blackfire-php/"$extension_version"/blackfire-php-"$platform"_amd64-php-"$no_dot_version".so >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
echo "extension=blackfire.so" | sudo tee -a "$blackfire_ini_file" >/dev/null 2>&1
|
enable_extension blackfire extension
|
||||||
add_extension_log "$extension-$extension_version" "Installed and enabled"
|
add_extension_log blackfire "$status"
|
||||||
}
|
}
|
||||||
|
109
src/scripts/ext/extension_map.php
Normal file
109
src/scripts/ext/extension_map.php
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for a map of extensions and their dependent extensions.
|
||||||
|
*
|
||||||
|
* Class ExtensionMap
|
||||||
|
*/
|
||||||
|
class ExtensionMap {
|
||||||
|
/** @var string Directory in which shared extensions are stored. */
|
||||||
|
private $extension_dir;
|
||||||
|
|
||||||
|
/** @var string File extension for PHP extension file. */
|
||||||
|
private $file_extension;
|
||||||
|
|
||||||
|
/** @var string Prefix in PHP extension file. */
|
||||||
|
private $file_prefix;
|
||||||
|
|
||||||
|
/** @var string String to store the map */
|
||||||
|
private $map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ExtensionMap constructor.
|
||||||
|
*/
|
||||||
|
function __construct() {
|
||||||
|
$this->extension_dir = ini_get('extension_dir');
|
||||||
|
$this->file_extension = (PHP_OS == 'WINNT' ? '.dll' : '.so');
|
||||||
|
$this->file_prefix = (PHP_OS == 'WINNT' ? 'php_' : '');
|
||||||
|
$this->map = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to check if a shared extension file exists.
|
||||||
|
*
|
||||||
|
* @param string $extension
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function checkSharedExtension($extension) {
|
||||||
|
$extension_file = $this->extension_dir. DIRECTORY_SEPARATOR . $this->file_prefix . $extension . $this->file_extension;
|
||||||
|
return file_exists($extension_file);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to get all shared extensions.
|
||||||
|
*
|
||||||
|
* @return string[]
|
||||||
|
*/
|
||||||
|
public function getSharedExtensions() {
|
||||||
|
$files = scandir($this->extension_dir);
|
||||||
|
$extensions = array_diff($files, array('.','..'));
|
||||||
|
$filter_pattern = "/$this->file_extension|$this->file_prefix/";
|
||||||
|
return array_map(function ($extension) use($filter_pattern) {
|
||||||
|
return preg_replace($filter_pattern, '', $extension);
|
||||||
|
}, $extensions);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to patch dependencies if there are any bugs in Reflection data.
|
||||||
|
*
|
||||||
|
* @param string $extension
|
||||||
|
* @param array $dependencies
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function patchDependencies($extension, $dependencies) {
|
||||||
|
// memcached 2.2.0 has no dependencies in reflection data.
|
||||||
|
if($extension == 'memcached') {
|
||||||
|
$dependencies = array_unique(array_merge($dependencies, array('igbinary', 'json', 'msgpack')));
|
||||||
|
}
|
||||||
|
return $dependencies;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to add extension to the map.
|
||||||
|
*
|
||||||
|
* @param string $extension
|
||||||
|
* @throws ReflectionException
|
||||||
|
*/
|
||||||
|
public function addExtensionToMap($extension) {
|
||||||
|
// PHP 5.3 does not allow using $this.
|
||||||
|
$self = $this;
|
||||||
|
|
||||||
|
$ref = new ReflectionExtension($extension);
|
||||||
|
$dependencies = array_keys(array_map('strtolower', $ref->getDependencies()));
|
||||||
|
$dependencies = $this->patchDependencies($extension, $dependencies);
|
||||||
|
$dependencies = array_filter($dependencies, function ($dependency) use ($self) {
|
||||||
|
return $self->checkSharedExtension($dependency);
|
||||||
|
});
|
||||||
|
$self->map .= $extension . ': ' . implode(' ', $dependencies) . PHP_EOL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to print the map of shared extensions and their dependent extensions.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function __toString() {
|
||||||
|
$extensions = array_map('strtolower', $this->getSharedExtensions());
|
||||||
|
foreach ($extensions as $extension) {
|
||||||
|
try {
|
||||||
|
$this->addExtensionToMap($extension);
|
||||||
|
} catch (ReflectionException $e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $this->map;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$extension_map = new ExtensionMap();
|
||||||
|
echo $extension_map;
|
@ -18,8 +18,13 @@ add_firebird_helper() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
add_firebird() {
|
add_firebird() {
|
||||||
enable_extension pdo_firebird
|
if [ "$(uname -s )" = "Darwin" ]; then
|
||||||
|
add_firebird_client_darwin >/dev/null 2>&1
|
||||||
|
fi
|
||||||
|
enable_extension pdo_firebird extension
|
||||||
|
status="Enabled"
|
||||||
if ! check_extension pdo_firebird; then
|
if ! check_extension pdo_firebird; then
|
||||||
|
status="Installed and enabled"
|
||||||
if [ "$(uname -s)" = "Linux" ]; then
|
if [ "$(uname -s)" = "Linux" ]; then
|
||||||
if [[ "${version:?}" =~ 5.3|${nightly_versions:?} ]]; then
|
if [[ "${version:?}" =~ 5.3|${nightly_versions:?} ]]; then
|
||||||
add_firebird_helper /usr >/dev/null 2>&1
|
add_firebird_helper /usr >/dev/null 2>&1
|
||||||
@ -27,9 +32,8 @@ add_firebird() {
|
|||||||
add_pdo_extension firebird >/dev/null 2>&1
|
add_pdo_extension firebird >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
add_firebird_client_darwin >/dev/null 2>&1
|
|
||||||
add_firebird_helper /opt/firebird >/dev/null 2>&1
|
add_firebird_helper /opt/firebird >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
add_extension_log pdo_firebird "Installed and enabled"
|
|
||||||
fi
|
fi
|
||||||
|
add_extension_log pdo_firebird "$status"
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ Function Repair-ICU() {
|
|||||||
}
|
}
|
||||||
$zip_url = Get-ICUUrl $icu.Groups[1].Value $installed.Architecture $vs
|
$zip_url = Get-ICUUrl $icu.Groups[1].Value $installed.Architecture $vs
|
||||||
if ($zip_url -ne '') {
|
if ($zip_url -ne '') {
|
||||||
New-Item -Path "$php_dir" -Name "icu" -ItemType "directory" | Out-Null
|
New-Item -Path "$php_dir" -Name "icu" -ItemType "directory" -Force > $null 2>&1
|
||||||
Invoke-WebRequest -Uri $zip_url -OutFile "$php_dir\icu\icu.zip"
|
Invoke-WebRequest -Uri $zip_url -OutFile "$php_dir\icu\icu.zip"
|
||||||
Expand-Archive -Path $php_dir\icu\icu.zip -DestinationPath $php_dir\icu -Force
|
Expand-Archive -Path $php_dir\icu\icu.zip -DestinationPath $php_dir\icu -Force
|
||||||
Get-ChildItem $php_dir\icu\bin -Filter *.dll | Copy-Item -Destination $php_dir -Force
|
Get-ChildItem $php_dir\icu\bin -Filter *.dll | Copy-Item -Destination $php_dir -Force
|
||||||
|
@ -99,7 +99,7 @@ add_http_version() {
|
|||||||
ext=$1
|
ext=$1
|
||||||
enable_http
|
enable_http
|
||||||
if [ "x$(php -r "echo phpversion('http');")" != "x${ext##*-}" ]; then
|
if [ "x$(php -r "echo phpversion('http');")" != "x${ext##*-}" ]; then
|
||||||
remove_extension http >/dev/null
|
disable_extension_helper http >/dev/null
|
||||||
add_http_helper pecl_http-"${ext##*-}" "$os"
|
add_http_helper pecl_http-"${ext##*-}" "$os"
|
||||||
status="Installed and enabled"
|
status="Installed and enabled"
|
||||||
fi
|
fi
|
||||||
|
@ -8,6 +8,7 @@ Function Add-LicenseLog() {
|
|||||||
# Function to add ioncube extension.
|
# Function to add ioncube extension.
|
||||||
Function Add-Ioncube() {
|
Function Add-Ioncube() {
|
||||||
try {
|
try {
|
||||||
|
$status = 'Enabled'
|
||||||
if (-not(Test-Path $ext_dir\php_ioncube.dll)) {
|
if (-not(Test-Path $ext_dir\php_ioncube.dll)) {
|
||||||
$status = 'Installed and enabled'
|
$status = 'Installed and enabled'
|
||||||
$arch_part = $arch
|
$arch_part = $arch
|
||||||
|
@ -1,17 +1,19 @@
|
|||||||
# Function to log result of a operation.
|
# Function to log result of a operation.
|
||||||
add_license_log() {
|
add_license_log() {
|
||||||
printf "::group::\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "ioncube" "Click to read the ioncube loader license information"
|
printf "::group::\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "ioncube" "Click to read the ioncube loader license information"
|
||||||
cat /tmp/ioncube/LICENSE.txt
|
cat "${ext_dir:?}"/IONCUBE_LICENSE.txt
|
||||||
echo "::endgroup::"
|
echo "::endgroup::"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to install ioncube.
|
# Function to install ioncube.
|
||||||
add_ioncube() {
|
add_ioncube() {
|
||||||
if [ ! -e "${ext_dir:?}/ioncube.so" ]; then
|
status='Enabled'
|
||||||
|
if ! shared_extension ioncube; then
|
||||||
status='Installed and enabled'
|
status='Installed and enabled'
|
||||||
os_name='lin' && [ "$(uname -s)" = "Darwin" ] && os_name='mac'
|
os_name='lin' && [ "$(uname -s)" = "Darwin" ] && os_name='mac'
|
||||||
get -s -n "" https://downloads.ioncube.com/loader_downloads/ioncube_loaders_"$os_name"_x86-64.tar.gz | tar -xzf - -C /tmp
|
get -s -n "" https://downloads.ioncube.com/loader_downloads/ioncube_loaders_"$os_name"_x86-64.tar.gz | tar -xzf - -C /tmp
|
||||||
sudo mv /tmp/ioncube/ioncube_loader_"$os_name"_"${version:?}".so "$ext_dir/ioncube.so"
|
sudo mv /tmp/ioncube/ioncube_loader_"$os_name"_"${version:?}".so "${ext_dir:?}/ioncube.so"
|
||||||
|
sudo cp /tmp/ioncube/LICENSE.txt "$ext_dir"/IONCUBE_LICENSE.txt
|
||||||
fi
|
fi
|
||||||
echo "zend_extension=$ext_dir/ioncube.so" | sudo tee "${scan_dir:?}/00-ioncube.ini" >/dev/null 2>&1
|
echo "zend_extension=$ext_dir/ioncube.so" | sudo tee "${scan_dir:?}/00-ioncube.ini" >/dev/null 2>&1
|
||||||
add_extension_log "ioncube" "$status"
|
add_extension_log "ioncube" "$status"
|
||||||
|
@ -35,7 +35,7 @@ add_client() {
|
|||||||
|
|
||||||
# Function to install oci8 and pdo_oci.
|
# Function to install oci8 and pdo_oci.
|
||||||
add_oci_helper() {
|
add_oci_helper() {
|
||||||
if ! [ -e "${ext_dir:?}/$ext.so" ]; then
|
if ! shared_extension "$ext"; then
|
||||||
status='Installed and enabled'
|
status='Installed and enabled'
|
||||||
read -r "${ext}_LINUX_LIBS" <<< "libaio-dev"
|
read -r "${ext}_LINUX_LIBS" <<< "libaio-dev"
|
||||||
read -r "${ext}_CONFIGURE_OPTS" <<< "--with-php-config=$(command -v php-config) --with-${ext/_/-}=instantclient,$oracle_client"
|
read -r "${ext}_CONFIGURE_OPTS" <<< "--with-php-config=$(command -v php-config) --with-${ext/_/-}=instantclient,$oracle_client"
|
||||||
@ -43,6 +43,8 @@ add_oci_helper() {
|
|||||||
patch_phpize
|
patch_phpize
|
||||||
add_extension_from_source "$ext" https://github.com php php-src "$(php_src_tag)" extension get
|
add_extension_from_source "$ext" https://github.com php php-src "$(php_src_tag)" extension get
|
||||||
restore_phpize
|
restore_phpize
|
||||||
|
else
|
||||||
|
enable_extension "$ext" extension
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,21 +1,25 @@
|
|||||||
# Helper function to add phalcon.
|
# Helper function to add phalcon.
|
||||||
add_phalcon_helper() {
|
add_phalcon_helper() {
|
||||||
status='Installed and enabled'
|
status='Installed and enabled'
|
||||||
if [ "$extension" = "phalcon4" ]; then
|
if [ "$(uname -s)" = "Darwin" ]; then
|
||||||
install_packages "php${version:?}-psr" "php${version:?}-$extension"
|
add_brew_extension "$extension" extension
|
||||||
else
|
else
|
||||||
install_packages "php${version:?}-$extension"
|
if [ "$extension" = "phalcon4" ]; then
|
||||||
|
install_packages "php${version:?}-psr" "php${version:?}-$extension"
|
||||||
|
else
|
||||||
|
install_packages "php${version:?}-$extension"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to add phalcon3.
|
# Function to add phalcon3.
|
||||||
add_phalcon3() {
|
add_phalcon3() {
|
||||||
if [ -e "${ext_dir:?}/phalcon.so" ]; then
|
if shared_extension phalcon; then
|
||||||
phalcon_version=$(php -d="extension=phalcon.so" -r "echo phpversion('phalcon');" | cut -d'.' -f 1)
|
phalcon_version=$(php -d="extension=phalcon.so" -r "echo phpversion('phalcon');" | cut -d'.' -f 1)
|
||||||
if [ "$phalcon_version" != "$extension_major_version" ]; then
|
if [ "$phalcon_version" != "$extension_major_version" ]; then
|
||||||
add_phalcon_helper
|
add_phalcon_helper
|
||||||
else
|
else
|
||||||
echo "extension=phalcon.so" | sudo tee -a "$phalcon_ini_file"
|
enable_extension phalcon extension
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
add_phalcon_helper
|
add_phalcon_helper
|
||||||
@ -24,16 +28,14 @@ add_phalcon3() {
|
|||||||
|
|
||||||
# Function to add phalcon4.
|
# Function to add phalcon4.
|
||||||
add_phalcon4() {
|
add_phalcon4() {
|
||||||
if [ -e "${ext_dir:?}/psr.so" ] && ! php -m | grep -i -q -w psr; then
|
enable_extension psr extension
|
||||||
echo "extension=psr.so" | sudo tee -a "${ini_file:?}"
|
if shared_extension phalcon; then
|
||||||
fi
|
if check_extension psr; then
|
||||||
if [ -e "$ext_dir/phalcon.so" ]; then
|
|
||||||
if php -m | grep -i -q -w psr; then
|
|
||||||
phalcon_version=$(php -d="extension=phalcon" -r "echo phpversion('phalcon');" | cut -d'.' -f 1)
|
phalcon_version=$(php -d="extension=phalcon" -r "echo phpversion('phalcon');" | cut -d'.' -f 1)
|
||||||
if [ "$phalcon_version" != "$extension_major_version" ]; then
|
if [ "$phalcon_version" != "$extension_major_version" ]; then
|
||||||
add_phalcon_helper
|
add_phalcon_helper
|
||||||
else
|
else
|
||||||
echo "extension=phalcon.so" | sudo tee -a "$phalcon_ini_file"
|
enable_extension phalcon extension
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
add_phalcon_helper
|
add_phalcon_helper
|
||||||
@ -47,7 +49,6 @@ add_phalcon4() {
|
|||||||
add_phalcon() {
|
add_phalcon() {
|
||||||
extension=$1
|
extension=$1
|
||||||
status='Enabled'
|
status='Enabled'
|
||||||
phalcon_ini_file="${pecl_file:-${ini_file[@]}}"
|
|
||||||
extension_major_version=${extension: -1}
|
extension_major_version=${extension: -1}
|
||||||
if [ "$extension_major_version" = "4" ]; then
|
if [ "$extension_major_version" = "4" ]; then
|
||||||
add_phalcon4 >/dev/null 2>&1
|
add_phalcon4 >/dev/null 2>&1
|
||||||
|
@ -126,7 +126,7 @@ add_extension_from_source() {
|
|||||||
step_log "Setup $slug"
|
step_log "Setup $slug"
|
||||||
(
|
(
|
||||||
add_devtools phpize >/dev/null 2>&1
|
add_devtools phpize >/dev/null 2>&1
|
||||||
delete_extension "$extension"
|
disable_extension_helper "$extension"
|
||||||
fetch_extension "$fetch"
|
fetch_extension "$fetch"
|
||||||
if ! [ "$(find . -maxdepth 1 -name '*.m4' -exec grep -H 'PHP_NEW_EXTENSION' {} \; | wc -l)" != "0" ]; then
|
if ! [ "$(find . -maxdepth 1 -name '*.m4' -exec grep -H 'PHP_NEW_EXTENSION' {} \; | wc -l)" != "0" ]; then
|
||||||
add_log "${cross:?}" "$source" "$source does not have a PHP extension"
|
add_log "${cross:?}" "$source" "$source does not have a PHP extension"
|
||||||
|
@ -14,40 +14,18 @@ self_hosted_helper() {
|
|||||||
# Function to install a package
|
# Function to install a package
|
||||||
install_packages() {
|
install_packages() {
|
||||||
packages=("$@")
|
packages=("$@")
|
||||||
[[ "${packages[*]}" =~ php ]] && add_ppa ondrej/php >/dev/null 2>&1
|
|
||||||
$apt_install "${packages[@]}" >/dev/null 2>&1 || (update_lists && $apt_install "${packages[@]}" >/dev/null 2>&1)
|
$apt_install "${packages[@]}" >/dev/null 2>&1 || (update_lists && $apt_install "${packages[@]}" >/dev/null 2>&1)
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to disable an extension.
|
# Function to disable an extension.
|
||||||
disable_extension() {
|
disable_extension_helper() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
sudo sed -Ei "/=(.*\/)?\"?$extension(.so)?$/d" "${ini_file[@]}"
|
local disable_dependents=${2:-false}
|
||||||
sudo sed -Ei "/=(.*\/)?\"?$extension(.so)?$/d" "$pecl_file"
|
if [ "$disable_dependents" = "true" ]; then
|
||||||
sudo find "$ini_dir"/.. -name "*$extension.ini" -delete >/dev/null 2>&1 || true
|
disable_extension_dependents "$extension"
|
||||||
}
|
|
||||||
|
|
||||||
# Function to delete an extension.
|
|
||||||
delete_extension() {
|
|
||||||
extension=$1
|
|
||||||
disable_extension "$extension"
|
|
||||||
sudo rm -rf "$ext_dir"/"$extension".so >/dev/null 2>&1
|
|
||||||
sudo sed -i "/Package: php$version-$extension/,/^$/d" /var/lib/dpkg/status
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to disable and delete extensions.
|
|
||||||
remove_extension() {
|
|
||||||
extension=$1
|
|
||||||
if check_extension "$extension"; then
|
|
||||||
if [[ ! "$version" =~ ${old_versions:?} ]] && [ -e /etc/php/"$version"/mods-available/"$extension".ini ]; then
|
|
||||||
sudo phpdismod -v "$version" "$extension" >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
delete_extension "$extension"
|
|
||||||
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Removed") ||
|
|
||||||
add_log "${cross:?}" ":$extension" "Could not remove $extension on PHP ${semver:?}"
|
|
||||||
else
|
|
||||||
delete_extension "$extension"
|
|
||||||
add_log "${tick:?}" ":$extension" "Could not find $extension on PHP $semver"
|
|
||||||
fi
|
fi
|
||||||
|
sudo sed -Ei "/=(.*\/)?\"?$extension(.so)?$/d" "${ini_file[@]}" "$pecl_file"
|
||||||
|
sudo find "$ini_dir"/.. -name "*$extension.ini" -not -path "*mods-available*" -delete >/dev/null 2>&1 || true
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to add PDO extension.
|
# Function to add PDO extension.
|
||||||
@ -58,8 +36,8 @@ add_pdo_extension() {
|
|||||||
else
|
else
|
||||||
ext=$1
|
ext=$1
|
||||||
ext_name=$1
|
ext_name=$1
|
||||||
if [ -e "$ext_dir"/pdo.so ]; then
|
if shared_extension pdo; then
|
||||||
disable_extension pdo
|
disable_extension_helper pdo
|
||||||
echo "extension=pdo.so" | sudo tee "${ini_file[@]/php.ini/conf.d/10-pdo.ini}" >/dev/null 2>&1
|
echo "extension=pdo.so" | sudo tee "${ini_file[@]/php.ini/conf.d/10-pdo.ini}" >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
if [ "$ext" = "mysql" ]; then
|
if [ "$ext" = "mysql" ]; then
|
||||||
@ -81,19 +59,22 @@ add_pdo_extension() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to check if a package exists
|
||||||
|
check_package() {
|
||||||
|
sudo apt-cache policy "$1" 2>/dev/null | grep -q 'Candidate'
|
||||||
|
}
|
||||||
|
|
||||||
# Function to add extensions.
|
# Function to add extensions.
|
||||||
add_extension() {
|
add_extension() {
|
||||||
extension=$1
|
local extension=$1
|
||||||
prefix=$2
|
prefix=$2
|
||||||
|
package=php"$version"-"$extension"
|
||||||
enable_extension "$extension" "$prefix"
|
enable_extension "$extension" "$prefix"
|
||||||
if check_extension "$extension"; then
|
if check_extension "$extension"; then
|
||||||
add_log "${tick:?}" "$extension" "Enabled"
|
add_log "${tick:?}" "$extension" "Enabled"
|
||||||
else
|
else
|
||||||
if [[ "$version" =~ ${nightly_versions:?} ]]; then
|
add_ppa ondrej/php >/dev/null 2>&1 || update_ppa ondrej/php
|
||||||
pecl_install "$extension"
|
(check_package "$package" && install_packages "$package") || pecl_install "$extension"
|
||||||
else
|
|
||||||
install_packages "php$version-$extension" || pecl_install "$extension"
|
|
||||||
fi
|
|
||||||
add_extension_log "$extension" "Installed and enabled"
|
add_extension_log "$extension" "Installed and enabled"
|
||||||
fi
|
fi
|
||||||
sudo chmod 777 "${ini_file[@]}"
|
sudo chmod 777 "${ini_file[@]}"
|
||||||
@ -126,8 +107,8 @@ add_pecl() {
|
|||||||
install_packages php-pear
|
install_packages php-pear
|
||||||
fi
|
fi
|
||||||
configure_pecl >/dev/null 2>&1
|
configure_pecl >/dev/null 2>&1
|
||||||
pecl_version=$(get_tool_version "pecl" "version")
|
pear_version=$(get_tool_version "pecl" "version")
|
||||||
add_log "${tick:?}" "PECL" "Added PECL $pecl_version"
|
add_log "${tick:?}" "PECL" "Added PECL $pear_version"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to switch versions of PHP binaries.
|
# Function to switch versions of PHP binaries.
|
||||||
@ -146,8 +127,8 @@ switch_version() {
|
|||||||
# Function to install packaged PHP
|
# Function to install packaged PHP
|
||||||
add_packaged_php() {
|
add_packaged_php() {
|
||||||
if [ "$runner" = "self-hosted" ] || [ "${use_package_cache:-true}" = "false" ]; then
|
if [ "$runner" = "self-hosted" ] || [ "${use_package_cache:-true}" = "false" ]; then
|
||||||
update_lists
|
add_ppa ondrej/php >/dev/null 2>&1 || update_ppa ondrej/php
|
||||||
IFS=' ' read -r -a packages <<<"$(echo "cli curl mbstring xml intl" | sed "s/[^ ]*/php$version-&/g")"
|
IFS=' ' read -r -a packages <<<"$(echo "cli curl dev mbstring xml intl" | sed "s/[^ ]*/php$version-&/g")"
|
||||||
install_packages "${packages[@]}"
|
install_packages "${packages[@]}"
|
||||||
else
|
else
|
||||||
run_script "php-ubuntu" "$version"
|
run_script "php-ubuntu" "$version"
|
||||||
@ -156,13 +137,13 @@ add_packaged_php() {
|
|||||||
|
|
||||||
# Function to update PHP.
|
# Function to update PHP.
|
||||||
update_php() {
|
update_php() {
|
||||||
initial_version=$(php_semver)
|
initial_version="$(php_semver)$(php_extra_version)"
|
||||||
add_packaged_php
|
add_php
|
||||||
updated_version=$(php_semver)
|
updated_version="$(php_semver)$(php_extra_version)"
|
||||||
if [ "$updated_version" != "$initial_version" ]; then
|
if [ "$updated_version" != "$initial_version" ]; then
|
||||||
status="Updated to"
|
status="Updated to"
|
||||||
else
|
else
|
||||||
status="Switched to"
|
status="Found"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -174,6 +155,7 @@ add_php() {
|
|||||||
setup_old_versions
|
setup_old_versions
|
||||||
else
|
else
|
||||||
add_packaged_php
|
add_packaged_php
|
||||||
|
switch_version >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
status="Installed"
|
status="Installed"
|
||||||
}
|
}
|
||||||
@ -189,7 +171,7 @@ link_pecl_file() {
|
|||||||
|
|
||||||
# Function to get extra version.
|
# Function to get extra version.
|
||||||
php_extra_version() {
|
php_extra_version() {
|
||||||
if [[ ${version:?} =~ ${nightly_versions:?} ]]; then
|
if [ -e /etc/php/"$version"/COMMIT ]; then
|
||||||
echo " ($(cat "/etc/php/$version/COMMIT"))"
|
echo " ($(cat "/etc/php/$version/COMMIT"))"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -202,15 +184,15 @@ setup_php() {
|
|||||||
if [ ! -e "/usr/bin/php$version" ]; then
|
if [ ! -e "/usr/bin/php$version" ]; then
|
||||||
add_php >/dev/null 2>&1
|
add_php >/dev/null 2>&1
|
||||||
else
|
else
|
||||||
|
if ! [[ "$version" =~ ${old_versions:?} ]]; then
|
||||||
|
switch_version >/dev/null 2>&1
|
||||||
|
fi
|
||||||
if [ "${update:?}" = "true" ]; then
|
if [ "${update:?}" = "true" ]; then
|
||||||
update_php >/dev/null 2>&1
|
update_php >/dev/null 2>&1
|
||||||
else
|
else
|
||||||
status="Switched to"
|
status="Switched to"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if ! [[ "$version" =~ ${old_versions:?}|${nightly_versions:?} ]]; then
|
|
||||||
switch_version >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
if [ "$update" = "true" ]; then
|
if [ "$update" = "true" ]; then
|
||||||
update_php >/dev/null 2>&1
|
update_php >/dev/null 2>&1
|
||||||
@ -228,12 +210,13 @@ setup_php() {
|
|||||||
scan_dir=$(php --ini | grep additional | sed -e "s|.*: s*||")
|
scan_dir=$(php --ini | grep additional | sed -e "s|.*: s*||")
|
||||||
ini_dir=$(php --ini | grep "(php.ini)" | sed -e "s|.*: s*||")
|
ini_dir=$(php --ini | grep "(php.ini)" | sed -e "s|.*: s*||")
|
||||||
pecl_file="$scan_dir"/99-pecl.ini
|
pecl_file="$scan_dir"/99-pecl.ini
|
||||||
|
export ext_dir
|
||||||
mapfile -t ini_file < <(sudo find "$ini_dir/.." -name "php.ini" -exec readlink -m {} +)
|
mapfile -t ini_file < <(sudo find "$ini_dir/.." -name "php.ini" -exec readlink -m {} +)
|
||||||
link_pecl_file
|
link_pecl_file
|
||||||
configure_php
|
configure_php
|
||||||
sudo rm -rf /usr/local/bin/phpunit >/dev/null 2>&1
|
sudo rm -rf /usr/local/bin/phpunit >/dev/null 2>&1
|
||||||
sudo chmod 777 "${ini_file[@]}" "$pecl_file" "${tool_path_dir:?}"
|
sudo chmod 777 "${ini_file[@]}" "$pecl_file" "${tool_path_dir:?}"
|
||||||
sudo cp "$dist"/../src/configs/*.json "$RUNNER_TOOL_CACHE/"
|
sudo cp "$dist"/../src/configs/pm/*.json "$RUNNER_TOOL_CACHE/"
|
||||||
echo "::set-output name=php-version::$semver"
|
echo "::set-output name=php-version::$semver"
|
||||||
add_log "${tick:?}" "PHP" "$status PHP $semver$extra_version"
|
add_log "${tick:?}" "PHP" "$status PHP $semver$extra_version"
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,9 @@ Function Add-ToolsHelper() {
|
|||||||
Add-Extension ast >$null 2>&1
|
Add-Extension ast >$null 2>&1
|
||||||
} elseif($tool -eq "phive") {
|
} elseif($tool -eq "phive") {
|
||||||
Add-Extension xml >$null 2>&1
|
Add-Extension xml >$null 2>&1
|
||||||
|
} elseif($tool -eq "phpDocumentor") {
|
||||||
|
Add-Extension fileinfo >$null 2>&1
|
||||||
|
Copy-Item $bin_dir\phpDocumentor.bat -Destination $bin_dir\phpdoc.bat
|
||||||
} elseif($tool -eq "symfony-cli") {
|
} elseif($tool -eq "symfony-cli") {
|
||||||
Add-ToProfile $current_profile "symfony" "New-Alias symfony $bin_dir\symfony-cli.exe"
|
Add-ToProfile $current_profile "symfony" "New-Alias symfony $bin_dir\symfony-cli.exe"
|
||||||
Add-ToProfile $current_profile "symfony_cli" "New-Alias symfony-cli $bin_dir\symfony-cli.exe"
|
Add-ToProfile $current_profile "symfony_cli" "New-Alias symfony-cli $bin_dir\symfony-cli.exe"
|
||||||
|
@ -14,7 +14,15 @@ add_tools_helper() {
|
|||||||
add_extension curl extension >/dev/null 2>&1
|
add_extension curl extension >/dev/null 2>&1
|
||||||
add_extension mbstring extension >/dev/null 2>&1
|
add_extension mbstring extension >/dev/null 2>&1
|
||||||
add_extension xml extension >/dev/null 2>&1
|
add_extension xml extension >/dev/null 2>&1
|
||||||
|
elif [ "$tool" = "phpDocumentor" ]; then
|
||||||
|
add_extension fileinfo extension >/dev/null 2>&1
|
||||||
|
sudo ln -s "${tool_path:?}" "${tool_path_dir:?}"/phpdocumentor 2>/dev/null || true
|
||||||
|
sudo ln -s "${tool_path:?}" "${tool_path_dir:?}"/phpdoc
|
||||||
|
elif [[ "$tool" =~ phpunit(-polyfills)?$ ]]; then
|
||||||
|
if [ -e "${tool_path_dir:?}"/phpunit ]; then
|
||||||
|
sudo cp "${tool_path_dir:?}"/phpunit "${composer_bin:?}"
|
||||||
|
fi
|
||||||
elif [[ "$tool" =~ (symfony|vapor|wp)-cli ]]; then
|
elif [[ "$tool" =~ (symfony|vapor|wp)-cli ]]; then
|
||||||
sudo ln -s "${tool_path:?}" "${tool_path_dir:?}"/${tool%-*}
|
sudo ln -s "${tool_path:?}" "${tool_path_dir:?}"/"${tool%-*}"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
@ -1,7 +1,8 @@
|
|||||||
add_blackfire_linux() {
|
add_blackfire_linux() {
|
||||||
sudo mkdir -p /var/run/blackfire
|
sudo mkdir -p /var/run/blackfire /etc/blackfire
|
||||||
add_list debian/blackfire http://packages.blackfire.io/debian https://packages.blackfire.io/gpg.key any main
|
add_list debian/blackfire http://packages.blackfire.io/debian https://packages.blackfire.io/gpg.key any main
|
||||||
install_packages blackfire
|
install_packages blackfire
|
||||||
|
sudo chmod 777 /etc/blackfire/agent
|
||||||
}
|
}
|
||||||
|
|
||||||
add_blackfire_darwin() {
|
add_blackfire_darwin() {
|
||||||
|
@ -31,6 +31,10 @@ set_base_version() {
|
|||||||
else
|
else
|
||||||
set_base_version_codename
|
set_base_version_codename
|
||||||
set_base_version_id
|
set_base_version_id
|
||||||
|
|
||||||
|
# Remove once PPAs start having bookworm releases
|
||||||
|
[ "$VERSION_CODENAME" = 'bookworm' ] && VERSION_CODENAME="bullseye"
|
||||||
|
|
||||||
printf "ID=%s\nVERSION_ID=%s\nVERSION_CODENAME=%s\n" "$ID" "$VERSION_ID" "$VERSION_CODENAME" | tee /tmp/os-release >/dev/null 2>&1
|
printf "ID=%s\nVERSION_ID=%s\nVERSION_CODENAME=%s\n" "$ID" "$VERSION_ID" "$VERSION_CODENAME" | tee /tmp/os-release >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -96,6 +100,21 @@ add_key() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to check if a PPA and its lists exist
|
||||||
|
check_lists() {
|
||||||
|
ppa=$1
|
||||||
|
ppa_search=$2
|
||||||
|
if grep -Eqr "$ppa_search" "$list_dir"; then
|
||||||
|
list_count="$(sudo find /var/lib/apt/lists -type f -name "*${ppa/\//_}*" | wc -l)"
|
||||||
|
if [ "$list_count" = "0" ]; then
|
||||||
|
update_lists "$ppa" "$ppa_search"
|
||||||
|
fi
|
||||||
|
return 0;
|
||||||
|
else
|
||||||
|
return 1;
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# Function to add a sources list.
|
# Function to add a sources list.
|
||||||
add_list() {
|
add_list() {
|
||||||
ppa=${1-ondrej/php}
|
ppa=${1-ondrej/php}
|
||||||
@ -104,13 +123,18 @@ add_list() {
|
|||||||
package_dist=${4:-"$VERSION_CODENAME"}
|
package_dist=${4:-"$VERSION_CODENAME"}
|
||||||
branches=${5:-main}
|
branches=${5:-main}
|
||||||
ppa_search="deb .*$ppa_url $package_dist .*$branches"
|
ppa_search="deb .*$ppa_url $package_dist .*$branches"
|
||||||
grep -Eqr "$ppa_search" "$list_dir" && echo "Repository $ppa already exists" && return;
|
if check_lists "$ppa" "$ppa_search"; then
|
||||||
arch=$(dpkg --print-architecture)
|
echo "Repository $ppa already exists";
|
||||||
[ -e "$key_source" ] && key_file=$key_source || key_file="$key_dir"/"${ppa/\//-}"-keyring.gpg
|
return 1;
|
||||||
add_key "$ppa" "$ppa_url" "$package_dist" "$key_source" "$key_file"
|
else
|
||||||
echo "deb [arch=$arch signed-by=$key_file] $ppa_url $package_dist $branches" | sudo tee -a "$list_dir"/"${ppa/\//-}".list >/dev/null 2>&1
|
arch=$(dpkg --print-architecture)
|
||||||
update_lists "$ppa" "$ppa_search"
|
[ -e "$key_source" ] && key_file=$key_source || key_file="$key_dir"/"${ppa/\//-}"-keyring.gpg
|
||||||
. /etc/os-release
|
add_key "$ppa" "$ppa_url" "$package_dist" "$key_source" "$key_file"
|
||||||
|
echo "deb [arch=$arch signed-by=$key_file] $ppa_url $package_dist $branches" | sudo tee -a "$list_dir"/"${ppa/\//-}".list >/dev/null 2>&1
|
||||||
|
update_lists "$ppa" "$ppa_search"
|
||||||
|
. /etc/os-release
|
||||||
|
fi
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to remove a PPA.
|
# Function to remove a PPA.
|
||||||
@ -132,6 +156,20 @@ add_ppa() {
|
|||||||
else
|
else
|
||||||
add_list "$ppa"
|
add_list "$ppa"
|
||||||
fi
|
fi
|
||||||
|
status="$?"
|
||||||
|
. /etc/os-release
|
||||||
|
return $status
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to update a PPA.
|
||||||
|
update_ppa() {
|
||||||
|
set_base_version
|
||||||
|
ppa=${1:-ondrej/php}
|
||||||
|
ppa_url=${2:-"$lp_ppa/$ppa/ubuntu"}
|
||||||
|
package_dist=${4:-"$VERSION_CODENAME"}
|
||||||
|
branches=${5:-main}
|
||||||
|
ppa_search="deb .*$ppa_url $package_dist .*$branches"
|
||||||
|
update_lists "$ppa" "$ppa_search"
|
||||||
. /etc/os-release
|
. /etc/os-release
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ param (
|
|||||||
[ValidateNotNull()]
|
[ValidateNotNull()]
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
[string]
|
[string]
|
||||||
$version = '8.0',
|
$version = '8.1',
|
||||||
[Parameter(Position = 1, Mandatory = $true)]
|
[Parameter(Position = 1, Mandatory = $true)]
|
||||||
[ValidateNotNull()]
|
[ValidateNotNull()]
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
@ -74,20 +74,20 @@ Function Add-Path {
|
|||||||
Function Add-Printf {
|
Function Add-Printf {
|
||||||
if (-not(Test-Path "C:\Program Files\Git\usr\bin\printf.exe")) {
|
if (-not(Test-Path "C:\Program Files\Git\usr\bin\printf.exe")) {
|
||||||
if(Test-Path "C:\msys64\usr\bin\printf.exe") {
|
if(Test-Path "C:\msys64\usr\bin\printf.exe") {
|
||||||
New-Item -Path $bin_dir\printf.exe -ItemType SymbolicLink -Value C:\msys64\usr\bin\printf.exe
|
New-Item -Path $bin_dir\printf.exe -ItemType SymbolicLink -Value C:\msys64\usr\bin\printf.exe -Force > $null 2>&1
|
||||||
} else {
|
} else {
|
||||||
Invoke-WebRequest -Uri "$github/shivammathur/printf/releases/latest/download/printf-x64.zip" -OutFile "$bin_dir\printf.zip"
|
Invoke-WebRequest -Uri "$github/shivammathur/printf/releases/latest/download/printf-x64.zip" -OutFile "$bin_dir\printf.zip"
|
||||||
Expand-Archive -Path $bin_dir\printf.zip -DestinationPath $bin_dir -Force
|
Expand-Archive -Path $bin_dir\printf.zip -DestinationPath $bin_dir -Force
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
New-Item -Path $bin_dir\printf.exe -ItemType SymbolicLink -Value "C:\Program Files\Git\usr\bin\printf.exe"
|
New-Item -Path $bin_dir\printf.exe -ItemType SymbolicLink -Value "C:\Program Files\Git\usr\bin\printf.exe" -Force > $null 2>&1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to get a clean Powershell profile.
|
# Function to get a clean Powershell profile.
|
||||||
Function Get-CleanPSProfile {
|
Function Get-CleanPSProfile {
|
||||||
if(-not(Test-Path -LiteralPath $profile)) {
|
if(-not(Test-Path -LiteralPath $profile)) {
|
||||||
New-Item -Path $profile -ItemType "file" -Force
|
New-Item -Path $profile -ItemType "file" -Force > $null 2>&1
|
||||||
}
|
}
|
||||||
Set-Content $current_profile -Value ''
|
Set-Content $current_profile -Value ''
|
||||||
Add-ToProfile $profile $current_profile.replace('\', '\\') ". $current_profile"
|
Add-ToProfile $profile $current_profile.replace('\', '\\') ". $current_profile"
|
||||||
@ -141,24 +141,14 @@ Function Set-ExtensionPrerequisites
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to get extension pre-requisites.
|
# Function to add CA certificates to PHP.
|
||||||
# https://windows.php.net/downloads/pecl/deps
|
Function Add-PhpCAInfo {
|
||||||
# Currently only imagick is supported using this Cmdlet.
|
try {
|
||||||
Function Get-ExtensionPrerequisites{
|
Update-PhpCAInfo -Path $php_dir -Source Curl
|
||||||
Param (
|
} catch {
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
Add-Log $cross PHP "Could not fetch CA certificate bundle from Curl"
|
||||||
[ValidateNotNull()]
|
Update-PhpCAInfo -Path $php_dir -Source CurrentUser
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
|
||||||
[string]
|
|
||||||
$extension
|
|
||||||
)
|
|
||||||
$deps_dir = "$ext_dir\$extension-vc$($installed.VCVersion)-$arch"
|
|
||||||
$extensions_with_dependencies = ('imagick')
|
|
||||||
New-Item $deps_dir -Type Directory 2>&1 | Out-Null
|
|
||||||
if($extensions_with_dependencies.Contains($extension)) {
|
|
||||||
Install-PhpExtensionPrerequisite -Extension $extension -InstallPath $deps_dir -PhpPath $php_dir
|
|
||||||
}
|
}
|
||||||
return $deps_dir
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to add PHP extensions.
|
# Function to add PHP extensions.
|
||||||
@ -182,6 +172,8 @@ Function Add-Extension {
|
|||||||
)
|
)
|
||||||
try {
|
try {
|
||||||
$extension_info = Get-PhpExtension -Path $php_dir | Where-Object { $_.Name -eq $extension -or $_.Handle -eq $extension }
|
$extension_info = Get-PhpExtension -Path $php_dir | Where-Object { $_.Name -eq $extension -or $_.Handle -eq $extension }
|
||||||
|
$deps_dir = "$ext_dir\$extension-vc$($installed.VCVersion)-$arch"
|
||||||
|
New-Item $deps_dir -Type Directory -Force > $null 2>&1
|
||||||
if ($null -ne $extension_info) {
|
if ($null -ne $extension_info) {
|
||||||
switch ($extension_info.State) {
|
switch ($extension_info.State) {
|
||||||
'Builtin' {
|
'Builtin' {
|
||||||
@ -191,7 +183,7 @@ Function Add-Extension {
|
|||||||
Add-Log $tick $extension "Enabled"
|
Add-Log $tick $extension "Enabled"
|
||||||
}
|
}
|
||||||
default {
|
default {
|
||||||
$deps_dir = Get-ExtensionPrerequisites $extension
|
Enable-ExtensionDependencies $extension
|
||||||
Enable-PhpExtension -Extension $extension_info.Handle -Path $php_dir
|
Enable-PhpExtension -Extension $extension_info.Handle -Path $php_dir
|
||||||
Set-ExtensionPrerequisites $deps_dir
|
Set-ExtensionPrerequisites $deps_dir
|
||||||
Add-Log $tick $extension "Enabled"
|
Add-Log $tick $extension "Enabled"
|
||||||
@ -199,7 +191,6 @@ Function Add-Extension {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$deps_dir = Get-ExtensionPrerequisites $extension
|
|
||||||
$params = @{ Extension = $extension; MinimumStability = $stability; MaximumStability = $stability; Path = $php_dir; AdditionalFilesPath = $deps_dir; NoDependencies = $true }
|
$params = @{ Extension = $extension; MinimumStability = $stability; MaximumStability = $stability; Path = $php_dir; AdditionalFilesPath = $deps_dir; NoDependencies = $true }
|
||||||
if($extension_version -ne '') {
|
if($extension_version -ne '') {
|
||||||
$params["Version"] = $extension_version
|
$params["Version"] = $extension_version
|
||||||
@ -214,8 +205,13 @@ Function Add-Extension {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to remove PHP extensions.
|
# Function to get a map of extensions and their dependent shared extensions.
|
||||||
Function Remove-Extension() {
|
Function Get-ExtensionMap {
|
||||||
|
php -d'error_reporting=0' $dist\..\src\scripts\ext\extension_map.php
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to enable extension dependencies which are also extensions.
|
||||||
|
Function Enable-ExtensionDependencies {
|
||||||
Param (
|
Param (
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
[Parameter(Position = 0, Mandatory = $true)]
|
||||||
[ValidateNotNull()]
|
[ValidateNotNull()]
|
||||||
@ -223,21 +219,90 @@ Function Remove-Extension() {
|
|||||||
[string]
|
[string]
|
||||||
$extension
|
$extension
|
||||||
)
|
)
|
||||||
if(php -m | findstr -i $extension) {
|
if (-not(Test-Path $env:TEMP\map.orig)) {
|
||||||
try {
|
Get-ExtensionMap | Set-Content -Path $env:TEMP\map.orig
|
||||||
Disable-PhpExtension $extension $php_dir
|
}
|
||||||
if (Test-Path $ext_dir\php_$extension.dll) {
|
$entry = findstr /r "$extension`:.*" $env:TEMP\map.orig
|
||||||
Remove-Item $ext_dir\php_$extension.dll
|
if($entry) {
|
||||||
|
$entry.split(':')[1].trim().split(' ') | ForEach-Object {
|
||||||
|
if (-not(php -m | findstr -i $_)) {
|
||||||
|
Enable-PhpExtension -Extension $_ -Path $php_dir
|
||||||
}
|
}
|
||||||
Add-Log $tick ":$extension" "Removed"
|
|
||||||
} catch {
|
|
||||||
Add-Log $cross ":$extension" "Could not remove $extension on PHP $($installed.FullVersion)"
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to disable dependent extensions.
|
||||||
|
Function Disable-DependentExtensions() {
|
||||||
|
Param (
|
||||||
|
[Parameter(Position = 0, Mandatory = $true)]
|
||||||
|
[ValidateNotNull()]
|
||||||
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
|
[string]
|
||||||
|
$extension
|
||||||
|
)
|
||||||
|
Get-ExtensionMap | Select-String -Pattern ".*:.*\s$extension(\s|$)" | ForEach-Object {
|
||||||
|
$dependent = $_.Matches[0].Value.split(':')[0];
|
||||||
|
Disable-ExtensionHelper -Extension $dependent -DisableDependents
|
||||||
|
Add-Log $tick ":$extension" "Disabled $dependent as it depends on $extension"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Helper function to disable an extension.
|
||||||
|
Function Disable-ExtensionHelper() {
|
||||||
|
Param (
|
||||||
|
[Parameter(Position = 0, Mandatory = $true)]
|
||||||
|
[ValidateNotNull()]
|
||||||
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
|
[string]
|
||||||
|
$extension,
|
||||||
|
[switch] $DisableDependents
|
||||||
|
)
|
||||||
|
if($DisableDependents) {
|
||||||
|
Disable-DependentExtensions $extension
|
||||||
|
}
|
||||||
|
Disable-PhpExtension -Extension $extension -Path $php_dir
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to disable an extension.
|
||||||
|
Function Disable-Extension() {
|
||||||
|
Param (
|
||||||
|
[Parameter(Position = 0, Mandatory = $true)]
|
||||||
|
[ValidateNotNull()]
|
||||||
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
|
[string]
|
||||||
|
$extension,
|
||||||
|
[Parameter(Position = 1, Mandatory = $false)]
|
||||||
|
[ValidateNotNull()]
|
||||||
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
|
[string]
|
||||||
|
$DisableDependents
|
||||||
|
)
|
||||||
|
if(php -m | findstr -i $extension) {
|
||||||
|
if(Test-Path $ext_dir\php_$extension.dll) {
|
||||||
|
try {
|
||||||
|
$params = @{ Extension = $extension; DisableDependents = ($DisableDependents -ne 'false') }
|
||||||
|
Disable-ExtensionHelper @params
|
||||||
|
Add-Log $tick ":$extension" "Disabled"
|
||||||
|
} catch {
|
||||||
|
Add-Log $cross ":$extension" "Could not disable $extension on PHP $($installed.FullVersion)"
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Add-Log $cross ":$extension" "Could not disable $extension on PHP $($installed.FullVersion) as it not a shared extension"
|
||||||
|
}
|
||||||
|
} elseif(Test-Path $ext_dir\php_$extension.dll) {
|
||||||
|
Add-Log $tick ":$extension" "Disabled"
|
||||||
} else {
|
} else {
|
||||||
Add-Log $tick ":$extension" "Could not find $extension on PHP $($installed.FullVersion)"
|
Add-Log $tick ":$extension" "Could not find $extension on PHP $($installed.FullVersion)"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to disable shared extensions.
|
||||||
|
Function Disable-AllShared() {
|
||||||
|
(Get-Content $php_dir\php.ini) | Where-Object {$_ -notmatch '^(zend_)?extension\s*='} | Set-Content $php_dir\php.ini
|
||||||
|
Add-Log $tick "none" "Disabled all shared extensions"
|
||||||
|
}
|
||||||
|
|
||||||
# Function to configure composer.
|
# Function to configure composer.
|
||||||
Function Edit-ComposerConfig() {
|
Function Edit-ComposerConfig() {
|
||||||
Param(
|
Param(
|
||||||
@ -396,7 +461,6 @@ $current_profile = "$env:TEMP\setup-php.ps1"
|
|||||||
$ProgressPreference = 'SilentlyContinue'
|
$ProgressPreference = 'SilentlyContinue'
|
||||||
$jit_versions = '8.[0-9]'
|
$jit_versions = '8.[0-9]'
|
||||||
$nightly_versions = '8.[1-9]'
|
$nightly_versions = '8.[1-9]'
|
||||||
$cert_source='CurrentUser'
|
|
||||||
$enable_extensions = ('openssl', 'curl', 'mbstring')
|
$enable_extensions = ('openssl', 'curl', 'mbstring')
|
||||||
|
|
||||||
$arch = 'x64'
|
$arch = 'x64'
|
||||||
@ -412,9 +476,8 @@ if($env:RUNNER -eq 'self-hosted') {
|
|||||||
$bin_dir = 'C:\tools\bin'
|
$bin_dir = 'C:\tools\bin'
|
||||||
$php_dir = "$php_dir$version"
|
$php_dir = "$php_dir$version"
|
||||||
$ext_dir = "$php_dir\ext"
|
$ext_dir = "$php_dir\ext"
|
||||||
$cert_source='Curl'
|
|
||||||
Get-CleanPSProfile >$null 2>&1
|
Get-CleanPSProfile >$null 2>&1
|
||||||
New-Item $bin_dir -Type Directory 2>&1 | Out-Null
|
New-Item $bin_dir -Type Directory -Force > $null 2>&1
|
||||||
Add-Path -PathItem $bin_dir
|
Add-Path -PathItem $bin_dir
|
||||||
if($version -lt 5.6) {
|
if($version -lt 5.6) {
|
||||||
Add-Log $cross "PHP" "PHP $version is not supported on self-hosted runner"
|
Add-Log $cross "PHP" "PHP $version is not supported on self-hosted runner"
|
||||||
@ -424,7 +487,7 @@ if($env:RUNNER -eq 'self-hosted') {
|
|||||||
if ((Get-InstalledModule).Name -notcontains 'VcRedist') {
|
if ((Get-InstalledModule).Name -notcontains 'VcRedist') {
|
||||||
Install-Module -Name VcRedist -Force
|
Install-Module -Name VcRedist -Force
|
||||||
}
|
}
|
||||||
New-Item $php_dir -Type Directory 2>&1 | Out-Null
|
New-Item $php_dir -Type Directory -Force > $null 2>&1
|
||||||
Add-Path -PathItem $php_dir
|
Add-Path -PathItem $php_dir
|
||||||
setx PHPROOT $php_dir >$null 2>&1
|
setx PHPROOT $php_dir >$null 2>&1
|
||||||
} else {
|
} else {
|
||||||
@ -457,13 +520,16 @@ if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version
|
|||||||
try {
|
try {
|
||||||
if ($version -match $nightly_versions) {
|
if ($version -match $nightly_versions) {
|
||||||
Invoke-WebRequest -UseBasicParsing -Uri $php_builder/releases/latest/download/Get-PhpNightly.ps1 -OutFile $php_dir\Get-PhpNightly.ps1 > $null 2>&1
|
Invoke-WebRequest -UseBasicParsing -Uri $php_builder/releases/latest/download/Get-PhpNightly.ps1 -OutFile $php_dir\Get-PhpNightly.ps1 > $null 2>&1
|
||||||
& $php_dir\Get-PhpNightly.ps1 -Architecture $arch -ThreadSafe $ts -Path $php_dir > $null 2>&1
|
& $php_dir\Get-PhpNightly.ps1 -Architecture $arch -ThreadSafe $ts -Path $php_dir -Version $version > $null 2>&1
|
||||||
$extra_version = " ($(Get-Content $php_dir\COMMIT))"
|
if(Test-Path $php_dir\COMMIT) {
|
||||||
|
$extra_version = " ($( Get-Content $php_dir\COMMIT ))"
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
Install-Php -Version $version -Architecture $arch -ThreadSafe $ts -InstallVC -Path $php_dir -TimeZone UTC -InitialPhpIni Production -Force > $null 2>&1
|
Install-Php -Version $version -Architecture $arch -ThreadSafe $ts -InstallVC -Path $php_dir -TimeZone UTC -InitialPhpIni Production -Force > $null 2>&1
|
||||||
}
|
}
|
||||||
} catch { }
|
} catch { }
|
||||||
} else {
|
} else {
|
||||||
|
Set-PhpIniKey -Key 'extension_dir' -Value $ext_dir -Path $php_dir
|
||||||
if($version -match $jit_versions) {
|
if($version -match $jit_versions) {
|
||||||
('opcache.enable=1', 'opcache.jit_buffer_size=256M', 'opcache.jit=1235') | ForEach-Object { $p=$_.split('='); Set-PhpIniKey -Key $p[0] -Value $p[1] -Path $php_dir }
|
('opcache.enable=1', 'opcache.jit_buffer_size=256M', 'opcache.jit=1235') | ForEach-Object { $p=$_.split('='); Set-PhpIniKey -Key $p[0] -Value $p[1] -Path $php_dir }
|
||||||
}
|
}
|
||||||
@ -487,8 +553,8 @@ if($version -lt "5.5") {
|
|||||||
$enable_extensions += ('opcache')
|
$enable_extensions += ('opcache')
|
||||||
}
|
}
|
||||||
Enable-PhpExtension -Extension $enable_extensions -Path $php_dir
|
Enable-PhpExtension -Extension $enable_extensions -Path $php_dir
|
||||||
Update-PhpCAInfo -Path $php_dir -Source $cert_source
|
Add-PhpCAInfo
|
||||||
Copy-Item -Path $dist\..\src\configs\*.json -Destination $env:RUNNER_TOOL_CACHE
|
Copy-Item -Path $dist\..\src\configs\pm\*.json -Destination $env:RUNNER_TOOL_CACHE
|
||||||
New-Item -ItemType Directory -Path $composer_bin -Force 2>&1 | Out-Null
|
New-Item -ItemType Directory -Path $composer_bin -Force > $null 2>&1
|
||||||
Write-Output "::set-output name=php-version::$($installed.FullVersion)"
|
Write-Output "::set-output name=php-version::$($installed.FullVersion)"
|
||||||
Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)$extra_version"
|
Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)$extra_version"
|
||||||
|
29
src/utils.ts
29
src/utils.ts
@ -102,7 +102,7 @@ export async function getManifestURL(): Promise<string> {
|
|||||||
export async function parseVersion(version: string): Promise<string> {
|
export async function parseVersion(version: string): Promise<string> {
|
||||||
const manifest = await getManifestURL();
|
const manifest = await getManifestURL();
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case /^(latest|\d+\.x)$/.test(version):
|
case /^(latest|nightly|\d+\.x)$/.test(version):
|
||||||
return JSON.parse((await fetch(manifest))['data'])[version];
|
return JSON.parse((await fetch(manifest))['data'])[version];
|
||||||
default:
|
default:
|
||||||
switch (true) {
|
switch (true) {
|
||||||
@ -280,18 +280,21 @@ export async function extensionArray(
|
|||||||
case ' ':
|
case ' ':
|
||||||
return [];
|
return [];
|
||||||
default:
|
default:
|
||||||
return extension_csv
|
return [
|
||||||
.split(',')
|
extension_csv.match(/(^|,\s?)none(\s?,|$)/) ? 'none' : '',
|
||||||
.map(function (extension: string) {
|
...extension_csv
|
||||||
if (/.+-.+\/.+@.+/.test(extension)) {
|
.split(',')
|
||||||
return extension;
|
|
||||||
}
|
.map(function (extension: string) {
|
||||||
return extension
|
if (/.+-.+\/.+@.+/.test(extension)) {
|
||||||
.trim()
|
return extension;
|
||||||
.toLowerCase()
|
}
|
||||||
.replace(/^php[-_]/, '');
|
return extension
|
||||||
})
|
.trim()
|
||||||
.filter(Boolean);
|
.toLowerCase()
|
||||||
|
.replace(/^(:)?(php[-_]|none|zend )/, '$1');
|
||||||
|
})
|
||||||
|
].filter(Boolean);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
|
"declaration": true,
|
||||||
"esModuleInterop": true,
|
"esModuleInterop": true,
|
||||||
"lib": [
|
"lib": [
|
||||||
"ES2020"
|
"ES2020"
|
||||||
|
Reference in New Issue
Block a user