mirror of
https://github.com/shivammathur/setup-php.git
synced 2025-07-21 06:13:28 +07:00
Compare commits
1 Commits
Author | SHA1 | Date | |
---|---|---|---|
d14c0d0dd7 |
@ -10,7 +10,7 @@
|
|||||||
"plugin:import/warnings",
|
"plugin:import/warnings",
|
||||||
"plugin:import/typescript",
|
"plugin:import/typescript",
|
||||||
"plugin:prettier/recommended",
|
"plugin:prettier/recommended",
|
||||||
"prettier"
|
"prettier/@typescript-eslint"
|
||||||
],
|
],
|
||||||
"plugins": ["@typescript-eslint", "jest"]
|
"plugins": ["@typescript-eslint", "jest"]
|
||||||
}
|
}
|
5
.github/SECURITY.md
vendored
5
.github/SECURITY.md
vendored
@ -6,8 +6,8 @@ The following versions of this project are supported for security updates.
|
|||||||
|
|
||||||
| Version | Supported |
|
| Version | Supported |
|
||||||
| ------- | ------------------ |
|
| ------- | ------------------ |
|
||||||
| 1.11.x | :white_check_mark: |
|
| 1.10.x | :white_check_mark: |
|
||||||
| 2.11.x | :white_check_mark: |
|
| 2.8.x | :white_check_mark: |
|
||||||
|
|
||||||
## Supported PHP Versions
|
## Supported PHP Versions
|
||||||
|
|
||||||
@ -15,6 +15,7 @@ This security policy only applies to the latest patches of the following PHP ver
|
|||||||
|
|
||||||
| Version | Supported |
|
| Version | Supported |
|
||||||
| ------- | ------------------ |
|
| ------- | ------------------ |
|
||||||
|
| 7.2 | :white_check_mark: |
|
||||||
| 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: |
|
||||||
|
18
.github/workflows/docs.yml
vendored
18
.github/workflows/docs.yml
vendored
@ -1,8 +1,8 @@
|
|||||||
name: Docs workflow
|
name: Docs workflow
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
repository_dispatch:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '0 15 * * 6'
|
- cron: '0 0 * * 2'
|
||||||
jobs:
|
jobs:
|
||||||
create:
|
create:
|
||||||
name: Create
|
name: Create
|
||||||
@ -10,7 +10,7 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
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, ubuntu-16.04, windows-2019, macos-10.15, macos-11.0]
|
||||||
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']
|
||||||
steps:
|
steps:
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
@ -35,7 +35,7 @@ jobs:
|
|||||||
version: ${{ matrix.php-versions }}
|
version: ${{ matrix.php-versions }}
|
||||||
if: matrix.operating-system == 'windows-2019'
|
if: matrix.operating-system == 'windows-2019'
|
||||||
run: |
|
run: |
|
||||||
Write-Output "## PHP ${{ matrix.php-versions }}`n" | Out-File -FilePath "$env:file"
|
Write-Output "## PHP $version`n" | Out-File -FilePath "$env:file"
|
||||||
Write-Output "``````" | Out-File -FilePath "$env:file" -Append
|
Write-Output "``````" | Out-File -FilePath "$env:file" -Append
|
||||||
php -m | Out-File -FilePath "$env:file" -Append
|
php -m | Out-File -FilePath "$env:file" -Append
|
||||||
Write-Output "```````n" | Out-File -FilePath "$env:file" -Append
|
Write-Output "```````n" | Out-File -FilePath "$env:file" -Append
|
||||||
@ -59,14 +59,10 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
git config --local user.email "${{ secrets.email }}"
|
git config --local user.email "${{ secrets.email }}"
|
||||||
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 ubuntu-16.04 windows-2019 macos-10.15 macos-11.0; 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 "# PHP Extensions on $os" > Php-extensions-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; do
|
||||||
if [ "$os" = "macos-11" ]; then
|
cat lists/php"$version"-"$os".md >> Php-extensions-on-"$os".md
|
||||||
cat lists/php"$version"-macos-10.15.md >> Php-extensions-loaded-on-"$os".md
|
|
||||||
else
|
|
||||||
cat lists/php"$version"-"$os".md >> Php-extensions-loaded-on-"$os".md
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
rm -rf ./lists
|
rm -rf ./lists
|
||||||
|
6
.github/workflows/node-workflow.yml
vendored
6
.github/workflows/node-workflow.yml
vendored
@ -28,10 +28,10 @@ jobs:
|
|||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
- name: Setup Node.js 15.x
|
- name: Setup Node.js 12.x
|
||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v1
|
||||||
with:
|
with:
|
||||||
node-version: 15.x
|
node-version: 12.x
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: npm install
|
run: npm install
|
||||||
@ -48,4 +48,4 @@ jobs:
|
|||||||
- name: Send Coverage
|
- name: Send Coverage
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
timeout-minutes: 1
|
timeout-minutes: 1
|
||||||
run: curl -s https://codecov.io/bash | bash -s -- -t ${{secrets.CODECOV_TOKEN}} -f coverage/lcov.info -n github-actions-codecov-${{ matrix.operating-system }}
|
run: curl -s https://codecov.io/bash | bash -s -- -t ${{secrets.CODECOV_TOKEN}} -f coverage/clover.xml -n github-actions-codecov-${{ matrix.operating-system }}
|
||||||
|
2
.github/workflows/workflow.yml
vendored
2
.github/workflows/workflow.yml
vendored
@ -24,7 +24,7 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
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, ubuntu-16.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']
|
||||||
env:
|
env:
|
||||||
extensions: xml, opcache, xdebug, pcov
|
extensions: xml, opcache, xdebug, pcov
|
||||||
|
2
LICENSE
2
LICENSE
@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2019-2021 shivammathur and contributors
|
Copyright (c) 2019-2020 shivammathur and contributors
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
557
README.md
557
README.md
@ -15,17 +15,17 @@
|
|||||||
<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>
|
||||||
<a href="https://twitter.com/setup_php" title="setup-php twitter"><img alt="setup-php twitter" src="https://img.shields.io/badge/twitter-follow-1DA1F2?logo=twitter&logoColor=1DA1F2&labelColor=555555"></a>
|
<a href="https://twitter.com/setup_php" title="setup-php twitter"><img alt="setup-php twitter" src="https://img.shields.io/badge/twitter-follow-1DA1F2?logo=twitter&logoColor=1DA1F2&labelColor=555555"></a>
|
||||||
<a href="https://status.setup-php.com" title="setup-php status"><img alt="setup-php status" src="https://img.shields.io/badge/status-subscribe-28A745?logo=statuspage&logoColor=28A745&labelColor=555555"></a>
|
<a href="https://setup-php.statuspage.io/" title="setup-php status"><img alt="setup-php status" src="https://img.shields.io/badge/status-subscribe-28A745?logo=statuspage&logoColor=28A745&labelColor=555555"></a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
Setup PHP with required extensions, php.ini configuration, code-coverage support and various tools like composer in [GitHub Actions](https://github.com/features/actions "GitHub Actions"). This action gives you a cross platform interface to set up the PHP environment you need to test your application. Refer to [Usage](#memo-usage "How to use this") section and [examples](#examples "Examples of use") to see how to use this.
|
Setup PHP with required extensions, php.ini configuration, code-coverage support and various tools like composer in [GitHub Actions](https://github.com/features/actions "GitHub Actions"). This action gives you a cross platform interface to set up the PHP environment you need to test your application. Refer to [Usage](#memo-usage "How to use this") section and [examples](#examples "Examples of use") to see how to use this.
|
||||||
|
|
||||||
## Contents
|
## Contents
|
||||||
|
|
||||||
|
- [PHP Support](#tada-php-support)
|
||||||
- [OS/Platform Support](#cloud-osplatform-support)
|
- [OS/Platform Support](#cloud-osplatform-support)
|
||||||
- [GitHub-Hosted Runners](#github-hosted-runners)
|
- [GitHub-Hosted Runners](#github-hosted-runners)
|
||||||
- [Self-Hosted Runners](#self-hosted-runners)
|
- [Self-Hosted Runners](#self-hosted-runners)
|
||||||
- [PHP Support](#tada-php-support)
|
|
||||||
- [PHP Extension Support](#heavy_plus_sign-php-extension-support)
|
- [PHP Extension Support](#heavy_plus_sign-php-extension-support)
|
||||||
- [Tools Support](#wrench-tools-support)
|
- [Tools Support](#wrench-tools-support)
|
||||||
- [Coverage Support](#signal_strength-coverage-support)
|
- [Coverage Support](#signal_strength-coverage-support)
|
||||||
@ -34,22 +34,20 @@ Setup PHP with required extensions, php.ini configuration, code-coverage support
|
|||||||
- [Disable Coverage](#disable-coverage)
|
- [Disable Coverage](#disable-coverage)
|
||||||
- [Usage](#memo-usage)
|
- [Usage](#memo-usage)
|
||||||
- [Inputs](#inputs)
|
- [Inputs](#inputs)
|
||||||
- [Outputs](#outputs)
|
|
||||||
- [Flags](#flags)
|
- [Flags](#flags)
|
||||||
- [Basic Setup](#basic-setup)
|
- [Basic Setup](#basic-setup)
|
||||||
- [Matrix Setup](#matrix-setup)
|
- [Matrix Setup](#matrix-setup)
|
||||||
- [Nightly Build Setup](#nightly-build-setup)
|
|
||||||
- [Thread Safe Setup](#thread-safe-setup)
|
|
||||||
- [Force Update Setup](#force-update-setup)
|
|
||||||
- [Verbose Setup](#verbose-setup)
|
|
||||||
- [Multi-Arch Setup](#multi-arch-setup)
|
- [Multi-Arch Setup](#multi-arch-setup)
|
||||||
|
- [Nightly Build Setup](#nightly-build-setup)
|
||||||
- [Self Hosted Setup](#self-hosted-setup)
|
- [Self Hosted Setup](#self-hosted-setup)
|
||||||
- [Local Testing Setup](#local-testing-setup)
|
- [Local Testing Setup](#local-testing-setup)
|
||||||
- [JIT Configuration](#jit-configuration)
|
- [Thread Safe Setup](#thread-safe-setup)
|
||||||
|
- [Force Update](#force-update)
|
||||||
|
- [Verbose Setup](#verbose-setup)
|
||||||
- [Cache Extensions](#cache-extensions)
|
- [Cache Extensions](#cache-extensions)
|
||||||
- [Cache Composer Dependencies](#cache-composer-dependencies)
|
- [Cache Composer Dependencies](#cache-composer-dependencies)
|
||||||
|
- [Cache Node.js Dependencies](#cache-nodejs-dependencies)
|
||||||
- [Composer GitHub OAuth](#composer-github-oauth)
|
- [Composer GitHub OAuth](#composer-github-oauth)
|
||||||
- [Inline PHP Scripts](#inline-php-scripts)
|
|
||||||
- [Problem Matchers](#problem-matchers)
|
- [Problem Matchers](#problem-matchers)
|
||||||
- [Examples](#examples)
|
- [Examples](#examples)
|
||||||
- [Versioning](#bookmark-versioning)
|
- [Versioning](#bookmark-versioning)
|
||||||
@ -59,47 +57,8 @@ Setup PHP with required extensions, php.ini configuration, code-coverage support
|
|||||||
- [Dependencies](#package-dependencies)
|
- [Dependencies](#package-dependencies)
|
||||||
- [Further Reading](#bookmark_tabs-further-reading)
|
- [Further Reading](#bookmark_tabs-further-reading)
|
||||||
|
|
||||||
## :cloud: OS/Platform Support
|
|
||||||
|
|
||||||
Both `GitHub-hosted` and `self-hosted` runners are suppported by `setup-php` on the following OS/Platforms.
|
|
||||||
|
|
||||||
### GitHub-Hosted Runners
|
|
||||||
|
|
||||||
|Virtual environment|YAML workflow label|Pre-installed PHP|
|
|
||||||
|--- |--- |--- |
|
|
||||||
|Ubuntu 18.04|`ubuntu-18.04`|`PHP 7.1` to `PHP 8.0`|
|
|
||||||
|Ubuntu 20.04|`ubuntu-latest` or `ubuntu-20.04`|`PHP 7.4` to `PHP 8.0`|
|
|
||||||
|Windows Server 2019|`windows-latest` or `windows-2019`|`PHP 8.0`|
|
|
||||||
|Windows Server 2022|`windows-2022`|`PHP 8.0`|
|
|
||||||
|macOS Catalina 10.15|`macos-latest` or `macos-10.15`|`PHP 8.0`|
|
|
||||||
|macOS Big Sur 11.x|`macos-11`|`PHP 8.0`|
|
|
||||||
|
|
||||||
### Self-Hosted Runners
|
|
||||||
|
|
||||||
|Host OS/Virtual environment|YAML workflow label|
|
|
||||||
|--- |--- |
|
|
||||||
|Ubuntu 18.04|`self-hosted` or `Linux`|
|
|
||||||
|Ubuntu 20.04|`self-hosted` or `Linux`|
|
|
||||||
|Ubuntu 21.04|`self-hosted` or `Linux`|
|
|
||||||
|Debian 9|`self-hosted` or `Linux`|
|
|
||||||
|Debian 10|`self-hosted` or `Linux`|
|
|
||||||
|Debian 11|`self-hosted` or `Linux`|
|
|
||||||
|Windows 7 and newer|`self-hosted` or `Windows`|
|
|
||||||
|Windows Server 2012 R2 and newer|`self-hosted` or `Windows`|
|
|
||||||
|macOS Catalina 10.15|`self-hosted` or `macOS`|
|
|
||||||
|macOS Big Sur 11.x x86_64/arm64|`self-hosted` or `macOS`|
|
|
||||||
|
|
||||||
- Refer to the [self-hosted setup](#self-hosted-setup) to use the action on self-hosted runners.
|
|
||||||
- Operating systems based on the above Ubuntu and Debian versions are also supported on a best effort basis.
|
|
||||||
- If the requested PHP version is pre-installed, `setup-php` switches to it, otherwise it installs the PHP version.
|
|
||||||
|
|
||||||
## :tada: PHP Support
|
## :tada: PHP Support
|
||||||
|
|
||||||
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.6 to PHP 8.1 on self-hosted runners.
|
|
||||||
|
|
||||||
|PHP Version|Stability|Release Support|Runner Support|
|
|PHP Version|Stability|Release Support|Runner Support|
|
||||||
|--- |--- |--- |--- |
|
|--- |--- |--- |--- |
|
||||||
|`5.3`|`Stable`|`End of life`|`GitHub-hosted`|
|
|`5.3`|`Stable`|`End of life`|`GitHub-hosted`|
|
||||||
@ -108,55 +67,84 @@ On all supported OS/Platforms the following PHP versions are supported as per th
|
|||||||
|`5.6`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
|`5.6`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`7.0`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
|`7.0`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`7.1`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
|`7.1`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`7.2`|`Stable`|`End of life`|`GitHub-hosted`, `self-hosted`|
|
|`7.2`|`Stable`|`Security fixes only`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`7.3`|`Stable`|`Security fixes only`|`GitHub-hosted`, `self-hosted`|
|
|`7.3`|`Stable`|`Active`|`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`|`Nightly`|`In development`|`GitHub-hosted`, `self-hosted`|
|
||||||
|`8.1`|`Nightly`|`In development`|`GitHub-hosted`, `self-hosted`|
|
|`8.1`|`Nightly`|`In development`|`GitHub-hosted`, `self-hosted`|
|
||||||
|
|
||||||
**Notes:**
|
**Note:** Specifying `8.0` and `8.1` in `php-version` input installs a nightly build of `PHP 8.0.0-dev` and `PHP 8.1.0-dev` respectively. See [nightly build setup](#nightly-build-setup) for more information.
|
||||||
- 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.
|
|
||||||
- To use JIT on `PHP 8.0` and `PHP 8.1` refer to the [JIT configuration](#jit-configuration) section.
|
|
||||||
|
## :cloud: OS/Platform Support
|
||||||
|
|
||||||
|
The action supports both `GitHub-hosted` runners and `self-hosted` runners on the following operating systems.
|
||||||
|
|
||||||
|
### GitHub-Hosted Runners
|
||||||
|
|
||||||
|
|Virtual environment|YAML workflow label|Pre-installed PHP|
|
||||||
|
|--- |--- |--- |
|
||||||
|
|Ubuntu 16.04|`ubuntu-16.04`|`PHP 5.6` to `PHP 7.4`|
|
||||||
|
|Ubuntu 18.04|`ubuntu-latest` or `ubuntu-18.04`|`PHP 7.1` to `PHP 7.4`|
|
||||||
|
|Ubuntu 20.04|`ubuntu-20.04`|`PHP 7.4`|
|
||||||
|
|Windows Server 2019|`windows-latest` or `windows-2019`|`PHP 7.4`|
|
||||||
|
|macOS Catalina 10.15|`macos-latest` or `macos-10.15`|`PHP 7.4`|
|
||||||
|
|macOS Big Sur 11.0|`macos-11.0`|`PHP 7.4`|
|
||||||
|
|
||||||
|
### Self-Hosted Runners
|
||||||
|
|
||||||
|
|Host OS/Virtual environment|YAML workflow label|
|
||||||
|
|--- |--- |
|
||||||
|
|Ubuntu 16.04|`self-hosted` or `Linux`|
|
||||||
|
|Ubuntu 18.04|`self-hosted` or `Linux`|
|
||||||
|
|Ubuntu 20.04|`self-hosted` or `Linux`|
|
||||||
|
|Windows 7 and newer|`self-hosted` or `Windows`|
|
||||||
|
|Windows Server 2012 R2 and newer|`self-hosted` or `Windows`|
|
||||||
|
|macOS Catalina 10.15|`self-hosted` or `macOS`|
|
||||||
|
|macOS Big Sur 11.0|`self-hosted` or `macOS`|
|
||||||
|
|
||||||
|
- Refer to the [self-hosted setup](#self-hosted-setup) to use the action on self-hosted runners.
|
||||||
|
|
||||||
## :heavy_plus_sign: PHP Extension Support
|
## :heavy_plus_sign: PHP Extension Support
|
||||||
|
|
||||||
PHP extensions can be set up using the `extensions` input. It accepts a `string` in csv-format.
|
- Extensions enabled by default after `setup-php` runs can be found on the [wiki](https://github.com/shivammathur/setup-php/wiki).
|
||||||
|
|
||||||
- On `Ubuntu`, extensions which are available as a package, available on `PECL` or a git repository can be set up.
|
- On `ubuntu` by default extensions which are available as a package can be installed. PECL extensions if not available as a package can be installed by specifying `pecl` in the tools input.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with PECL extension
|
- name: Setup PHP with pecl extension
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
extensions: imagick, swoole
|
tools: pecl
|
||||||
|
extensions: swoole
|
||||||
```
|
```
|
||||||
|
|
||||||
- On `Windows`, extensions available on `PECL` which have the `DLL` binary can be set up.
|
- On `windows` PECL extensions which have the `DLL` binary can be installed.
|
||||||
|
|
||||||
- On `macOS`, extensions available on `PECL` or a git repository can be set up.
|
- On `macOS` PECL extensions can be installed.
|
||||||
|
|
||||||
- On `Ubuntu` and `macOS` to compile and install an extension from a git repository follow this [guide](https://github.com/shivammathur/setup-php/wiki/Add-extension-from-source "Guide to compile and install PHP extensions in setup-php").
|
|
||||||
|
|
||||||
- Extensions installed along with PHP if specified are enabled.
|
- Extensions installed along with PHP if specified are enabled.
|
||||||
|
|
||||||
- Specific versions of extensions available on `PECL` can be set up by suffixing the extension's name with the version. This is useful for installing old versions of extensions which support end of life PHP versions.
|
- Specific versions of PECL extensions can be installed by suffixing the version. This is useful for installing old versions of extensions which support end of life PHP versions.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with specific version of PECL extension
|
- name: Setup PHP with specific version of PECL extension
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '5.4'
|
php-version: '5.4'
|
||||||
|
tools: pecl
|
||||||
extensions: swoole-1.9.3
|
extensions: swoole-1.9.3
|
||||||
```
|
```
|
||||||
|
|
||||||
- Pre-release versions extensions available on `PECL` can be set up by suffixing the extension's name with its state i.e `alpha`, `beta`, `devel` or `snapshot`.
|
- Pre-release versions of PECL extensions can be setup by suffixing the extension with its state i.e `alpha`, `beta`, `devel` or `snapshot`.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with pre-release PECL extension
|
- name: Setup PHP with pre-release PECL extension
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
|
tools: pecl
|
||||||
extensions: xdebug-beta
|
extensions: xdebug-beta
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -166,26 +154,21 @@ PHP extensions can be set up using the `extensions` input. It accepts a `string`
|
|||||||
- name: Setup PHP and remove shared extension
|
- name: Setup PHP and remove shared extension
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
extensions: :opcache
|
extensions: :opcache
|
||||||
```
|
```
|
||||||
|
|
||||||
- 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 setup with specific `ICU` version for `PHP 5.6` to `PHP 7.4` 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
|
||||||
- name: Setup PHP with intl
|
- name: Setup PHP with intl
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
extensions: intl-69.1
|
extensions: intl-67.1
|
||||||
```
|
```
|
||||||
|
|
||||||
- Extensions loaded by default after `setup-php` runs can be found on the [wiki](https://github.com/shivammathur/setup-php/wiki).
|
- These extensions have custom support - `cubrid`, `pdo_cubrid` and `gearman` on `Ubuntu`, and `blackfire`, `couchbase`, `ioncube`, `oci8`, `pdo_oci`, `phalcon3` and `phalcon4` on all supported OS.
|
||||||
|
|
||||||
- These extensions have custom support:
|
|
||||||
- `cubrid`, `pdo_cubrid` and `gearman` on `Ubuntu`.
|
|
||||||
- `geos` on `Ubuntu` and `macOS`.
|
|
||||||
- `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 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`.
|
||||||
|
|
||||||
@ -193,7 +176,7 @@ PHP extensions can be set up using the `extensions` input. It accepts a `string`
|
|||||||
- name: Setup PHP with fail-fast
|
- name: Setup PHP with fail-fast
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
extensions: oci8
|
extensions: oci8
|
||||||
env:
|
env:
|
||||||
fail-fast: true
|
fail-fast: true
|
||||||
@ -201,82 +184,49 @@ PHP extensions can be set up using the `extensions` input. It accepts a `string`
|
|||||||
|
|
||||||
## :wrench: Tools Support
|
## :wrench: Tools Support
|
||||||
|
|
||||||
These tools can be set up globally using the `tools` input. It accepts a string in csv-format.
|
These tools can be setup globally using the `tools` input.
|
||||||
|
|
||||||
`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`, `pecl`, `phan`, `phing`, `phinx`, `phive`, `phpcbf`, `phpcpd`, `php-config`, `php-cs-fixer`, `phpcs`, `phpize`, `phpmd`, `phpspec`, `phpstan`, `phpunit`, `prestissimo`, `protoc`, `psalm`, `symfony`, `vapor-cli`
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with tools
|
- name: Setup PHP with tools
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
tools: php-cs-fixer, phpunit
|
tools: php-cs-fixer, phpunit
|
||||||
```
|
```
|
||||||
|
|
||||||
- In addition to above tools any composer tool or package can also be set up globally by specifying it as `vendor/package` matching the listing on Packagist. This format accepts the same [version constraints](https://getcomposer.org/doc/articles/versions.md#writing-version-constraints "Composer version constraints") as `composer`.
|
- To set up a particular version of a tool, specify it in the form `tool:version`. The latest stable version of `composer` is set up by default. You can set up the required `composer` version by specifying `v1`, `v2`, `snapshot` or `preview` as versions or the exact version in semver format.
|
||||||
|
|
||||||
```yaml
|
|
||||||
- name: Setup PHP with tools
|
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
tools: vimeo/psalm
|
|
||||||
```
|
|
||||||
|
|
||||||
- To set up a particular version of a tool, specify it in the form `tool:version`.
|
|
||||||
|
|
||||||
Version can be in the following format:
|
|
||||||
- Semver. For example `tool:1.2.3` or `tool:1.2.3-beta1`.
|
|
||||||
- Major version. For example `tool:1` or `tool:1.x`.
|
|
||||||
- Major and minor version. For example `tool:1.2` or `tool:1.2.x`.
|
|
||||||
|
|
||||||
When you specify just the major version or the version in `major.minor` format, the latest patch version matching the input will be setup.
|
|
||||||
|
|
||||||
Except for major versions of `composer`, For other tools when you specify only the `major` version or the version in `major.minor` format for any tool you can get rate limited by GitHub's API. To avoid this, it is recommended to provide a [`GitHub` OAuth token](https://github.com/shivammathur/setup-php#composer-github-oauth "Composer GitHub OAuth"). You can do that by setting `COMPOSER_TOKEN` environment variable.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- name: Setup PHP with tools
|
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
tools: php-cs-fixer:3, phpunit:8.5
|
|
||||||
env:
|
|
||||||
COMPOSER_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
```
|
|
||||||
|
|
||||||
- The latest stable version of `composer` is set up by default. You can set up the required `composer` version by specifying the major version `v1` or `v2`, or the version in `major.minor` or `semver` format, Additionally for composer `snapshot` and `preview` can also be specified to set up the respective releases.
|
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with composer v2
|
- name: Setup PHP with composer v2
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
tools: composer:v2
|
tools: composer:v2
|
||||||
```
|
```
|
||||||
|
|
||||||
- If you do not use composer in your workflow, you can specify `tools: none` to skip it.
|
- If you have specified composer plugins `prestissimo` or `composer-prefetcher` in tools, the latest stable version of `composer v1` will be setup. Unless some of your packages require `composer v1`, it is recommended to drop `prestissimo` and use `composer v2`.
|
||||||
|
|
||||||
|
- The latest versions of both agent `blackfire-agent` and client `blackfire` are setup when `blackfire` is specified in tools input. Please refer to the [official documentation](https://blackfire.io/docs/integrations/ci/github-actions "Blackfire.io documentation for GitHub Actions") for using `blackfire` with GitHub Actions.
|
||||||
|
|
||||||
|
- Version for other tools should be in `semver` format and a valid release of the tool. This is useful for installing tools for older versions of PHP. For example to set up `PHPUnit` on `PHP 7.2`.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP without composer
|
- name: Setup PHP with tools
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.2'
|
||||||
tools: none
|
tools: phpunit:8.5.8
|
||||||
```
|
```
|
||||||
|
|
||||||
- Scripts `phpize` and `php-config` are set up with the same version as of the input PHP version.
|
|
||||||
|
|
||||||
- The latest version of `blackfire` cli is set up when `blackfire` is specified in tools input. Please refer to the [official documentation](https://blackfire.io/docs/integrations/ci/github-actions "Blackfire.io documentation for GitHub Actions") for using `blackfire` with GitHub Actions.
|
|
||||||
|
|
||||||
- Tools `prestissimo` and `composer-prefetcher` will be skipped unless `composer:v1` is also specified in tools input. It is recommended to drop `prestissimo` and use `composer v2`.
|
|
||||||
|
|
||||||
- By default, tools which cannot be set up 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, tools which cannot be set up 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
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
tools: deployer
|
tools: deployer
|
||||||
env:
|
env:
|
||||||
fail-fast: true
|
fail-fast: true
|
||||||
@ -285,52 +235,42 @@ These tools can be set up globally using the `tools` input. It accepts a string
|
|||||||
**Notes**
|
**Notes**
|
||||||
- Input `tools` is useful to set up tools which you only use in GitHub Actions, thus keeping your `composer.json` tidy.
|
- Input `tools` is useful to set up tools which you only use in GitHub Actions, thus keeping your `composer.json` tidy.
|
||||||
- If you do not want to use all your dev-dependencies in GitHub Actions workflow, you can run composer with `--no-dev` and install required tools using `tools` input to speed up your workflow.
|
- If you do not want to use all your dev-dependencies in GitHub Actions workflow, you can run composer with `--no-dev` and install required tools using `tools` input to speed up your workflow.
|
||||||
- If you have a tool in your `composer.json`, do not set up it with `tools` input as the two instances of the tool might conflict.
|
- If you have a tool in your `composer.json`, do not setup it with `tools` input as the two instances of the tool might conflict.
|
||||||
|
|
||||||
## :signal_strength: Coverage Support
|
## :signal_strength: Coverage Support
|
||||||
|
|
||||||
### Xdebug
|
### Xdebug
|
||||||
|
|
||||||
Specify `coverage: xdebug` to use `Xdebug` and disable `PCOV`.
|
Specify `coverage: xdebug` to use `Xdebug`.
|
||||||
Runs on all [PHP versions supported](#tada-php-support "List of PHP versions supported on this GitHub Action").
|
Runs on all [PHP versions supported](#tada-php-support "List of PHP versions supported on this GitHub Action").
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with Xdebug
|
- name: Setup PHP with Xdebug
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
coverage: xdebug
|
|
||||||
```
|
|
||||||
|
|
||||||
- The latest version of Xdebug compatible with the PHP version is set up by default.
|
|
||||||
- If you need Xdebug 2.x on PHP 7.2, 7.3 or 7.4, you can specify `coverage: xdebug2`.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- name: Setup PHP with Xdebug 2.x
|
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '7.4'
|
php-version: '7.4'
|
||||||
coverage: xdebug2
|
coverage: xdebug
|
||||||
```
|
```
|
||||||
|
|
||||||
### PCOV
|
### PCOV
|
||||||
|
|
||||||
Specify `coverage: pcov` to use `PCOV` and disable `Xdebug`.
|
Specify `coverage: pcov` to use `PCOV` and disable `Xdebug`.
|
||||||
Runs on PHP 7.1 and newer PHP versions.
|
`PCOV` supports `PHP 7.1` and newer PHP versions.
|
||||||
|
Tests with `PCOV` run much faster than with `Xdebug`.
|
||||||
- If your source code directory is other than `src`, `lib` or, `app`, specify `pcov.directory` using the `ini-values` input.
|
If your source code directory is other than `src`, `lib` or, `app`, specify `pcov.directory` using the `ini-values` input.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with PCOV
|
- name: Setup PHP with PCOV
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
ini-values: pcov.directory=api #optional, see above for usage.
|
ini-values: pcov.directory=api #optional, see above for usage.
|
||||||
coverage: pcov
|
coverage: pcov
|
||||||
```
|
```
|
||||||
|
|
||||||
- PHPUnit 8.x and above supports PCOV out of the box.
|
`PHPUnit` 8 and above supports `PCOV` out of the box.
|
||||||
- If you are using PHPUnit 5.x, 6.x or 7.x, you need to set up `pcov/clobber` before executing your tests.
|
If you are using `PHPUnit` 5, 6 or 7, you will need `krakjoe/pcov-clobber`.
|
||||||
|
Before executing your tests add the following step.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PCOV
|
- name: Setup PCOV
|
||||||
@ -342,20 +282,18 @@ 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 remove both `Xdebug` and `PCOV`.
|
||||||
|
Consider disabling the coverage using this PHP action 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 remove `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.
|
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with no coverage driver
|
- name: Setup PHP with no coverage driver
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
coverage: none
|
coverage: none
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -368,9 +306,8 @@ Disable coverage for these reasons:
|
|||||||
#### `php-version` (required)
|
#### `php-version` (required)
|
||||||
|
|
||||||
- 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 `'7.4'`.
|
||||||
- Accepts `latest` to set up the latest stable PHP version.
|
- Accepts `latest` to set up the latest stable PHP version.
|
||||||
- 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)
|
||||||
@ -383,8 +320,7 @@ Disable coverage for these reasons:
|
|||||||
#### `ini-values` (optional)
|
#### `ini-values` (optional)
|
||||||
|
|
||||||
- Specify the values you want to add to `php.ini`.
|
- Specify the values you want to add to `php.ini`.
|
||||||
- Accepts a `string` in csv-format. For example `post_max_size=256M, max_execution_time=180`.
|
- Accepts a `string` in csv-format. For example `post_max_size=256M, short_open_tag=On`.
|
||||||
- Accepts ini values with commas if wrapped in quotes. For example `xdebug.mode="develop,coverage"`.
|
|
||||||
|
|
||||||
#### `coverage` (optional)
|
#### `coverage` (optional)
|
||||||
|
|
||||||
@ -398,25 +334,6 @@ Disable coverage for these reasons:
|
|||||||
- Accepts a `string` in csv-format. For example: `phpunit, phpcs`
|
- Accepts a `string` in csv-format. For example: `phpunit, phpcs`
|
||||||
- See [tools Support](#wrench-tools-support) for tools supported.
|
- See [tools Support](#wrench-tools-support) for tools supported.
|
||||||
|
|
||||||
### Outputs
|
|
||||||
|
|
||||||
#### `php-version`
|
|
||||||
|
|
||||||
To use outputs, give the `setup-php` step an `id`, you can use the same to get the outputs in a later step.
|
|
||||||
|
|
||||||
- Provides the PHP version in semver format.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- name: Setup PHP
|
|
||||||
id: setup-php
|
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
|
|
||||||
- name: Print PHP version
|
|
||||||
run: echo ${{ steps.setup-php.outputs.php-version }}
|
|
||||||
```
|
|
||||||
|
|
||||||
### Flags
|
### Flags
|
||||||
|
|
||||||
> Specify using `env` keyword
|
> Specify using `env` keyword
|
||||||
@ -430,7 +347,7 @@ To use outputs, give the `setup-php` step an `id`, you can use the same to get t
|
|||||||
|
|
||||||
#### `phpts` (optional)
|
#### `phpts` (optional)
|
||||||
|
|
||||||
- Specify to set up thread-safe version of PHP on Windows.
|
- Specify to set up thread-safe version of PHP on windows.
|
||||||
- Accepts `ts` and `nts`.
|
- Accepts `ts` and `nts`.
|
||||||
- By default, it is set to `nts`.
|
- By default, it is set to `nts`.
|
||||||
- See [thread safe setup](#thread-safe-setup) for more info.
|
- See [thread safe setup](#thread-safe-setup) for more info.
|
||||||
@ -440,7 +357,7 @@ To use outputs, give the `setup-php` step an `id`, you can use the same to get t
|
|||||||
- Specify to update PHP on the runner to the latest patch version.
|
- Specify to update PHP on the runner to the latest patch version.
|
||||||
- Accepts `true` and `false`.
|
- Accepts `true` and `false`.
|
||||||
- By default, it is set to `false`.
|
- By default, it is set to `false`.
|
||||||
- See [force update setup](#force-update-setup) for more info.
|
- See [force update](#force-update) for more info.
|
||||||
|
|
||||||
See below for more info.
|
See below for more info.
|
||||||
|
|
||||||
@ -450,12 +367,15 @@ See below for more info.
|
|||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
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:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
extensions: mbstring, intl
|
extensions: mbstring, intl
|
||||||
ini-values: post_max_size=256M, max_execution_time=180
|
ini-values: post_max_size=256M, short_open_tag=On
|
||||||
coverage: xdebug
|
coverage: xdebug
|
||||||
tools: php-cs-fixer, phpunit
|
tools: php-cs-fixer, phpunit
|
||||||
```
|
```
|
||||||
@ -470,101 +390,31 @@ jobs:
|
|||||||
runs-on: ${{ matrix.operating-system }}
|
runs-on: ${{ matrix.operating-system }}
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
operating-system: ['ubuntu-latest', 'windows-latest', 'macos-latest']
|
operating-system: [ubuntu-latest, windows-latest, macos-latest]
|
||||||
php-versions: ['7.3', '7.4', '8.0']
|
php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4']
|
||||||
phpunit-versions: ['latest']
|
name: PHP ${{ matrix.php-versions }} Test on ${{ matrix.operating-system }}
|
||||||
include:
|
|
||||||
- operating-system: 'ubuntu-latest'
|
|
||||||
php-versions: '7.2'
|
|
||||||
phpunit-versions: '8.5.19'
|
|
||||||
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:
|
||||||
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, short_open_tag=On
|
||||||
coverage: xdebug
|
|
||||||
tools: php-cs-fixer, phpunit:${{ matrix.phpunit-versions }}
|
|
||||||
```
|
|
||||||
|
|
||||||
### Nightly Build Setup
|
|
||||||
|
|
||||||
> Setup a nightly build of `PHP 8.1`.
|
|
||||||
|
|
||||||
- This version is currently in development.
|
|
||||||
- Some user space extensions might not support this version currently.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
steps:
|
|
||||||
- name: Setup nightly PHP
|
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.1'
|
|
||||||
extensions: mbstring
|
|
||||||
ini-values: post_max_size=256M, max_execution_time=180
|
|
||||||
coverage: xdebug
|
coverage: xdebug
|
||||||
tools: php-cs-fixer, phpunit
|
tools: php-cs-fixer, phpunit
|
||||||
```
|
```
|
||||||
|
|
||||||
### Thread Safe Setup
|
|
||||||
|
|
||||||
> Setup `TS` or `NTS` PHP on `Windows`.
|
|
||||||
|
|
||||||
- `NTS` versions are set up by default.
|
|
||||||
- On `Ubuntu` and `macOS` only `NTS` versions are supported.
|
|
||||||
- On `Windows` both `TS` and `NTS` versions are supported.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
jobs:
|
|
||||||
run:
|
|
||||||
runs-on: windows-latest
|
|
||||||
name: Setup PHP TS on Windows
|
|
||||||
steps:
|
|
||||||
- name: Setup PHP
|
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
env:
|
|
||||||
phpts: ts # specify ts or nts
|
|
||||||
```
|
|
||||||
|
|
||||||
### Force Update Setup
|
|
||||||
|
|
||||||
> Update to the latest patch of PHP versions.
|
|
||||||
|
|
||||||
- Pre-installed PHP versions on the GitHub Actions images are not updated to their latest patch release by default.
|
|
||||||
- You can specify the `update` environment variable to `true` for updating to the latest release.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- name: Setup PHP with latest versions
|
|
||||||
uses: shivammathur/setup-php@v2
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
env:
|
|
||||||
update: true # specify true or false
|
|
||||||
```
|
|
||||||
|
|
||||||
### Verbose Setup
|
|
||||||
|
|
||||||
> Debug your workflow
|
|
||||||
|
|
||||||
To debug any issues, you can use the `verbose` tag instead of `v2`.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- name: Setup PHP with logs
|
|
||||||
uses: shivammathur/setup-php@verbose
|
|
||||||
with:
|
|
||||||
php-version: '8.0'
|
|
||||||
```
|
|
||||||
|
|
||||||
### Multi-Arch Setup
|
### Multi-Arch Setup
|
||||||
|
|
||||||
> Setup PHP on multiple architecture on Ubuntu GitHub Runners.
|
> Setup PHP on multiple architecture on Ubuntu GitHub Runners.
|
||||||
|
|
||||||
- `PHP 5.6` to `PHP 8.0` are supported by `setup-php` on multiple architecture on `Ubuntu`.
|
- `PHP 5.6` to `PHP 7.4` are supported by `setup-php` on multiple architecture on `Ubuntu`.
|
||||||
- For this, you can use `shivammathur/node` images as containers. These have compatible `Nodejs` installed for JavaScript based GitHub Actions.
|
- For this, you can use `shivammathur/node` images as containers. These have compatible `Nodejs` and `spc` utility.
|
||||||
- Currently, for `ARM` based setup, you will need [self-hosted runners](#self-hosted-setup).
|
- Using `spc` you can run `setup-php` on both `i386` and `amd64` containers as opposed to [default syntax](#basic-setup), which only supports `amd64`.
|
||||||
|
- Currently, for `Arm` based setup, you will need [self-hosted runners](#self-hosted-setup).
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
jobs:
|
jobs:
|
||||||
@ -576,21 +426,50 @@ jobs:
|
|||||||
arch: ["amd64", "i386"]
|
arch: ["amd64", "i386"]
|
||||||
steps:
|
steps:
|
||||||
- name: Install PHP
|
- name: Install PHP
|
||||||
|
run: |
|
||||||
|
# Update spc (See https://github.com/shivammathur/spc for options)
|
||||||
|
spc -U
|
||||||
|
|
||||||
|
# Install PHP
|
||||||
|
spc --php-version "7.4" \
|
||||||
|
--extensions "mbstring, intl" \
|
||||||
|
--ini-values "post_max_size=256M, short_open_tag=On" \
|
||||||
|
--coverage "xdebug" \
|
||||||
|
--tools "php-cs-fixer, phpunit"
|
||||||
|
```
|
||||||
|
|
||||||
|
### Nightly Build Setup
|
||||||
|
|
||||||
|
> Setup a nightly build of `PHP 8.0` or `PHP 8.1`.
|
||||||
|
|
||||||
|
- These versions are currently in development.
|
||||||
|
- `PECL` is installed by default with these versions on `ubuntu` and `macOS`.
|
||||||
|
- Some user space extensions might not support these versions currently.
|
||||||
|
- Refer to this [RFC](https://wiki.php.net/rfc/jit "PHP JIT RFC configuration") for configuring `PHP JIT` on these versions.
|
||||||
|
- Refer to this [list of RFCs](https://wiki.php.net/rfc#php_80 "List of RFCs implemented in PHP8") for features implemented in `PHP 8.0`.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Setup nightly PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '8.1'
|
||||||
|
extensions: mbstring
|
||||||
|
ini-values: opcache.jit_buffer_size=256M, opcache.jit=1235, pcre.jit=1
|
||||||
|
coverage: pcov
|
||||||
|
tools: php-cs-fixer, phpunit
|
||||||
```
|
```
|
||||||
|
|
||||||
### Self Hosted Setup
|
### Self Hosted Setup
|
||||||
|
|
||||||
> Setup PHP on a self-hosted runner.
|
> Setup PHP on a self-hosted runner.
|
||||||
|
|
||||||
- To set up a containerised self-hosted runner, refer to the following guides as per your base operating system.
|
- To set up a dockerized self-hosted runner, refer to this [guide](https://github.com/shivammathur/setup-php/wiki/Dockerized-self-hosted-runner-on-Ubuntu) to set up in an `Ubuntu` container and refer to this [guide](https://github.com/shivammathur/setup-php/wiki/Dockerized-self-hosted-runner-on-Windows) to set up in a `Windows` container.
|
||||||
- [Linux](https://github.com/shivammathur/setup-php/wiki/Dockerized-self-hosted-runner-on-Linux)
|
|
||||||
- [Windows](https://github.com/shivammathur/setup-php/wiki/Dockerized-self-hosted-runner-on-Windows)
|
|
||||||
|
|
||||||
- To set up the runner directly on the host OS or in a virtual machine, follow this [requirements guide](https://github.com/shivammathur/setup-php/wiki/Requirements-for-self-hosted-runners "Requirements guide for self-hosted runner to run setup-php") before setting up the self-hosted runner.
|
- To set up the runner directly on the host OS or in a virtual machine, follow this [requirements guide](https://github.com/shivammathur/setup-php/wiki/Requirements-for-self-hosted-runners "Requirements guide for self-hosted runner to run setup-php") before setting up the self-hosted runner.
|
||||||
- If your workflow uses [service containers](https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idservices "GitHub Actions Services"), then set up the runner on a Linux host or in a Linux virtual machine. GitHub Actions does not support nested virtualization on Linux, so services will not work in a dockerized container.
|
- If your workflow uses [services](https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idservices "GitHub Actions Services"), then setup the runner on a Linux host or in a Linux virtual machine. GitHub Actions does not support nested virtualization on Linux, so services will not work in a dockerized container.
|
||||||
|
|
||||||
Specify the environment variable `runner` with the value `self-hosted`. Without this your workflow will fail.
|
Specify the environment variable `runner` with the value `self-hosted`. Without this your workflow will fail.
|
||||||
|
|
||||||
@ -615,8 +494,8 @@ jobs:
|
|||||||
```
|
```
|
||||||
|
|
||||||
**Notes**
|
**Notes**
|
||||||
- Do not set up multiple self-hosted runners on a single server instance as parallel workflow will conflict with each other.
|
- Do not setup multiple self-hosted runners on a single server instance as parallel workflow will conflict with each other.
|
||||||
- Do not set up self-hosted runners on the side on your development environment or your production server.
|
- Do not setup self-hosted runners on the side on your development environment or your production server.
|
||||||
- Avoid using the same labels for your `self-hosted` runners which are used by `GitHub-hosted` runners.
|
- Avoid using the same labels for your `self-hosted` runners which are used by `GitHub-hosted` runners.
|
||||||
|
|
||||||
### Local Testing Setup
|
### Local Testing Setup
|
||||||
@ -627,46 +506,85 @@ jobs:
|
|||||||
jobs:
|
jobs:
|
||||||
run:
|
run:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
name: PHP 7.4 Test
|
||||||
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:
|
||||||
php-version: '8.0'
|
php-version: 7.4
|
||||||
```
|
```
|
||||||
|
|
||||||
Run the workflow locally with `act` using [`shivammathur/node`](https://github.com/shivammathur/node-docker "Docker image to run setup-php") docker images.
|
Run the workflow locally with `act` using [`shivammathur/node`](https://github.com/shivammathur/node-docker "Docker image to run setup-php") docker image.
|
||||||
|
|
||||||
Choose the image tag which matches the `runs-on` property in your workflow. For example, if you are using `ubuntu-20.04` in your workflow, run `act -P ubuntu-20.04=shivammathur/node:20.04`.
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
# For runs-on: ubuntu-latest
|
# For runs-on: ubuntu-latest
|
||||||
act -P ubuntu-latest=shivammathur/node:latest
|
act -P ubuntu-latest=shivammathur/node:latest
|
||||||
|
|
||||||
# For runs-on: ubuntu-20.04
|
# For runs-on: ubuntu-20.04
|
||||||
act -P ubuntu-20.04=shivammathur/node:2004
|
act -P ubuntu-20.04=shivammathur/node:focal
|
||||||
|
|
||||||
# For runs-on: ubuntu-18.04
|
# For runs-on: ubuntu-18.04
|
||||||
act -P ubuntu-18.04=shivammathur/node:1804
|
act -P ubuntu-18.04=shivammathur/node:bionic
|
||||||
|
|
||||||
|
# For runs-on: ubuntu-16.04
|
||||||
|
act -P ubuntu-16.04=shivammathur/node:xenial
|
||||||
```
|
```
|
||||||
|
|
||||||
### JIT Configuration
|
### Thread Safe Setup
|
||||||
|
|
||||||
> Enable Just-in-time(JIT) on PHP 8.0 and PHP 8.1.
|
> Setup `TS` or `NTS` PHP on `Windows`.
|
||||||
|
|
||||||
- To enable JIT, enable `opcache` in cli mode by setting `opcache.enable_cli=1`.
|
- `NTS` versions are setup by default.
|
||||||
- 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.
|
- On `Ubuntu` and `macOS` only `NTS` versions are supported.
|
||||||
- By default, `opcache.jit=1235` and `opcache.jit_buffer_size=256M` are set which can be changed using `ini-values` input.
|
- On `Windows` both `TS` and `NTS` versions are supported.
|
||||||
- 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 example to enable JIT in `tracing` mode with buffer size of `64 MB`.
|
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP with JIT in tracing mode
|
jobs:
|
||||||
|
run:
|
||||||
|
runs-on: windows-latest
|
||||||
|
name: Setup PHP TS on Windows
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
coverage: none
|
env:
|
||||||
ini-values: opcache.enable_cli=1, opcache.jit=tracing, opcache.jit_buffer_size=64M
|
phpts: ts # specify ts or nts
|
||||||
|
```
|
||||||
|
|
||||||
|
### Force Update
|
||||||
|
|
||||||
|
> Update to the latest patch of PHP versions.
|
||||||
|
|
||||||
|
- Pre-installed PHP versions on the GitHub Actions runner are not updated to their latest patch release by default.
|
||||||
|
- You can specify the `update` environment variable to `true` to force update to the latest release.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- name: Setup PHP with latest versions
|
||||||
|
uses: shivammathur/setup-php@v2
|
||||||
|
with:
|
||||||
|
php-version: '7.4'
|
||||||
|
env:
|
||||||
|
update: true # specify true or false
|
||||||
|
```
|
||||||
|
|
||||||
|
### Verbose Setup
|
||||||
|
|
||||||
|
> Debug your workflow
|
||||||
|
|
||||||
|
To debug any issues, you can use the `verbose` tag instead of `v2`.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- name: Setup PHP with logs
|
||||||
|
uses: shivammathur/setup-php@verbose
|
||||||
|
with:
|
||||||
|
php-version: '7.4'
|
||||||
```
|
```
|
||||||
|
|
||||||
### Cache Extensions
|
### Cache Extensions
|
||||||
@ -707,37 +625,36 @@ key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}-${{ matrix.p
|
|||||||
restore-keys: ${{ runner.os }}-composer-${{ matrix.prefer }}-
|
restore-keys: ${{ runner.os }}-composer-${{ matrix.prefer }}-
|
||||||
```
|
```
|
||||||
|
|
||||||
### Composer GitHub OAuth
|
### Cache Node.js Dependencies
|
||||||
|
|
||||||
If you have a number of workflows which set up multiple tools or have many composer dependencies, you might hit the GitHub's rate limit for composer. Also, if you specify only the major version or the version in `major.minor` format, you can hit the rate limit. To avoid this you can specify an `OAuth` token by setting `COMPOSER_TOKEN` environment variable. You can use [`GITHUB_TOKEN`](https://help.github.com/en/actions/configuring-and-managing-workflows/authenticating-with-the-github_token "GITHUB_TOKEN documentation") secret for this purpose.
|
If your project has node.js dependencies, you can persist NPM or yarn cache directory. The cached files are available across check-runs and will reduce the workflow execution time.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP
|
- name: Get node.js cache directory
|
||||||
uses: shivammathur/setup-php@v2
|
id: node-cache-dir
|
||||||
|
run: echo "::set-output name=dir::$(npm config get cache)" # Use $(yarn cache dir) for yarn
|
||||||
|
|
||||||
|
- name: Cache dependencies
|
||||||
|
uses: actions/cache@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
path: ${{ steps.node-cache-dir.outputs.dir }}
|
||||||
env:
|
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} # Use '**/yarn.lock' for yarn
|
||||||
COMPOSER_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
restore-keys: ${{ runner.os }}-node-
|
||||||
```
|
```
|
||||||
|
|
||||||
### Inline PHP Scripts
|
**Note:** Please do not cache `node_modules` directory as that will have side effects.
|
||||||
|
|
||||||
If you have to run multiple lines of PHP code in your workflow, you can do that easily without saving it to a file.
|
### Composer GitHub OAuth
|
||||||
|
|
||||||
Put the code in the run property of a step and specify the shell as `php {0}`.
|
If you have a number of workflows which setup multiple tools or have many composer dependencies, you might hit the GitHub's rate limit for composer. To avoid that you can add an `OAuth` token to the composer's config by setting `COMPOSER_TOKEN` environment variable. You can use [`GITHUB_TOKEN`](https://help.github.com/en/actions/configuring-and-managing-workflows/authenticating-with-the-github_token "GITHUB_TOKEN documentation") secret for this purpose.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
|
env:
|
||||||
- name: Run PHP code
|
COMPOSER_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
shell: php {0}
|
|
||||||
run: |
|
|
||||||
<?php
|
|
||||||
$welcome = "Hello, world";
|
|
||||||
echo $welcome;
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Problem Matchers
|
### Problem Matchers
|
||||||
@ -770,7 +687,7 @@ PHPStan supports error reporting in GitHub Actions, so it does not require probl
|
|||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
tools: phpstan
|
tools: phpstan
|
||||||
|
|
||||||
- name: Run PHPStan
|
- name: Run PHPStan
|
||||||
@ -785,7 +702,7 @@ Psalm supports error reporting in GitHub Actions with an output format `github`.
|
|||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
tools: psalm
|
tools: psalm
|
||||||
|
|
||||||
- name: Run Psalm
|
- name: Run Psalm
|
||||||
@ -803,7 +720,7 @@ For examples refer to [cs2pr documentation](https://github.com/staabm/annotate-p
|
|||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: '8.0'
|
php-version: '7.4'
|
||||||
tools: cs2pr, phpcs
|
tools: cs2pr, phpcs
|
||||||
|
|
||||||
- name: Run phpcs
|
- name: Run phpcs
|
||||||
@ -842,9 +759,9 @@ Examples of using `setup-php` with various PHP Frameworks and Packages.
|
|||||||
|
|
||||||
## :bookmark: Versioning
|
## :bookmark: Versioning
|
||||||
|
|
||||||
- Use the `v2` tag as `setup-php` version. It is a rolling tag and is synced with the latest minor and patch releases. With `v2` you automatically get the bug fixes, security patches, new features and support for latest PHP releases. For debugging any issues `verbose` tag can be used temporarily. It outputs all the logs and is also synced with the latest releases.
|
- Use the `v2` tag as `setup-php` version. It is a rolling tag and is synced with the latest minor and patch releases. With `v2` you automatically get the bug fixes, new features and support for latest PHP releases. For debugging any issues `verbose` tag can be used temporarily. It outputs all the logs and is also synced with the latest releases.
|
||||||
- Semantic release versions can also be used. It is recommended to [use dependabot](https://docs.github.com/en/github/administering-a-repository/keeping-your-actions-up-to-date-with-github-dependabot "Setup Dependabot with GitHub Actions") with semantic versioning to keep the actions in your workflows up to date.
|
- Semantic release versions can also be used. It is recommended to [use dependabot](https://docs.github.com/en/github/administering-a-repository/keeping-your-actions-up-to-date-with-github-dependabot "Setup Dependabot with GitHub Actions") with semantic versioning to keep the actions in your workflows up to date.
|
||||||
- Commit SHA can also be used, but are not recommended. They have to be updated with every release manually, without which you will not get any bug fixes, security patches or new features.
|
- Commit SHA can also be used, but are not recommended. They have to be updated with every release manually, without which you will not get any bug fixes or new features.
|
||||||
- It is highly discouraged to use the `master` branch as version, it might break your workflow after major releases as they have breaking changes.
|
- It is highly discouraged to use the `master` branch as version, it might break your workflow after major releases as they have breaking changes.
|
||||||
- If you are using the `v1` tag or a `1.x.y` version, you should [switch to v2](https://github.com/shivammathur/setup-php/wiki/Switch-to-v2 "Guide for switching from setup-php v1 to v2") as `v1` only gets critical bug fixes. Maintenance support for `v1` will be dropped with the last `PHP 8.0` release.
|
- If you are using the `v1` tag or a `1.x.y` version, you should [switch to v2](https://github.com/shivammathur/setup-php/wiki/Switch-to-v2 "Guide for switching from setup-php v1 to v2") as `v1` only gets critical bug fixes. Maintenance support for `v1` will be dropped with the last `PHP 8.0` release.
|
||||||
|
|
||||||
@ -859,42 +776,35 @@ Examples of using `setup-php` with various PHP Frameworks and Packages.
|
|||||||
> Contributions are welcome!
|
> Contributions are welcome!
|
||||||
|
|
||||||
- See [Contributor's Guide](.github/CONTRIBUTING.md "shivammathur/setup-php contribution guide") before you start.
|
- See [Contributor's Guide](.github/CONTRIBUTING.md "shivammathur/setup-php contribution guide") before you start.
|
||||||
- If you face any issues or want to suggest a feature/improvement, start a discussion [here](https://github.com/shivammathur/setup-php/discussions "Setup PHP discussions").
|
- If you face any issues while using this or want to suggest a feature/improvement, create an issue [here](https://github.com/shivammathur/setup-php/issues "Issues reported").
|
||||||
|
|
||||||
*Contributors of `setup-php` and other related projects*
|
*Join the list of setup-php contributors*
|
||||||
|
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://github.com/shivammathur/setup-php/graphs/contributors">
|
<a href="https://github.com/shivammathur/setup-php/graphs/contributors">
|
||||||
<img src="https://setup-php.com/contributors/?" alt="Contributors of setup-php and related projects" width="100%">
|
<img src="https://opencollective.com/setup-php/contributors.svg?width=1024&button=false" alt="setup-php contributors" width="100%">
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
## :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 consider supporting our work by sponsoring using [Open Collective](https://opencollective.com/setup-php), [Paypal](https://www.paypal.me/shivammathur "Shivam Mathur PayPal") or [Patreon](https://www.patreon.com/shivammathur "Shivam Mathur Patreon").
|
||||||
|
- If you use `setup-php` at your company, please [reach out](mailto:contact@setup-php.com) to sponsor the project.
|
||||||
|
|
||||||
*`setup-php` is generously supported by*
|
*Huge thanks to the following companies for supporting `setup-php`*
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
<a href="https://www.jetbrains.com/?from=setup-php">
|
<a href="https://www.jetbrains.com/?from=setup-php">
|
||||||
<img src="https://setup-php.com/sponsors/jetbrains.svg" alt="JetBrains" width="106" height="60">
|
<img src="https://shivammathur.com/jetbrains.svg" alt="JetBrains" width="106" height="60">
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<a href="https://blackfire.io/?utm_source=setup-php">
|
<a href="https://blackfire.io/?utm_source=setup-php">
|
||||||
<img src="https://setup-php.com/sponsors//blackfire.svg" alt="Blackfire" width="212" height="60">
|
<img src="https://shivammathur.com/blackfire.svg" alt="Blackfire" width="212" height="60">
|
||||||
</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>
|
||||||
|
|
||||||
<a href="https://tidelift.com/subscription/pkg/npm-setup-php">
|
<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">
|
<img src="https://shivammathur.com/tidelift.png" alt="Tidelift" width="70" height="60">
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -902,6 +812,7 @@ Examples of using `setup-php` with various PHP Frameworks and Packages.
|
|||||||
|
|
||||||
- [Node.js dependencies](https://github.com/shivammathur/setup-php/network/dependencies "Node.js dependencies")
|
- [Node.js dependencies](https://github.com/shivammathur/setup-php/network/dependencies "Node.js dependencies")
|
||||||
- [aaronparker/VcRedist](https://github.com/aaronparker/VcRedist "VcRedist PowerShell package")
|
- [aaronparker/VcRedist](https://github.com/aaronparker/VcRedist "VcRedist PowerShell package")
|
||||||
|
- [gplessis/dotdeb-php](https://github.com/gplessis/dotdeb-php "Packaging for end of life PHP versions")
|
||||||
- [mlocati/powershell-phpmanager](https://github.com/mlocati/powershell-phpmanager "Package to handle PHP on windows")
|
- [mlocati/powershell-phpmanager](https://github.com/mlocati/powershell-phpmanager "Package to handle PHP on windows")
|
||||||
- [ppa:ondrej/php](https://launchpad.net/~ondrej/+archive/ubuntu/php "Packaging active PHP packages")
|
- [ppa:ondrej/php](https://launchpad.net/~ondrej/+archive/ubuntu/php "Packaging active PHP packages")
|
||||||
- [shivammathur/cache-extensions](https://github.com/shivammathur/cache-extensions "GitHub action to help with caching PHP extensions")
|
- [shivammathur/cache-extensions](https://github.com/shivammathur/cache-extensions "GitHub action to help with caching PHP extensions")
|
||||||
@ -912,8 +823,8 @@ Examples of using `setup-php` with various PHP Frameworks and Packages.
|
|||||||
- [shivammathur/php-builder](https://github.com/shivammathur/php-builder "Nightly PHP package for Ubuntu")
|
- [shivammathur/php-builder](https://github.com/shivammathur/php-builder "Nightly PHP package for Ubuntu")
|
||||||
- [shivammathur/php-builder-windows](https://github.com/shivammathur/php-builder-windows "Nightly PHP package for Windows")
|
- [shivammathur/php-builder-windows](https://github.com/shivammathur/php-builder-windows "Nightly PHP package for Windows")
|
||||||
- [shivammathur/php-ubuntu](https://github.com/shivammathur/php-ubuntu "Cache stable PHP Packages for Ubuntu")
|
- [shivammathur/php-ubuntu](https://github.com/shivammathur/php-ubuntu "Cache stable PHP Packages for Ubuntu")
|
||||||
- [shivammathur/php5-darwin](https://github.com/shivammathur/php5-darwin "Scripts to set up PHP5 versions on darwin")
|
- [shivammathur/php5-darwin](https://github.com/shivammathur/php5-darwin "Scripts to setup PHP5 versions on darwin")
|
||||||
- [shivammathur/php5-ubuntu](https://github.com/shivammathur/php5-ubuntu "Scripts to set up PHP5 versions on ubuntu")
|
- [shivammathur/php5-ubuntu](https://github.com/shivammathur/php5-ubuntu "Scripts to setup PHP5 versions on ubuntu")
|
||||||
|
|
||||||
## :bookmark_tabs: Further Reading
|
## :bookmark_tabs: Further Reading
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ describe('Config tests', () => {
|
|||||||
true
|
true
|
||||||
);
|
);
|
||||||
expect(linux).toContain(
|
expect(linux).toContain(
|
||||||
'echo "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata" | sudo tee -a "${pecl_file:-${ini_file[@]}}"'
|
'echo "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata"'
|
||||||
);
|
);
|
||||||
|
|
||||||
linux = await config.addINIValues(
|
linux = await config.addINIValues(
|
||||||
@ -40,7 +40,7 @@ describe('Config tests', () => {
|
|||||||
'darwin'
|
'darwin'
|
||||||
);
|
);
|
||||||
expect(darwin).toContain(
|
expect(darwin).toContain(
|
||||||
'echo "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata" | sudo tee -a "${pecl_file:-${ini_file[@]}}"'
|
'echo "post_max_size=256M\nshort_open_tag=On\ndate.timezone=Asia/Kolkata"'
|
||||||
);
|
);
|
||||||
|
|
||||||
darwin = await config.addINIValues(
|
darwin = await config.addINIValues(
|
||||||
|
@ -30,29 +30,39 @@ describe('Config tests', () => {
|
|||||||
expect(win32).toContain('Add-Extension xdebug');
|
expect(win32).toContain('Add-Extension xdebug');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug3 on windows', async () => {
|
|
||||||
const win32: string = await coverage.addCoverage('xdebug3', '7.4', 'win32');
|
|
||||||
expect(win32).toContain('Add-Extension xdebug');
|
|
||||||
});
|
|
||||||
|
|
||||||
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 () => {
|
it('checking addCoverage with Xdebug on linux', async () => {
|
||||||
const linux: string = await coverage.addCoverage('xdebug', '8.0', 'linux');
|
const linux: string = await coverage.addCoverage('xdebug', '8.0', 'linux');
|
||||||
expect(linux).toContain('add_extension xdebug');
|
expect(linux).toContain('add_extension xdebug');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug3 on linux', async () => {
|
it('checking addCoverage with Xdebug3 on linux', async () => {
|
||||||
const linux: string = await coverage.addCoverage('xdebug3', '8.0', 'linux');
|
const linux: string = await coverage.addCoverage('xdebug3', '7.4', 'linux');
|
||||||
expect(linux).toContain('add_extension xdebug');
|
expect(linux).toContain('add_extension_from_source xdebug');
|
||||||
|
expect(linux).toContain('echo "xdebug.mode=coverage"');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug2 on linux', async () => {
|
it('checking addCoverage with Xdebug3 on linux', async () => {
|
||||||
const linux: string = await coverage.addCoverage('xdebug2', '7.4', 'linux');
|
const linux: string = await coverage.addCoverage('xdebug3', '8.0', 'linux');
|
||||||
expect(linux).toContain('add_pecl_extension xdebug 2.9.8 zend_extension');
|
expect(linux).toContain('add_extension xdebug');
|
||||||
|
expect(linux).toContain('echo "xdebug.mode=coverage"');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('checking addCoverage with Xdebug on linux', async () => {
|
||||||
|
const linux: string = await coverage.addCoverage('xdebug', '8.0', 'linux');
|
||||||
|
expect(linux).toContain('add_extension xdebug');
|
||||||
|
expect(linux).toContain('echo "xdebug.mode=coverage"');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('checking addCoverage with Xdebug3 on linux', async () => {
|
||||||
|
const linux: string = await coverage.addCoverage('xdebug3', '8.1', 'linux');
|
||||||
|
expect(linux).toContain('add_extension xdebug');
|
||||||
|
expect(linux).toContain('echo "xdebug.mode=coverage"');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('checking addCoverage with Xdebug on linux', async () => {
|
||||||
|
const linux: string = await coverage.addCoverage('xdebug', '8.1', 'linux');
|
||||||
|
expect(linux).toContain('add_extension xdebug');
|
||||||
|
expect(linux).toContain('echo "xdebug.mode=coverage"');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking addCoverage with Xdebug on darwin', async () => {
|
it('checking addCoverage with Xdebug on darwin', async () => {
|
||||||
@ -64,24 +74,6 @@ describe('Config tests', () => {
|
|||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
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 () => {
|
it('checking disableCoverage windows', async () => {
|
||||||
const win32 = await coverage.addCoverage('none', '7.4', 'win32');
|
const win32 = await coverage.addCoverage('none', '7.4', 'win32');
|
||||||
expect(win32).toContain('Remove-Extension xdebug');
|
expect(win32).toContain('Remove-Extension xdebug');
|
||||||
|
@ -3,7 +3,7 @@ import * as extensions from '../src/extensions';
|
|||||||
describe('Extension tests', () => {
|
describe('Extension tests', () => {
|
||||||
it('checking addExtensionOnWindows', async () => {
|
it('checking addExtensionOnWindows', async () => {
|
||||||
let win32: string = await extensions.addExtension(
|
let win32: string = await extensions.addExtension(
|
||||||
'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',
|
'Xdebug, pcov, sqlite, :intl, phalcon4, ioncube, oci8, pdo_oci, ast-beta, grpc-1.2.3, inotify-1.2.3alpha2, sqlsrv-1.2.3preview1',
|
||||||
'7.4',
|
'7.4',
|
||||||
'win32'
|
'win32'
|
||||||
);
|
);
|
||||||
@ -12,7 +12,6 @@ describe('Extension tests', () => {
|
|||||||
expect(win32).toContain('Add-Extension sqlite3');
|
expect(win32).toContain('Add-Extension sqlite3');
|
||||||
expect(win32).toContain('Remove-Extension intl');
|
expect(win32).toContain('Remove-Extension intl');
|
||||||
expect(win32).toContain('Add-Phalcon phalcon4');
|
expect(win32).toContain('Add-Phalcon phalcon4');
|
||||||
expect(win32).toContain('Add-Http');
|
|
||||||
expect(win32).toContain('Add-Ioncube');
|
expect(win32).toContain('Add-Ioncube');
|
||||||
expect(win32).toContain('Add-Oci oci8');
|
expect(win32).toContain('Add-Oci oci8');
|
||||||
expect(win32).toContain('Add-Oci pdo_oci');
|
expect(win32).toContain('Add-Oci pdo_oci');
|
||||||
@ -26,9 +25,6 @@ describe('Extension tests', () => {
|
|||||||
'Add-Log "$cross" "pcov" "pcov is not supported on PHP 5.6"'
|
'Add-Log "$cross" "pcov" "pcov is not supported on PHP 5.6"'
|
||||||
);
|
);
|
||||||
|
|
||||||
win32 = await extensions.addExtension('xdebug2', '7.2', 'win32');
|
|
||||||
expect(win32).toContain('Add-Extension xdebug stable 2.9.8');
|
|
||||||
|
|
||||||
win32 = await extensions.addExtension('mysql', '7.4', 'win32');
|
win32 = await extensions.addExtension('mysql', '7.4', 'win32');
|
||||||
expect(win32).toContain('Add-Extension mysqli');
|
expect(win32).toContain('Add-Extension mysqli');
|
||||||
expect(win32).toContain('Add-Extension mysqlnd');
|
expect(win32).toContain('Add-Extension mysqlnd');
|
||||||
@ -59,24 +55,17 @@ describe('Extension tests', () => {
|
|||||||
|
|
||||||
win32 = await extensions.addExtension('blackfire-1.31.0', '7.3', 'win32');
|
win32 = await extensions.addExtension('blackfire-1.31.0', '7.3', 'win32');
|
||||||
expect(win32).toContain('Add-Blackfire blackfire-1.31.0');
|
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 () => {
|
it('checking addExtensionOnLinux', async () => {
|
||||||
let linux: string = await extensions.addExtension(
|
let linux: string = await extensions.addExtension(
|
||||||
'Xdebug, pcov, sqlite, :intl, ast, ast-beta, pdo_mysql, pdo-odbc, xdebug-alpha, grpc-1.2.3',
|
'Xdebug, xdebug3, pcov, sqlite, :intl, ast, ast-beta, pdo_mysql, pdo-odbc, xdebug-alpha, grpc-1.2.3',
|
||||||
'7.4',
|
'7.4',
|
||||||
'linux'
|
'linux'
|
||||||
);
|
);
|
||||||
expect(linux).toContain('add_extension xdebug');
|
expect(linux).toContain(
|
||||||
|
'add_extension_from_source xdebug xdebug/xdebug master --enable-xdebug zend_extension'
|
||||||
|
);
|
||||||
expect(linux).toContain('add_extension sqlite3');
|
expect(linux).toContain('add_extension sqlite3');
|
||||||
expect(linux).toContain('remove_extension intl');
|
expect(linux).toContain('remove_extension intl');
|
||||||
expect(linux).toContain('add_unstable_extension ast beta extension');
|
expect(linux).toContain('add_unstable_extension ast beta extension');
|
||||||
@ -107,9 +96,6 @@ describe('Extension tests', () => {
|
|||||||
linux = await extensions.addExtension('cubrid', '7.4', 'linux');
|
linux = await extensions.addExtension('cubrid', '7.4', 'linux');
|
||||||
expect(linux).toContain('add_cubrid cubrid');
|
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');
|
linux = await extensions.addExtension('xdebug', '7.2', 'openbsd');
|
||||||
expect(linux).toContain('Platform openbsd is not supported');
|
expect(linux).toContain('Platform openbsd is not supported');
|
||||||
|
|
||||||
@ -120,15 +106,6 @@ describe('Extension tests', () => {
|
|||||||
linux = await extensions.addExtension('ioncube', '7.3', 'linux');
|
linux = await extensions.addExtension('ioncube', '7.3', 'linux');
|
||||||
expect(linux).toContain('add_ioncube');
|
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');
|
linux = await extensions.addExtension('oci8, pdo_oci', '7.3', 'linux');
|
||||||
expect(linux).toContain('add_oci oci8');
|
expect(linux).toContain('add_oci oci8');
|
||||||
expect(linux).toContain('add_oci pdo_oci');
|
expect(linux).toContain('add_oci pdo_oci');
|
||||||
@ -144,51 +121,32 @@ describe('Extension tests', () => {
|
|||||||
|
|
||||||
linux = await extensions.addExtension('intl-67.1', '7.3', 'linux');
|
linux = await extensions.addExtension('intl-67.1', '7.3', 'linux');
|
||||||
expect(linux).toContain('add_intl intl-67.1');
|
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 () => {
|
it('checking addExtensionOnDarwin', async () => {
|
||||||
let darwin: string = await extensions.addExtension(
|
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',
|
'Xdebug, pcov, grpc, igbinary, imagick, protobuf, swoole, sqlite, oci8, pdo_oci, :intl, ast-beta, grpc-1.2.3',
|
||||||
'7.2',
|
'7.2',
|
||||||
'darwin'
|
'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 xdebug zend_extension');
|
||||||
expect(darwin).toContain('add_brew_extension pcov extension');
|
expect(darwin).toContain('add_brew_extension pcov extension');
|
||||||
expect(darwin).toContain('add_brew_extension grpc extension');
|
expect(darwin).toContain('add_brew_extension grpc extension');
|
||||||
expect(darwin).toContain('add_brew_extension igbinary extension');
|
expect(darwin).toContain('add_brew_extension igbinary extension');
|
||||||
expect(darwin).toContain('add_brew_extension imagick 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 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 swoole extension');
|
||||||
expect(darwin).toContain('add_brew_extension yaml extension');
|
|
||||||
expect(darwin).toContain('add_extension sqlite3');
|
expect(darwin).toContain('add_extension sqlite3');
|
||||||
expect(darwin).toContain('remove_extension intl');
|
expect(darwin).toContain('remove_extension intl');
|
||||||
expect(darwin).toContain('add_unstable_extension ast beta extension');
|
expect(darwin).toContain('add_unstable_extension ast beta extension');
|
||||||
expect(darwin).toContain('add_pecl_extension grpc 1.2.3 extension');
|
expect(darwin).toContain('add_pecl_extension grpc 1.2.3 extension');
|
||||||
|
|
||||||
|
darwin = await extensions.addExtension('phalcon3', '7.0', 'darwin');
|
||||||
|
expect(darwin).toContain('add_phalcon phalcon3');
|
||||||
|
|
||||||
|
darwin = await extensions.addExtension('phalcon4', '7.3', 'darwin');
|
||||||
|
expect(darwin).toContain('add_phalcon phalcon4');
|
||||||
|
|
||||||
darwin = await extensions.addExtension('couchbase', '5.6', 'darwin');
|
darwin = await extensions.addExtension('couchbase', '5.6', 'darwin');
|
||||||
expect(darwin).toContain('add_couchbase');
|
expect(darwin).toContain('add_couchbase');
|
||||||
|
|
||||||
@ -198,15 +156,6 @@ describe('Extension tests', () => {
|
|||||||
darwin = await extensions.addExtension('ioncube', '7.3', 'darwin');
|
darwin = await extensions.addExtension('ioncube', '7.3', 'darwin');
|
||||||
expect(darwin).toContain('add_ioncube');
|
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');
|
darwin = await extensions.addExtension('oci8, pdo_oci', '7.3', 'darwin');
|
||||||
expect(darwin).toContain('add_oci oci8');
|
expect(darwin).toContain('add_oci oci8');
|
||||||
expect(darwin).toContain('add_oci pdo_oci');
|
expect(darwin).toContain('add_oci pdo_oci');
|
||||||
@ -228,8 +177,11 @@ describe('Extension tests', () => {
|
|||||||
darwin = await extensions.addExtension('xdebug', '7.2', 'darwin');
|
darwin = await extensions.addExtension('xdebug', '7.2', 'darwin');
|
||||||
expect(darwin).toContain('add_brew_extension xdebug');
|
expect(darwin).toContain('add_brew_extension xdebug');
|
||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug2', '7.2', 'darwin');
|
darwin = await extensions.addExtension('redis', '5.6', 'darwin');
|
||||||
expect(darwin).toContain('add_brew_extension xdebug2');
|
expect(darwin).toContain('add_extension redis-2.2.8');
|
||||||
|
|
||||||
|
darwin = await extensions.addExtension('redis', '7.2', 'darwin');
|
||||||
|
expect(darwin).toContain('add_extension redis');
|
||||||
|
|
||||||
darwin = await extensions.addExtension('imagick', '5.5', 'darwin');
|
darwin = await extensions.addExtension('imagick', '5.5', 'darwin');
|
||||||
expect(darwin).toContain('add_extension imagick');
|
expect(darwin).toContain('add_extension imagick');
|
||||||
@ -250,14 +202,5 @@ describe('Extension tests', () => {
|
|||||||
|
|
||||||
darwin = await extensions.addExtension('xdebug', '7.2', 'openbsd');
|
darwin = await extensions.addExtension('xdebug', '7.2', 'openbsd');
|
||||||
expect(darwin).toContain('Platform openbsd is not supported');
|
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,9 +5,7 @@ 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(
|
||||||
.fn()
|
|
||||||
.mockImplementation(
|
|
||||||
async (
|
async (
|
||||||
filename: string,
|
filename: string,
|
||||||
version: string,
|
version: string,
|
||||||
@ -39,7 +37,8 @@ jest.mock('../src/install', () => ({
|
|||||||
return script;
|
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(
|
||||||
await utils.getInput('php-version', true)
|
await utils.getInput('php-version', true)
|
||||||
@ -53,7 +52,8 @@ jest.mock('../src/install', () => ({
|
|||||||
version,
|
version,
|
||||||
__dirname
|
__dirname
|
||||||
].join(' ');
|
].join(' ');
|
||||||
})
|
}
|
||||||
|
)
|
||||||
}));
|
}));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -117,7 +117,7 @@ describe('Install', () => {
|
|||||||
|
|
||||||
script = '' + (await install.run());
|
script = '' + (await install.run());
|
||||||
expect(script).toContain('initial script');
|
expect(script).toContain('initial script');
|
||||||
expect(script).toContain('bash linux.sh 8.0 ');
|
expect(script).toContain('bash linux.sh 7.4 ');
|
||||||
|
|
||||||
setEnv('7.3', 'linux', 'a, b', 'a=b', 'x', 'phpunit');
|
setEnv('7.3', 'linux', 'a, b', 'a=b', 'x', 'phpunit');
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -19,11 +19,7 @@ async function cleanup(path: string): Promise<void> {
|
|||||||
describe('Utils tests', () => {
|
describe('Utils tests', () => {
|
||||||
it('checking readEnv', async () => {
|
it('checking readEnv', async () => {
|
||||||
process.env['test'] = 'setup-php';
|
process.env['test'] = 'setup-php';
|
||||||
process.env['test-hyphen'] = 'setup-php';
|
|
||||||
expect(await utils.readEnv('test')).toBe('setup-php');
|
expect(await utils.readEnv('test')).toBe('setup-php');
|
||||||
expect(await utils.readEnv('TEST')).toBe('setup-php');
|
|
||||||
expect(await utils.readEnv('test_hyphen')).toBe('setup-php');
|
|
||||||
expect(await utils.readEnv('TEST_HYPHEN')).toBe('setup-php');
|
|
||||||
expect(await utils.readEnv('undefined')).toBe('');
|
expect(await utils.readEnv('undefined')).toBe('');
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -32,43 +28,15 @@ describe('Utils tests', () => {
|
|||||||
expect(await utils.getInput('test', false)).toBe('setup-php');
|
expect(await utils.getInput('test', false)).toBe('setup-php');
|
||||||
expect(await utils.getInput('setup-php', false)).toBe('setup-php');
|
expect(await utils.getInput('setup-php', false)).toBe('setup-php');
|
||||||
expect(await utils.getInput('DoesNotExist', false)).toBe('');
|
expect(await utils.getInput('DoesNotExist', false)).toBe('');
|
||||||
await expect(async () => {
|
expect(async () => {
|
||||||
await utils.getInput('DoesNotExist', true);
|
await utils.getInput('DoesNotExist', true);
|
||||||
}).rejects.toThrow('Input required and not supplied: DoesNotExist');
|
}).rejects.toThrow('Input required and not supplied: DoesNotExist');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking fetch', async () => {
|
|
||||||
const manifest = await utils.getManifestURL();
|
|
||||||
let response: Record<string, string> = await utils.fetch(manifest);
|
|
||||||
expect(response.error).toBe(undefined);
|
|
||||||
expect(response.data).toContain('latest');
|
|
||||||
|
|
||||||
response = await utils.fetch(manifest, 'invalid_token');
|
|
||||||
expect(response.error).not.toBe(undefined);
|
|
||||||
expect(response.data).toBe(undefined);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking getManifestURL', async () => {
|
|
||||||
expect(await utils.getManifestURL()).toContain('php-versions.json');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('checking parseVersion', async () => {
|
it('checking parseVersion', async () => {
|
||||||
jest
|
|
||||||
.spyOn(utils, 'fetch')
|
|
||||||
.mockImplementation(
|
|
||||||
async (url, token?): Promise<Record<string, string>> => {
|
|
||||||
if (!token || token === 'valid_token') {
|
|
||||||
return {data: `{ "latest": "8.0", "5.x": "5.6", "url": "${url}" }`};
|
|
||||||
} else {
|
|
||||||
return {error: 'Invalid token'};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
expect(await utils.parseVersion('latest')).toBe('8.0');
|
|
||||||
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('latest')).toBe('7.4');
|
||||||
expect(await utils.parseVersion('4.x')).toBe(undefined);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking asyncForEach', async () => {
|
it('checking asyncForEach', async () => {
|
||||||
@ -90,7 +58,7 @@ describe('Utils tests', () => {
|
|||||||
expect(await utils.color('warning')).toBe('33');
|
expect(await utils.color('warning')).toBe('33');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking readFile', async () => {
|
it('checking readScripts', async () => {
|
||||||
const darwin: string = fs.readFileSync(
|
const darwin: string = fs.readFileSync(
|
||||||
path.join(__dirname, '../src/scripts/darwin.sh'),
|
path.join(__dirname, '../src/scripts/darwin.sh'),
|
||||||
'utf8'
|
'utf8'
|
||||||
@ -103,12 +71,12 @@ describe('Utils tests', () => {
|
|||||||
path.join(__dirname, '../src/scripts/win32.ps1'),
|
path.join(__dirname, '../src/scripts/win32.ps1'),
|
||||||
'utf8'
|
'utf8'
|
||||||
);
|
);
|
||||||
expect(await utils.readFile('darwin.sh', 'src/scripts')).toBe(darwin);
|
expect(await utils.readScript('darwin.sh')).toBe(darwin);
|
||||||
expect(await utils.readFile('darwin.sh', 'src/scripts')).toBe(darwin);
|
expect(await utils.readScript('darwin.sh')).toBe(darwin);
|
||||||
expect(await utils.readFile('linux.sh', 'src/scripts')).toBe(linux);
|
expect(await utils.readScript('linux.sh')).toBe(linux);
|
||||||
expect(await utils.readFile('linux.sh', 'src/scripts')).toBe(linux);
|
expect(await utils.readScript('linux.sh')).toBe(linux);
|
||||||
expect(await utils.readFile('win32.ps1', 'src/scripts')).toBe(win32);
|
expect(await utils.readScript('win32.ps1')).toBe(win32);
|
||||||
expect(await utils.readFile('win32.ps1', 'src/scripts')).toBe(win32);
|
expect(await utils.readScript('win32.ps1')).toBe(win32);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking writeScripts', async () => {
|
it('checking writeScripts', async () => {
|
||||||
@ -143,20 +111,6 @@ describe('Utils tests', () => {
|
|||||||
'b=2',
|
'b=2',
|
||||||
'c=3'
|
'c=3'
|
||||||
]);
|
]);
|
||||||
expect(await utils.CSVArray('\'a=1,2\', "b=3, 4", c=5, d=~e~')).toEqual([
|
|
||||||
'a=1,2',
|
|
||||||
'b=3, 4',
|
|
||||||
'c=5',
|
|
||||||
"d='~e~'"
|
|
||||||
]);
|
|
||||||
expect(await utils.CSVArray('a=\'1,2\', b="3, 4", c=5')).toEqual([
|
|
||||||
'a=1,2',
|
|
||||||
'b=3, 4',
|
|
||||||
'c=5'
|
|
||||||
]);
|
|
||||||
expect(
|
|
||||||
await utils.CSVArray('a=E_ALL, b=E_ALL & ~ E_ALL, c="E_ALL", d=\'E_ALL\'')
|
|
||||||
).toEqual(['a=E_ALL', 'b=E_ALL & ~ E_ALL', 'c=E_ALL', 'd=E_ALL']);
|
|
||||||
expect(await utils.CSVArray('')).toEqual([]);
|
expect(await utils.CSVArray('')).toEqual([]);
|
||||||
expect(await utils.CSVArray(' ')).toEqual([]);
|
expect(await utils.CSVArray(' ')).toEqual([]);
|
||||||
});
|
});
|
||||||
@ -277,31 +231,4 @@ describe('Utils tests', () => {
|
|||||||
await utils.customPackage('pkg8', 'ext', '1.2.3', 'linux')
|
await utils.customPackage('pkg8', 'ext', '1.2.3', 'linux')
|
||||||
).toContain(script_path + '\nadd_pkg 1.2.3');
|
).toContain(script_path + '\nadd_pkg 1.2.3');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('checking parseExtensionSource', async () => {
|
|
||||||
expect(
|
|
||||||
await utils.parseExtensionSource(
|
|
||||||
'ext-org-name/repo-name@release',
|
|
||||||
'extension'
|
|
||||||
)
|
|
||||||
).toContain(
|
|
||||||
'\nadd_extension_from_source ext https://github.com org-name repo-name release extension'
|
|
||||||
);
|
|
||||||
expect(
|
|
||||||
await utils.parseExtensionSource(
|
|
||||||
'ext-https://sub.domain.tld/org/repo@release',
|
|
||||||
'extension'
|
|
||||||
)
|
|
||||||
).toContain(
|
|
||||||
'\nadd_extension_from_source ext https://sub.domain.tld org repo release extension'
|
|
||||||
);
|
|
||||||
expect(
|
|
||||||
await utils.parseExtensionSource(
|
|
||||||
'ext-https://sub.domain.XN--tld/org/repo@release',
|
|
||||||
'extension'
|
|
||||||
)
|
|
||||||
).toContain(
|
|
||||||
'\nadd_extension_from_source ext https://sub.domain.XN--tld org repo release extension'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
name: 'Setup PHP Action'
|
name: 'Setup PHP Action'
|
||||||
author: shivammathur
|
author: shivammathur
|
||||||
description: 'GitHub Action for PHP'
|
description: 'Setup PHP with required extensions, php.ini configuration, code-coverage support and various tools like composer'
|
||||||
branding:
|
branding:
|
||||||
color: 'purple'
|
color: 'purple'
|
||||||
icon: 'play-circle'
|
icon: 'play-circle'
|
||||||
inputs:
|
inputs:
|
||||||
php-version:
|
php-version:
|
||||||
description: 'Setup PHP version.'
|
description: 'Setup PHP version.'
|
||||||
default: '8.0'
|
default: '7.4'
|
||||||
required: true
|
required: true
|
||||||
extensions:
|
extensions:
|
||||||
description: 'Setup PHP extensions.'
|
description: 'Setup PHP extensions.'
|
||||||
@ -21,9 +21,6 @@ inputs:
|
|||||||
tools:
|
tools:
|
||||||
description: 'Setup popular tools globally.'
|
description: 'Setup popular tools globally.'
|
||||||
required: false
|
required: false
|
||||||
outputs:
|
|
||||||
php-version:
|
|
||||||
description: 'PHP version in semver format'
|
|
||||||
runs:
|
runs:
|
||||||
using: 'node12'
|
using: 'node12'
|
||||||
main: 'dist/index.js'
|
main: 'dist/index.js'
|
||||||
|
4535
dist/index.js
vendored
4535
dist/index.js
vendored
File diff suppressed because it is too large
Load Diff
@ -25,7 +25,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
php-version: ${{ matrix.php-versions }}
|
php-version: ${{ matrix.php-versions }}
|
||||||
extensions: blackfire
|
extensions: blackfire
|
||||||
tools: blackfire #Setup Blackfire cli
|
tools: blackfire #Setup Blackfire client and agent
|
||||||
coverage: none
|
coverage: none
|
||||||
- name: Profile
|
- name: Profile
|
||||||
run: blackfire run php my-script.php # Refer to https://blackfire.io/docs/cookbooks/profiling-cli
|
run: blackfire run php my-script.php # Refer to https://blackfire.io/docs/cookbooks/profiling-cli
|
||||||
|
@ -26,7 +26,6 @@ jobs:
|
|||||||
uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
|
uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
|
||||||
with:
|
with:
|
||||||
php-version: ${{ matrix.php-versions }}
|
php-version: ${{ matrix.php-versions }}
|
||||||
tools: phpunit-bridge
|
|
||||||
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, mysql
|
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, mysql
|
||||||
coverage: xdebug #optional
|
coverage: xdebug #optional
|
||||||
- name: Start mysql service
|
- name: Start mysql service
|
||||||
@ -43,15 +42,14 @@ jobs:
|
|||||||
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
|
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
|
||||||
restore-keys: ${{ runner.os }}-composer-
|
restore-keys: ${{ runner.os }}-composer-
|
||||||
- name: Install Composer dependencies
|
- name: Install Composer dependencies
|
||||||
run: composer install --no-progress --prefer-dist --optimize-autoloader
|
run: |
|
||||||
|
composer install --no-progress --prefer-dist --optimize-autoloader
|
||||||
- name: Run Migration
|
- name: Run Migration
|
||||||
run: |
|
run: |
|
||||||
composer require --dev symfony/orm-pack
|
composer require symfony/orm-pack
|
||||||
php bin/console doctrine:schema:update --force || echo "No migrations found or schema update failed"
|
php bin/console doctrine:schema:update --force || echo "No migrations found or schema update failed"
|
||||||
php bin/console doctrine:migrations:migrate || echo "No migrations found or migration failed"
|
php bin/console doctrine:migrations:migrate || echo "No migrations found or migration failed"
|
||||||
env:
|
env:
|
||||||
DATABASE_URL: mysql://root:symfony@127.0.0.1:${{ job.services.mysql.ports['3306'] }}/symfony
|
DATABASE_URL: mysql://root:symfony@127.0.0.1:${{ job.services.mysql.ports['3306'] }}/symfony
|
||||||
- name: Install PHPUnit
|
- name: Run Tests
|
||||||
run: simple-phpunit install
|
run: php bin/phpunit --coverage-text
|
||||||
- name: Run tests
|
|
||||||
run: simple-phpunit --coverage-text
|
|
@ -26,7 +26,6 @@ jobs:
|
|||||||
uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
|
uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
|
||||||
with:
|
with:
|
||||||
php-version: ${{ matrix.php-versions }}
|
php-version: ${{ matrix.php-versions }}
|
||||||
tools: phpunit-bridge
|
|
||||||
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, pgsql
|
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite, pgsql
|
||||||
coverage: xdebug #optional
|
coverage: xdebug #optional
|
||||||
- name: Get composer cache directory
|
- name: Get composer cache directory
|
||||||
@ -41,15 +40,14 @@ jobs:
|
|||||||
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
|
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
|
||||||
restore-keys: ${{ runner.os }}-composer-
|
restore-keys: ${{ runner.os }}-composer-
|
||||||
- name: Install Composer dependencies
|
- name: Install Composer dependencies
|
||||||
run: composer install --no-progress --prefer-dist --optimize-autoloader
|
run: |
|
||||||
|
composer install --no-progress --prefer-dist --optimize-autoloader
|
||||||
- name: Run Migration
|
- name: Run Migration
|
||||||
run: |
|
run: |
|
||||||
composer require --dev symfony/orm-pack
|
composer require symfony/orm-pack
|
||||||
php bin/console doctrine:schema:update --force || echo "No migrations found or schema update failed"
|
php bin/console doctrine:schema:update --force || echo "No migrations found or schema update failed"
|
||||||
php bin/console doctrine:migrations:migrate || echo "No migrations found or migration failed"
|
php bin/console doctrine:migrations:migrate || echo "No migrations found or migration failed"
|
||||||
env:
|
env:
|
||||||
DATABASE_URL: postgres://postgres:postgres@127.0.0.1:${{ job.services.postgres.ports[5432] }}/postgres?charset=UTF-8
|
DATABASE_URL: postgres://postgres:postgres@127.0.0.1:${{ job.services.postgres.ports[5432] }}/postgres?charset=UTF-8
|
||||||
- name: Install PHPUnit
|
- name: Run Tests
|
||||||
run: simple-phpunit install
|
run: php bin/phpunit --coverage-text
|
||||||
- name: Run tests
|
|
||||||
run: simple-phpunit --coverage-text
|
|
@ -17,7 +17,6 @@ jobs:
|
|||||||
uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
|
uses: shivammathur/setup-php@v2 #https://github.com/shivammathur/setup-php
|
||||||
with:
|
with:
|
||||||
php-version: ${{ matrix.php-versions }}
|
php-version: ${{ matrix.php-versions }}
|
||||||
tools: phpunit-bridge
|
|
||||||
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite
|
extensions: mbstring, xml, ctype, iconv, intl, pdo_sqlite
|
||||||
coverage: xdebug #optional
|
coverage: xdebug #optional
|
||||||
- name: Get composer cache directory
|
- name: Get composer cache directory
|
||||||
@ -32,8 +31,8 @@ jobs:
|
|||||||
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
|
key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
|
||||||
restore-keys: ${{ runner.os }}-composer-
|
restore-keys: ${{ runner.os }}-composer-
|
||||||
- name: Install Composer dependencies
|
- name: Install Composer dependencies
|
||||||
run: composer install --no-progress --prefer-dist --optimize-autoloader
|
run: |
|
||||||
- name: Install PHPUnit
|
composer require symfony/orm-pack
|
||||||
run: simple-phpunit install
|
composer install --no-progress --prefer-dist --optimize-autoloader
|
||||||
- name: Run tests
|
- name: Run Tests
|
||||||
run: simple-phpunit --coverage-text
|
run: php bin/phpunit --coverage-text
|
11282
package-lock.json
generated
11282
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
44
package.json
44
package.json
@ -1,15 +1,15 @@
|
|||||||
{
|
{
|
||||||
"name": "setup-php",
|
"name": "setup-php",
|
||||||
"version": "2.13.0",
|
"version": "2.8.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": "dist/index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "tsc",
|
"build": "tsc",
|
||||||
"lint": "eslint **/*.ts --cache --fix",
|
"lint": "eslint **/*.ts --cache --fix",
|
||||||
"format": "prettier --write **/*.ts && git add .",
|
"format": "prettier --write **/*.ts && git add .",
|
||||||
"format-check": "prettier --check **/*.ts",
|
"format-check": "prettier --check **/*.ts",
|
||||||
"release": "ncc build -o dist && git add -f dist/",
|
"release": "ncc build src/install.ts -o dist && git add -f dist/",
|
||||||
"test": "jest"
|
"test": "jest"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
@ -24,28 +24,28 @@
|
|||||||
"author": "shivammathur",
|
"author": "shivammathur",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.5.0",
|
"@actions/core": "^1.2.6",
|
||||||
"@actions/exec": "^1.1.0",
|
"@actions/exec": "^1.0.4",
|
||||||
"@actions/io": "^1.1.1",
|
"@actions/io": "^1.0.2",
|
||||||
"fs": "0.0.1-security"
|
"fs": "0.0.1-security"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/jest": "^27.0.1",
|
"@types/jest": "^26.0.15",
|
||||||
"@types/node": "^16.7.1",
|
"@types/node": "^14.14.7",
|
||||||
"@typescript-eslint/eslint-plugin": "^4.29.2",
|
"@typescript-eslint/eslint-plugin": "^4.7.0",
|
||||||
"@typescript-eslint/parser": "^4.29.2",
|
"@typescript-eslint/parser": "^4.7.0",
|
||||||
"@vercel/ncc": "^0.29.2",
|
"@zeit/ncc": "^0.22.3",
|
||||||
"eslint": "^7.32.0",
|
"eslint": "^7.13.0",
|
||||||
"eslint-config-prettier": "^8.3.0",
|
"eslint-config-prettier": "^6.15.0",
|
||||||
"eslint-plugin-import": "^2.24.1",
|
"eslint-plugin-import": "^2.22.1",
|
||||||
"eslint-plugin-jest": "^24.4.0",
|
"eslint-plugin-jest": "^24.1.3",
|
||||||
"eslint-plugin-prettier": "^3.4.1",
|
"eslint-plugin-prettier": "^3.1.4",
|
||||||
"husky": "^4.3.8",
|
"husky": "^4.3.0",
|
||||||
"jest": "^27.0.6",
|
"jest": "^26.6.3",
|
||||||
"jest-circus": "^27.0.6",
|
"jest-circus": "^26.6.3",
|
||||||
"prettier": "^2.3.2",
|
"prettier": "^2.1.2",
|
||||||
"ts-jest": "^27.0.5",
|
"ts-jest": "^26.4.4",
|
||||||
"typescript": "^4.3.5"
|
"typescript": "^4.0.5"
|
||||||
},
|
},
|
||||||
"husky": {
|
"husky": {
|
||||||
"skipCI": true,
|
"skipCI": true,
|
||||||
|
@ -14,12 +14,7 @@ export async function addINIValuesUnix(
|
|||||||
script +=
|
script +=
|
||||||
'\n' + (await utils.addLog('$tick', line, 'Added to php.ini', 'linux'));
|
'\n' + (await utils.addLog('$tick', line, 'Added to php.ini', 'linux'));
|
||||||
});
|
});
|
||||||
return (
|
return 'echo "' + ini_values.join('\n') + '" >> $ini_file' + script;
|
||||||
'echo "' +
|
|
||||||
ini_values.join('\n') +
|
|
||||||
'" | sudo tee -a "${pecl_file:-${ini_file[@]}}" >/dev/null 2>&1' +
|
|
||||||
script
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,17 +0,0 @@
|
|||||||
8,jessie
|
|
||||||
9,stretch
|
|
||||||
10,buster
|
|
||||||
11,bullseye
|
|
||||||
12,bookworm
|
|
||||||
16.04 LTS,xenial
|
|
||||||
16.10,yakkety
|
|
||||||
17.04,zesty
|
|
||||||
17.10,artful
|
|
||||||
18.04 LTS,bionic
|
|
||||||
18.10,cosmic
|
|
||||||
19.04,disco
|
|
||||||
19.10,eoan
|
|
||||||
20.04 LTS,focal
|
|
||||||
20.10,groovy
|
|
||||||
21.04,hirsute
|
|
||||||
21.10,impish
|
|
|
@ -1,6 +0,0 @@
|
|||||||
{
|
|
||||||
"latest": "8.0",
|
|
||||||
"5.x": "5.6",
|
|
||||||
"7.x": "7.4",
|
|
||||||
"8.x": "8.0"
|
|
||||||
}
|
|
@ -1,236 +0,0 @@
|
|||||||
{
|
|
||||||
"composer-normalize": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "ergebnis/composer-normalize",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"cs2pr": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "staabm/annotate-pull-request-from-checkstyle",
|
|
||||||
"extension": "",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"infection": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "infection/infection",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"phan": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "phan/phan",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-v"
|
|
||||||
},
|
|
||||||
"php-cs-fixer": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "FriendsOfPHP/PHP-CS-Fixer",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"fetch_latest": "true",
|
|
||||||
"version_prefix": "v",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"phpcbf": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "squizlabs/PHP_CodeSniffer",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "--version"
|
|
||||||
},
|
|
||||||
"phpcs": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "squizlabs/PHP_CodeSniffer",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "--version"
|
|
||||||
},
|
|
||||||
"phpmd": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "phpmd/phpmd",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "--version"
|
|
||||||
},
|
|
||||||
"phpstan": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "phpstan/phpstan",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"psalm": {
|
|
||||||
"type": "phar",
|
|
||||||
"repository": "vimeo/psalm",
|
|
||||||
"extension": ".phar",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-v"
|
|
||||||
},
|
|
||||||
"behat": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "behat/behat"
|
|
||||||
},
|
|
||||||
"codeception": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "codeception/codeception"
|
|
||||||
},
|
|
||||||
"automatic-composer-prefetcher": {
|
|
||||||
"type": "composer",
|
|
||||||
"alias": "composer-prefetcher",
|
|
||||||
"repository": "narrowspark/automatic-composer-prefetcher"
|
|
||||||
},
|
|
||||||
"composer-require-checker": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "maglnet/composer-require-checker"
|
|
||||||
},
|
|
||||||
"composer-unused": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "icanhazstring/composer-unused"
|
|
||||||
},
|
|
||||||
"flex": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "symfony/flex"
|
|
||||||
},
|
|
||||||
"phinx": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "robmorgan/phinx"
|
|
||||||
},
|
|
||||||
"phplint": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "overtrue/phplint"
|
|
||||||
},
|
|
||||||
"phpspec": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "phpspec/phpspec"
|
|
||||||
},
|
|
||||||
"phpunit-bridge": {
|
|
||||||
"alias": "simple-phpunit",
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "symfony/phpunit-bridge"
|
|
||||||
},
|
|
||||||
"prestissimo": {
|
|
||||||
"type": "composer",
|
|
||||||
"repository": "hirak/prestissimo"
|
|
||||||
},
|
|
||||||
"vapor-cli": {
|
|
||||||
"type": "composer",
|
|
||||||
"alias": "vapor",
|
|
||||||
"repository": "laravel/vapor-cli"
|
|
||||||
},
|
|
||||||
"blackfire": {
|
|
||||||
"type": "custom-package",
|
|
||||||
"alias": "blackfire-agent"
|
|
||||||
},
|
|
||||||
"grpc_php_plugin": {
|
|
||||||
"type": "custom-package",
|
|
||||||
"repository": "grpc/grpc",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "v"
|
|
||||||
},
|
|
||||||
"protoc": {
|
|
||||||
"type": "custom-package",
|
|
||||||
"repository": "protocolbuffers/protobuf",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"version_prefix": "v"
|
|
||||||
},
|
|
||||||
"blackfire-player": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"domain": "https://get.blackfire.io",
|
|
||||||
"function": "blackfire_player",
|
|
||||||
"version_prefix": "v",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"composer": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"domain": "https://getcomposer.org",
|
|
||||||
"repository": "composer/composer",
|
|
||||||
"function": "composer"
|
|
||||||
},
|
|
||||||
"deployer": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"domain": "https://deployer.org",
|
|
||||||
"repository": "deployphp/deployer",
|
|
||||||
"function": "deployer",
|
|
||||||
"version_prefix": "v",
|
|
||||||
"version_parameter": "-V"
|
|
||||||
},
|
|
||||||
"pecl": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"function": "pecl"
|
|
||||||
},
|
|
||||||
"phing": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"domain": "https://www.phing.info",
|
|
||||||
"repository": "phingofficial/phing",
|
|
||||||
"function": "phing",
|
|
||||||
"extension": ".phar",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "-v"
|
|
||||||
},
|
|
||||||
"phive": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"repository": "phar-io/phive",
|
|
||||||
"domain": "https://phar.io",
|
|
||||||
"function": "phive",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "status"
|
|
||||||
},
|
|
||||||
"phpcpd": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"repository": "sebastianbergmann/phpcpd",
|
|
||||||
"domain": "https://phar.phpunit.de",
|
|
||||||
"function": "phpcpd",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "--version"
|
|
||||||
},
|
|
||||||
"phpunit": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"repository": "sebastianbergmann/phpunit",
|
|
||||||
"domain": "https://phar.phpunit.de",
|
|
||||||
"function": "phpcpd",
|
|
||||||
"version_prefix": "",
|
|
||||||
"version_parameter": "--version"
|
|
||||||
},
|
|
||||||
"phpize": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"function": "dev_tools",
|
|
||||||
"alias": "php-config"
|
|
||||||
},
|
|
||||||
"php-config": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"function": "dev_tools"
|
|
||||||
},
|
|
||||||
"symfony-cli": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"function": "symfony",
|
|
||||||
"alias": "symfony",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"repository": "symfony/cli",
|
|
||||||
"version_prefix": "v",
|
|
||||||
"version_parameter": "version"
|
|
||||||
},
|
|
||||||
"wp-cli": {
|
|
||||||
"type": "custom-function",
|
|
||||||
"function": "wp_cli",
|
|
||||||
"repository": "wp-cli/wp-cli",
|
|
||||||
"domain": "https://github.com",
|
|
||||||
"alias": "wp",
|
|
||||||
"extension": ".phar",
|
|
||||||
"version_parameter": "--version",
|
|
||||||
"version_prefix": "v"
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,115 +0,0 @@
|
|||||||
{
|
|
||||||
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
||||||
"$id": "https://raw.githubusercontent.com/shivammathur/setup-php/develop/src/configs/tools_schema.json",
|
|
||||||
"type": "object",
|
|
||||||
"title": "Tools",
|
|
||||||
"default": {},
|
|
||||||
"examples": [
|
|
||||||
{
|
|
||||||
"tool": {
|
|
||||||
"alias": "tool_alias",
|
|
||||||
"domain": "https://example.com",
|
|
||||||
"extension": ".ext",
|
|
||||||
"fetch_latest": "true",
|
|
||||||
"function": "function_name",
|
|
||||||
"repository": "user/tool",
|
|
||||||
"type": "phar, composer, custom-package or custom-function",
|
|
||||||
"version_parameter": "--version",
|
|
||||||
"version_prefix": "v"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"items": {
|
|
||||||
"properties": {
|
|
||||||
"alias": {
|
|
||||||
"$id": "#/items/properties/alias",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The alias schema",
|
|
||||||
"description": "Alias for a tool.",
|
|
||||||
"examples": [
|
|
||||||
"tool_alias"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"domain": {
|
|
||||||
"$id": "#/items/properties/domain",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The domain schema",
|
|
||||||
"description": "Domain URL of the tool.",
|
|
||||||
"examples": [
|
|
||||||
"https://example.com"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"extension": {
|
|
||||||
"$id": "#/items/properties/extension",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The extension schema",
|
|
||||||
"description": "File extension of the tool.",
|
|
||||||
"examples": [
|
|
||||||
".ext"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"fetch_latest": {
|
|
||||||
"$id": "#/items/properties/fetch_latest",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The fetch_latest schema",
|
|
||||||
"description": "Fetch the latest version from GitHub releases.",
|
|
||||||
"enum": [
|
|
||||||
"true",
|
|
||||||
"false"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"function": {
|
|
||||||
"$id": "#/items/properties/function",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The function schema",
|
|
||||||
"description": "Function name in tools.ts which returns the script to setup the tool.",
|
|
||||||
"examples": [
|
|
||||||
"function_name"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"repository": {
|
|
||||||
"$id": "#/items/properties/repository",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The repository schema",
|
|
||||||
"description": "GitHub repository of the tool.",
|
|
||||||
"examples": [
|
|
||||||
"user/tool"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"type": {
|
|
||||||
"$id": "#/items/properties/type",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The type schema",
|
|
||||||
"description": "Type of tool: phar, composer, custom-package or custom-function.",
|
|
||||||
"enum": [
|
|
||||||
"phar",
|
|
||||||
"composer",
|
|
||||||
"custom-package",
|
|
||||||
"custom-function"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"version_parameter": {
|
|
||||||
"$id": "#/items/properties/version_parameter",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The version_parameter schema",
|
|
||||||
"description": "Parameter to get the tool version.",
|
|
||||||
"examples": [
|
|
||||||
"--version"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"version_prefix": {
|
|
||||||
"$id": "#/items/properties/version_prefix",
|
|
||||||
"type": "string",
|
|
||||||
"title": "The version_prefix schema",
|
|
||||||
"description": "Prefix of the version in the download URL.",
|
|
||||||
"examples": [
|
|
||||||
"v"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"type"
|
|
||||||
],
|
|
||||||
"additionalProperties": true
|
|
||||||
}
|
|
||||||
}
|
|
@ -16,19 +16,28 @@ export async function addCoverageXdebug(
|
|||||||
os_version: string,
|
os_version: string,
|
||||||
pipe: string
|
pipe: string
|
||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
let script = '\n';
|
const xdebug =
|
||||||
script +=
|
|
||||||
(await extensions.addExtension(':pcov', version, os_version, true)) + pipe;
|
|
||||||
script +=
|
|
||||||
(await extensions.addExtension(extension, version, os_version, true)) +
|
(await extensions.addExtension(extension, version, os_version, true)) +
|
||||||
pipe;
|
pipe;
|
||||||
script += await utils.addLog(
|
const ini = await config.addINIValues(
|
||||||
|
'xdebug.mode=coverage',
|
||||||
|
os_version,
|
||||||
|
true
|
||||||
|
);
|
||||||
|
const log = await utils.addLog(
|
||||||
'$tick',
|
'$tick',
|
||||||
extension,
|
extension,
|
||||||
'Xdebug enabled as coverage driver',
|
'Xdebug enabled as coverage driver',
|
||||||
os_version
|
os_version
|
||||||
);
|
);
|
||||||
return script;
|
switch (true) {
|
||||||
|
case /^xdebug3$/.test(extension):
|
||||||
|
case /^8\.\d$/.test(version):
|
||||||
|
return '\n' + xdebug + '\n' + ini + '\n' + log;
|
||||||
|
case /^xdebug$/.test(extension):
|
||||||
|
default:
|
||||||
|
return xdebug + '\n' + log;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -46,15 +55,24 @@ export async function addCoveragePCOV(
|
|||||||
let script = '\n';
|
let script = '\n';
|
||||||
switch (true) {
|
switch (true) {
|
||||||
default:
|
default:
|
||||||
script +=
|
|
||||||
(await extensions.addExtension(':xdebug', 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 +
|
||||||
|
'\n';
|
||||||
script +=
|
script +=
|
||||||
(await config.addINIValues('pcov.enabled=1', os_version, true)) + '\n';
|
(await config.addINIValues('pcov.enabled=1', os_version, true)) + '\n';
|
||||||
|
|
||||||
|
// add command to disable xdebug and enable pcov
|
||||||
|
switch (os_version) {
|
||||||
|
case 'linux':
|
||||||
|
case 'darwin':
|
||||||
|
script += 'remove_extension xdebug' + pipe + '\n';
|
||||||
|
break;
|
||||||
|
case 'win32':
|
||||||
|
script += 'Remove-Extension xdebug' + pipe + '\n';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
// success
|
// success
|
||||||
script += await utils.addLog(
|
script += await utils.addLog(
|
||||||
'$tick',
|
'$tick',
|
||||||
@ -91,11 +109,17 @@ export async function disableCoverage(
|
|||||||
pipe: string
|
pipe: string
|
||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
let script = '\n';
|
let script = '\n';
|
||||||
script +=
|
switch (os_version) {
|
||||||
(await extensions.addExtension(':pcov', version, os_version, true)) + pipe;
|
case 'linux':
|
||||||
script +=
|
case 'darwin':
|
||||||
(await extensions.addExtension(':xdebug', version, os_version, true)) +
|
script += 'remove_extension xdebug' + pipe + '\n';
|
||||||
pipe;
|
script += 'remove_extension pcov' + pipe + '\n';
|
||||||
|
break;
|
||||||
|
case 'win32':
|
||||||
|
script += 'Remove-Extension xdebug' + pipe + '\n';
|
||||||
|
script += 'Remove-Extension pcov' + pipe + '\n';
|
||||||
|
break;
|
||||||
|
}
|
||||||
script += await utils.addLog(
|
script += await utils.addLog(
|
||||||
'$tick',
|
'$tick',
|
||||||
'none',
|
'none',
|
||||||
@ -121,18 +145,15 @@ export async function addCoverage(
|
|||||||
coverage_driver = coverage_driver.toLowerCase();
|
coverage_driver = coverage_driver.toLowerCase();
|
||||||
const script: string =
|
const script: string =
|
||||||
'\n' + (await utils.stepLog('Setup Coverage', os_version));
|
'\n' + (await utils.stepLog('Setup Coverage', os_version));
|
||||||
const pipe: string = (await utils.suppressOutput(os_version)) + '\n';
|
const pipe: string = await utils.suppressOutput(os_version);
|
||||||
switch (coverage_driver) {
|
switch (coverage_driver) {
|
||||||
case 'pcov':
|
case 'pcov':
|
||||||
return script + (await addCoveragePCOV(version, os_version, pipe));
|
return script + (await addCoveragePCOV(version, os_version, pipe));
|
||||||
case 'xdebug':
|
case 'xdebug':
|
||||||
case 'xdebug3':
|
case 'xdebug3':
|
||||||
return (
|
return (
|
||||||
script + (await addCoverageXdebug('xdebug', version, os_version, pipe))
|
script +
|
||||||
);
|
(await addCoverageXdebug(coverage_driver, version, os_version, pipe))
|
||||||
case 'xdebug2':
|
|
||||||
return (
|
|
||||||
script + (await addCoverageXdebug('xdebug2', version, os_version, pipe))
|
|
||||||
);
|
);
|
||||||
case 'none':
|
case 'none':
|
||||||
return script + (await disableCoverage(version, os_version, pipe));
|
return script + (await disableCoverage(version, os_version, pipe));
|
||||||
|
@ -17,28 +17,24 @@ export async function addExtensionDarwin(
|
|||||||
const version_extension: string = version + extension;
|
const version_extension: string = version + extension;
|
||||||
const [ext_name, ext_version]: string[] = extension.split('-');
|
const [ext_name, ext_version]: string[] = extension.split('-');
|
||||||
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
||||||
|
|
||||||
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 += '\nremove_extension ' + ext_name.slice(1);
|
||||||
return;
|
return;
|
||||||
// match extensions for compiling from source
|
// match 5.3blackfire...5.6blackfire, 7.0blackfire...7.4blackfire
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
// match 5.3blackfire-(semver)...5.6blackfire-(semver), 7.0blackfire-(semver)...7.4blackfire-(semver)
|
||||||
add_script += await utils.parseExtensionSource(extension, ext_prefix);
|
// match pdo_oci and oci8
|
||||||
return;
|
// match 5.3ioncube...7.4ioncube, 7.0ioncube...7.4ioncube
|
||||||
// match 5.3blackfire...8.0blackfire
|
|
||||||
// match 5.3blackfire-(semver)...8.0blackfire-(semver)
|
|
||||||
// match couchbase, geos, pdo_oci, oci8, http, pecl_http
|
|
||||||
// match 5.3ioncube...7.4ioncube
|
|
||||||
// match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4
|
// match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4
|
||||||
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(
|
// match 5.6couchbase...7.4couchbase
|
||||||
|
case /^(5\.[3-6]|7\.[0-4])blackfire(-\d+\.\d+\.\d+)?$/.test(
|
||||||
version_extension
|
version_extension
|
||||||
):
|
):
|
||||||
case /^couchbase$|^geos$|^pdo_oci$|^oci8$|^(pecl_)?http|^pdo_firebird$/.test(
|
case /^pdo_oci$|^oci8$/.test(extension):
|
||||||
extension
|
case /^5\.[3-6]ioncube$|^7\.[0-4]ioncube$/.test(version_extension):
|
||||||
):
|
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension):
|
||||||
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
case /^5\.6couchbase$|^7\.[0-4]couchbase$/.test(version_extension):
|
||||||
add_script += await utils.customPackage(
|
add_script += await utils.customPackage(
|
||||||
ext_name,
|
ext_name,
|
||||||
'ext',
|
'ext',
|
||||||
@ -47,7 +43,7 @@ export async function addExtensionDarwin(
|
|||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
// match pre-release versions. For example - xdebug-beta
|
// match pre-release versions. For example - xdebug-beta
|
||||||
case /.+-(stable|beta|alpha|devel|snapshot|rc|preview)/.test(extension):
|
case /.*-(beta|alpha|devel|snapshot)/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nadd_unstable_extension',
|
'\nadd_unstable_extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
@ -56,7 +52,7 @@ export async function addExtensionDarwin(
|
|||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
// match semver
|
// match semver
|
||||||
case /.+-\d+\.\d+\.\d+.*/.test(extension):
|
case /.*-\d+\.\d+\.\d+.*/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nadd_pecl_extension',
|
'\nadd_pecl_extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
@ -68,21 +64,24 @@ 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.6xdebug to 8.9xdebug, 5.6igbinary to 8.9igbinary
|
||||||
// match 7.1 and newer - pcov
|
// match 5.6grpc to 7.4grpc, 5.6imagick to 7.4imagick, 5.6protobuf to 7.4protobuf, 5.6swoole to 7.4swoole
|
||||||
// match 5.6 to 7.4 - propro
|
// match 7.1pcov to 8.9pcov
|
||||||
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(
|
case /(5\.6|7\.[0-4]|8\.[0-9])(xdebug|igbinary)/.test(version_extension):
|
||||||
|
case /(5\.6|7\.[0-4])(grpc|imagick|protobuf|swoole)/.test(
|
||||||
version_extension
|
version_extension
|
||||||
):
|
):
|
||||||
case /(5\.6|7\.[0-4])propro/.test(version_extension):
|
case /(7\.[1-4]|8\.[0-9])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):
|
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nadd_brew_extension',
|
'\nadd_brew_extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
ext_prefix
|
ext_prefix
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
|
// match 5.6redis
|
||||||
|
case /5\.6redis/.test(version_extension):
|
||||||
|
extension = 'redis-2.2.8';
|
||||||
|
break;
|
||||||
// match sqlite
|
// match sqlite
|
||||||
case /^sqlite$/.test(extension):
|
case /^sqlite$/.test(extension):
|
||||||
extension = 'sqlite3';
|
extension = 'sqlite3';
|
||||||
@ -117,19 +116,17 @@ export async function addExtensionWindows(
|
|||||||
case /^:/.test(ext_name):
|
case /^:/.test(ext_name):
|
||||||
remove_script += '\nRemove-Extension ' + ext_name.slice(1);
|
remove_script += '\nRemove-Extension ' + ext_name.slice(1);
|
||||||
break;
|
break;
|
||||||
// match 5.3blackfire...8.0blackfire
|
// match 5.3blackfire...5.6blackfire, 7.0blackfire...7.4blackfire
|
||||||
// match 5.3blackfire-(semver)...8.0blackfire-(semver)
|
// match 5.3blackfire-(semver)...5.6blackfire-(semver), 7.0blackfire-(semver)...7.4blackfire-(semver)
|
||||||
// match pdo_oci and oci8
|
// match pdo_oci and oci8
|
||||||
// match 5.3ioncube...7.4ioncube
|
// match 5.3ioncube...7.4ioncube, 7.0ioncube...7.4ioncube
|
||||||
// match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4
|
// match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4
|
||||||
// match 7.1pecl_http...8.0pecl_http and 7.1http...8.0http
|
case /^(5\.[3-6]|7\.[0-4])blackfire(-\d+\.\d+\.\d+)?$/.test(
|
||||||
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(
|
|
||||||
version_extension
|
version_extension
|
||||||
):
|
):
|
||||||
case /^pdo_oci$|^oci8$|^pdo_firebird$/.test(extension):
|
case /^pdo_oci$|^oci8$/.test(extension):
|
||||||
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
case /^5\.[3-6]ioncube$|^7\.[0-4]ioncube$/.test(version_extension):
|
||||||
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension):
|
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension):
|
||||||
case /^(7\.[1-4]|8\.0)(pecl_)?http/.test(version_extension):
|
|
||||||
add_script += await utils.customPackage(
|
add_script += await utils.customPackage(
|
||||||
ext_name,
|
ext_name,
|
||||||
'ext',
|
'ext',
|
||||||
@ -138,23 +135,15 @@ export async function addExtensionWindows(
|
|||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
// match pre-release versions. For example - xdebug-beta
|
// match pre-release versions. For example - xdebug-beta
|
||||||
case /.+-(stable|beta|alpha|devel|snapshot)/.test(extension):
|
case /.*-(beta|alpha|devel|snapshot)/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nAdd-Extension',
|
'\nAdd-Extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
ext_version.replace('stable', '')
|
ext_version
|
||||||
);
|
|
||||||
break;
|
|
||||||
// match extensions for compiling from source
|
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
|
||||||
add_script += await utils.getUnsupportedLog(
|
|
||||||
extension,
|
|
||||||
version,
|
|
||||||
'win32'
|
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
// match semver without state
|
// match semver without state
|
||||||
case /.+-\d+\.\d+\.\d+$/.test(extension):
|
case /.*-\d+\.\d+\.\d+$/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nAdd-Extension',
|
'\nAdd-Extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
@ -163,8 +152,8 @@ export async function addExtensionWindows(
|
|||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
// match semver with state
|
// match semver with state
|
||||||
case /.+-\d+\.\d+\.\d+[a-zA-Z]+\d*/.test(extension):
|
case /.*-(\d+\.\d+\.\d)([a-zA-Z+]+)\d*/.test(version_extension):
|
||||||
matches = /.+-(\d+\.\d+\.\d+)([a-zA-Z]+)\d*/.exec(
|
matches = /.*-(\d+\.\d+\.\d)([a-zA-Z+]+)\d*/.exec(
|
||||||
version_extension
|
version_extension
|
||||||
) as RegExpExecArray;
|
) as RegExpExecArray;
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
@ -174,23 +163,21 @@ export async function addExtensionWindows(
|
|||||||
matches[1]
|
matches[1]
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
// match 7.2xdebug2 to 7.4xdebug2
|
|
||||||
case /7\.[2-4]xdebug2/.test(version_extension):
|
|
||||||
add_script += '\nAdd-Extension xdebug stable 2.9.8';
|
|
||||||
break;
|
|
||||||
// match 5.3pcov to 7.0pcov
|
// match 5.3pcov to 7.0pcov
|
||||||
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, 'win32');
|
add_script += await utils.getUnsupportedLog('pcov', version, 'win32');
|
||||||
break;
|
break;
|
||||||
// match 5.3 to 5.6 - mysql, mysqli, mysqlnd
|
// match 5.3mysql..5.6mysql
|
||||||
case /^5\.[3-6](?<!pdo_)(mysql|mysqli|mysqlnd)$/.test(version_extension):
|
// match 5.3mysqli..5.6mysqli
|
||||||
|
// match 5.3mysqlnd..5.6mysqlnd
|
||||||
|
case /^5\.\d(mysql|mysqli|mysqlnd)$/.test(version_extension):
|
||||||
add_script +=
|
add_script +=
|
||||||
'\nAdd-Extension mysql\nAdd-Extension mysqli\nAdd-Extension mysqlnd';
|
'\nAdd-Extension mysql\nAdd-Extension mysqli\nAdd-Extension mysqlnd';
|
||||||
break;
|
break;
|
||||||
// match 7.0 and newer mysql, mysqli and mysqlnd
|
// match 7.0mysql..8.9mysql
|
||||||
case /(?<!5\.[3-6])(?<!pdo_)(mysql|mysqli|mysqlnd)$/.test(
|
// match 7.0mysqli..8.9mysqli
|
||||||
version_extension
|
// match 7.0mysqlnd..8.9mysqlnd
|
||||||
):
|
case /[7-8]\.\d(mysql|mysqli|mysqlnd)$/.test(version_extension):
|
||||||
add_script += '\nAdd-Extension mysqli\nAdd-Extension mysqlnd';
|
add_script += '\nAdd-Extension mysqli\nAdd-Extension mysqlnd';
|
||||||
break;
|
break;
|
||||||
// match sqlite
|
// match sqlite
|
||||||
@ -223,34 +210,31 @@ export async function addExtensionLinux(
|
|||||||
const version_extension: string = version + extension;
|
const version_extension: string = version + extension;
|
||||||
const [ext_name, ext_version]: string[] = extension.split('-');
|
const [ext_name, ext_version]: string[] = extension.split('-');
|
||||||
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
const ext_prefix = await utils.getExtensionPrefix(ext_name);
|
||||||
|
|
||||||
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 += '\nremove_extension ' + ext_name.slice(1);
|
||||||
return;
|
return;
|
||||||
// match extensions for compiling from source
|
// match 5.3blackfire...5.6blackfire, 7.0blackfire...7.4blackfire
|
||||||
case /.+-.+\/.+@.+/.test(extension):
|
// match 5.3blackfire-(semver)...5.6blackfire-(semver), 7.0blackfire-(semver)...7.4blackfire-(semver)
|
||||||
add_script += await utils.parseExtensionSource(extension, ext_prefix);
|
|
||||||
return;
|
|
||||||
// match 5.3blackfire...8.0blackfire
|
|
||||||
// match 5.3blackfire-(semver)...8.0blackfire-(semver)
|
|
||||||
// match 5.3pdo_cubrid...7.2php_cubrid, 5.3cubrid...7.4cubrid
|
// match 5.3pdo_cubrid...7.2php_cubrid, 5.3cubrid...7.4cubrid
|
||||||
// match couchbase, geos, pdo_oci, oci8, http, pecl_http
|
// match pdo_oci and oci8
|
||||||
// match 5.3ioncube...7.4ioncube
|
// match 5.3ioncube...7.4ioncube, 7.0ioncube...7.4ioncube
|
||||||
// match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4
|
// match 7.0phalcon3...7.3phalcon3 and 7.2phalcon4...7.4phalcon4
|
||||||
case /^(5\.[3-6]|7\.[0-4]|8\.0)blackfire(-\d+\.\d+\.\d+)?$/.test(
|
// match 5.6gearman...7.4gearman, 5.6couchbase...7.4couchbase
|
||||||
|
case /^(5\.[3-6]|7\.[0-4])blackfire(-\d+\.\d+\.\d+)?$/.test(
|
||||||
version_extension
|
version_extension
|
||||||
):
|
):
|
||||||
case /^((5\.[3-6])|(7\.[0-2]))pdo_cubrid$|^((5\.[3-6])|(7\.[0-4]))cubrid$/.test(
|
case /^((5\.[3-6])|(7\.[0-2]))pdo_cubrid$|^((5\.[3-6])|(7\.[0-4]))cubrid$/.test(
|
||||||
version_extension
|
version_extension
|
||||||
):
|
):
|
||||||
case /^couchbase$|^gearman$|^geos$|^pdo_oci$|^oci8$|^(pecl_)?http|^pdo_firebird$/.test(
|
case /^pdo_oci$|^oci8$/.test(extension):
|
||||||
extension
|
case /^5\.6intl-[\d]+\.[\d]+$|^7\.[0-4]intl-[\d]+\.[\d]+$/.test(
|
||||||
|
version_extension
|
||||||
):
|
):
|
||||||
case /(?<!5\.[3-5])intl-[\d]+\.[\d]+$/.test(version_extension):
|
case /^5\.[3-6]ioncube$|^7\.[0-4]ioncube$/.test(version_extension):
|
||||||
case /^(5\.[3-6]|7\.[0-4])ioncube$/.test(version_extension):
|
|
||||||
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension):
|
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension):
|
||||||
|
case /^((5\.6)|(7\.[0-4]))(gearman|couchbase)$/.test(version_extension):
|
||||||
add_script += await utils.customPackage(
|
add_script += await utils.customPackage(
|
||||||
ext_name,
|
ext_name,
|
||||||
'ext',
|
'ext',
|
||||||
@ -259,7 +243,7 @@ export async function addExtensionLinux(
|
|||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
// match pre-release versions. For example - xdebug-beta
|
// match pre-release versions. For example - xdebug-beta
|
||||||
case /.+-(stable|beta|alpha|devel|snapshot|rc|preview)/.test(extension):
|
case /.*-(beta|alpha|devel|snapshot)/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nadd_unstable_extension',
|
'\nadd_unstable_extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
@ -268,7 +252,7 @@ export async function addExtensionLinux(
|
|||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
// match semver versions
|
// match semver versions
|
||||||
case /.+-\d+\.\d+\.\d+.*/.test(extension):
|
case /.*-\d+\.\d+\.\d+.*/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script += await utils.joins(
|
||||||
'\nadd_pecl_extension',
|
'\nadd_pecl_extension',
|
||||||
ext_name,
|
ext_name,
|
||||||
@ -280,17 +264,17 @@ export async function addExtensionLinux(
|
|||||||
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, 'linux');
|
add_script += await utils.getUnsupportedLog('pcov', version, 'linux');
|
||||||
return;
|
return;
|
||||||
// match 7.2xdebug2...7.4xdebug2
|
// match 7.2xdebug3..7.4xdebug3
|
||||||
case /^7\.[2-4]xdebug2$/.test(version_extension):
|
case /^7\.[2-4]xdebug3$/.test(version_extension):
|
||||||
add_script += await utils.joins(
|
add_script +=
|
||||||
'\nadd_pecl_extension',
|
'\nadd_extension_from_source xdebug xdebug/xdebug master --enable-xdebug zend_extension';
|
||||||
'xdebug',
|
|
||||||
'2.9.8',
|
|
||||||
ext_prefix
|
|
||||||
);
|
|
||||||
return;
|
return;
|
||||||
|
// match 8.0xdebug3...8.9xdebug3
|
||||||
|
case /^8\.[0-9]xdebug3$/.test(version_extension):
|
||||||
|
extension = 'xdebug';
|
||||||
|
break;
|
||||||
// match pdo extensions
|
// match pdo extensions
|
||||||
case /^pdo[_-].+/.test(extension):
|
case /.*pdo[_-].*/.test(version_extension):
|
||||||
extension = extension.replace(/pdo[_-]|3/, '');
|
extension = extension.replace(/pdo[_-]|3/, '');
|
||||||
add_script += '\nadd_pdo_extension ' + extension;
|
add_script += '\nadd_pdo_extension ' + extension;
|
||||||
return;
|
return;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import {exec} from '@actions/exec';
|
import {exec} from '@actions/exec/lib/exec';
|
||||||
import * as core from '@actions/core';
|
import * as core from '@actions/core';
|
||||||
import * as config from './config';
|
import * as config from './config';
|
||||||
import * as coverage from './coverage';
|
import * as coverage from './coverage';
|
||||||
@ -25,9 +25,12 @@ export async function getScript(
|
|||||||
const extension_csv: string = await utils.getInput('extensions', false);
|
const extension_csv: string = await utils.getInput('extensions', false);
|
||||||
const ini_values_csv: string = await utils.getInput('ini-values', false);
|
const ini_values_csv: string = await utils.getInput('ini-values', false);
|
||||||
const coverage_driver: string = await utils.getInput('coverage', false);
|
const coverage_driver: string = await utils.getInput('coverage', false);
|
||||||
const tools_csv: string = await utils.getInput('tools', false);
|
let tools_csv: string = await utils.getInput('tools', false);
|
||||||
|
if (/.*-(beta|alpha|devel|snapshot|\d+\.\d+\.\d+).*/.test(extension_csv)) {
|
||||||
|
tools_csv = 'pecl, ' + tools_csv;
|
||||||
|
}
|
||||||
|
|
||||||
let script: string = await utils.readFile(filename, 'src/scripts');
|
let script: string = await utils.readScript(filename);
|
||||||
script += await tools.addTools(tools_csv, version, os_version);
|
script += await tools.addTools(tools_csv, version, os_version);
|
||||||
|
|
||||||
if (extension_csv) {
|
if (extension_csv) {
|
||||||
@ -51,32 +54,18 @@ export async function getScript(
|
|||||||
*/
|
*/
|
||||||
export async function run(): Promise<void> {
|
export async function run(): Promise<void> {
|
||||||
try {
|
try {
|
||||||
if ((await utils.readEnv('ImageOS')) == 'ubuntu16') {
|
|
||||||
core.setFailed(
|
|
||||||
'setup-php is not supported on Ubuntu 16.04. Please upgrade to Ubuntu 18.04 or Ubuntu 20.04 - https://setup-php.com/i/452'
|
|
||||||
);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const version: string = await utils.parseVersion(
|
const version: string = await utils.parseVersion(
|
||||||
await utils.getInput('php-version', true)
|
await utils.getInput('php-version', true)
|
||||||
);
|
);
|
||||||
if (version) {
|
|
||||||
const os_version: string = process.platform;
|
const os_version: string = process.platform;
|
||||||
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(await utils.joins(tool, location, version, __dirname));
|
await exec(await utils.joins(tool, location, version, __dirname));
|
||||||
} else {
|
|
||||||
core.setFailed('Unable to get the PHP version');
|
|
||||||
}
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message);
|
core.setFailed(error.message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// call the run function
|
// call the run function
|
||||||
(async () => {
|
run();
|
||||||
await run();
|
|
||||||
})().catch(error => {
|
|
||||||
core.setFailed(error.message);
|
|
||||||
});
|
|
||||||
|
@ -2,18 +2,14 @@
|
|||||||
export tick="✓"
|
export tick="✓"
|
||||||
export cross="✗"
|
export cross="✗"
|
||||||
export curl_opts=(-sL)
|
export curl_opts=(-sL)
|
||||||
|
export nightly_versions="8.[0-1]"
|
||||||
export old_versions="5.[3-5]"
|
export old_versions="5.[3-5]"
|
||||||
export jit_versions="8.[0-9]"
|
|
||||||
export nightly_versions="8.[1-9]"
|
|
||||||
export xdebug3_versions="7.[2-4]|8.[0-9]"
|
|
||||||
export tool_path_dir="/usr/local/bin"
|
export tool_path_dir="/usr/local/bin"
|
||||||
export composer_home="$HOME/.composer"
|
export composer_bin="$HOME/.composer/vendor/bin"
|
||||||
export composer_bin="$composer_home/vendor/bin"
|
export composer_json="$HOME/.composer/composer.json"
|
||||||
export composer_json="$composer_home/composer.json"
|
|
||||||
export composer_lock="$composer_home/composer.lock"
|
|
||||||
export latest="releases/latest/download"
|
export latest="releases/latest/download"
|
||||||
export github="https://github.com/shivammathur"
|
export github="https://github.com/shivammathur"
|
||||||
export jsdeliver="https://cdn.jsdelivr.net/gh/shivammathur"
|
export bintray="https://dl.bintray/shivammathur"
|
||||||
|
|
||||||
# Function to log start of a operation.
|
# Function to log start of a operation.
|
||||||
step_log() {
|
step_log() {
|
||||||
@ -30,15 +26,18 @@ add_log() {
|
|||||||
printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message"
|
printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message"
|
||||||
else
|
else
|
||||||
printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message"
|
printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message"
|
||||||
[ "$fail_fast" = "true" ] && exit 1
|
[ "$fail_fast" = "true" ] && exit 1;
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to log result of installing extension.
|
# Function to log result of installing extension.
|
||||||
add_extension_log() {
|
add_extension_log() {
|
||||||
|
extension=$1
|
||||||
|
status=$2
|
||||||
|
extension_name=$(echo "$extension" | cut -d '-' -f 1)
|
||||||
(
|
(
|
||||||
check_extension "$(echo "$1" | cut -d '-' -f 1)" && add_log "$tick" "$1" "$2"
|
check_extension "$extension_name" && add_log "$tick" "$extension_name" "$status"
|
||||||
) || add_log "$cross" "$1" "Could not install $1 on PHP ${semver:?}"
|
) || add_log "$cross" "$extension_name" "Could not install $extension on PHP ${semver:?}"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to read env inputs.
|
# Function to read env inputs.
|
||||||
@ -71,12 +70,12 @@ get() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to download and run scripts from GitHub releases with jsdeliver fallback.
|
# Function to download and run scripts from GitHub releases with bintray fallback.
|
||||||
run_script() {
|
run_script() {
|
||||||
repo=$1
|
repo=$1
|
||||||
shift
|
shift
|
||||||
args=("$@")
|
args=("$@")
|
||||||
get -q -e /tmp/install.sh "$github/$repo/$latest/install.sh" "$jsdeliver/$1@main/scripts/install.sh"
|
get -q -e /tmp/install.sh "$github/$repo/$latest/install.sh" "$bintray/php/$repo.sh"
|
||||||
bash /tmp/install.sh "${args[@]}"
|
bash /tmp/install.sh "${args[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -102,51 +101,21 @@ check_extension() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to enable cached extensions.
|
|
||||||
enable_cache_extension() {
|
|
||||||
deps=()
|
|
||||||
for ext in /tmp/extcache/"$1"/*; do
|
|
||||||
deps+=("$(basename "$ext")")
|
|
||||||
done
|
|
||||||
if [ "x${deps[*]}" = "x" ]; then
|
|
||||||
sudo rm -rf /tmp/extcache/"$1"
|
|
||||||
enable_extension "$1" "$2"
|
|
||||||
else
|
|
||||||
deps+=("$1")
|
|
||||||
if php "${deps[@]/#/-d ${2}=}" -m 2>/dev/null | grep -i -q "$1"; then
|
|
||||||
for ext in "${deps[@]}"; do
|
|
||||||
sudo rm -rf /tmp/extcache/"$ext"
|
|
||||||
enable_extension "$ext" "$2"
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to enable existing extensions.
|
# Function to enable existing extensions.
|
||||||
enable_extension() {
|
enable_extension() {
|
||||||
modules_dir="/var/lib/php/modules/$version"
|
if [ -e /tmp/setup_php_dismod ] && grep -q "$1" /tmp/setup_php_dismod; then
|
||||||
[ -d "$modules_dir" ] && sudo find "$modules_dir" -path "*disabled*$1" -delete
|
sudo phpenmod -v "$version" "$1" >/dev/null 2>&1
|
||||||
if [ -d /tmp/extcache/"$1" ]; then
|
fi
|
||||||
enable_cache_extension "$1" "$2"
|
if ! check_extension "$1" && [ -e "${ext_dir:?}/$1.so" ]; then
|
||||||
elif ! check_extension "$1" && [ -e "${ext_dir:?}/$1.so" ]; then
|
echo "$2=${ext_dir:?}/$1.so" >>"${pecl_file:-$ini_file}"
|
||||||
echo "$2=${ext_dir:?}/$1.so" | sudo tee -a "${pecl_file:-${ini_file[@]}}" >/dev/null
|
|
||||||
fi
|
fi
|
||||||
}
|
|
||||||
|
|
||||||
# Function to configure PHP
|
|
||||||
configure_php() {
|
|
||||||
(
|
|
||||||
echo -e "date.timezone=UTC\nmemory_limit=-1"
|
|
||||||
[[ "$version" =~ $jit_versions ]] && echo -e "opcache.enable=1\nopcache.jit_buffer_size=256M\nopcache.jit=1235"
|
|
||||||
[[ "$version" =~ $xdebug3_versions ]] && echo -e "xdebug.mode=coverage"
|
|
||||||
) | sudo tee -a "${pecl_file:-${ini_file[@]}}" >/dev/null
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to configure PECL.
|
# Function to configure PECL.
|
||||||
configure_pecl() {
|
configure_pecl() {
|
||||||
if ! [ -e /tmp/pecl_config ]; then
|
if ! [ -e /tmp/pecl_config ] && command -v pecl >/dev/null; then
|
||||||
for script in pear pecl; do
|
for script in pear pecl; do
|
||||||
sudo "$script" config-set php_ini "${pecl_file:-${ini_file[@]}}"
|
sudo "$script" config-set php_ini "${pecl_file:-$ini_file}"
|
||||||
sudo "$script" channel-update "$script".php.net
|
sudo "$script" channel-update "$script".php.net
|
||||||
done
|
done
|
||||||
echo '' | sudo tee /tmp/pecl_config >/dev/null 2>&1
|
echo '' | sudo tee /tmp/pecl_config >/dev/null 2>&1
|
||||||
@ -156,12 +125,12 @@ 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
|
extension=$1
|
||||||
stability="$(echo "$2" | grep -m 1 -Eio "(stable|alpha|beta|rc|snapshot|preview)")"
|
stability="$(echo "$2" | grep -m 1 -Eio "(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)
|
||||||
pecl_version=$(echo "$response" | grep -m 1 -Eio "([0-9]+\.[0-9]+\.[0-9]+${stability}[0-9]+)")
|
pecl_version=$(echo "$response" | grep -m 1 -Pio "(\d*\.\d*\.\d*$stability\d*)")
|
||||||
if [ ! "$pecl_version" ]; then
|
if [ ! "$pecl_version" ]; then
|
||||||
pecl_version=$(echo "$response" | grep -m 1 -Eo "([0-9]+\.[0-9]+\.[0-9]+)")
|
pecl_version=$(echo "$response" | grep -m 1 -Po "(\d*\.\d*\.\d*)")
|
||||||
fi
|
fi
|
||||||
echo "$pecl_version"
|
echo "$pecl_version"
|
||||||
}
|
}
|
||||||
@ -169,30 +138,9 @@ get_pecl_version() {
|
|||||||
# Function to install PECL extensions and accept default options
|
# Function to install PECL extensions and accept default options
|
||||||
pecl_install() {
|
pecl_install() {
|
||||||
local extension=$1
|
local extension=$1
|
||||||
add_pecl >/dev/null 2>&1
|
|
||||||
yes '' 2>/dev/null | sudo pecl install -f "$extension" >/dev/null 2>&1
|
yes '' 2>/dev/null | sudo pecl install -f "$extension" >/dev/null 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to install a specific version of PECL extension.
|
|
||||||
add_pecl_extension() {
|
|
||||||
extension=$1
|
|
||||||
pecl_version=$2
|
|
||||||
prefix=$3
|
|
||||||
enable_extension "$extension" "$prefix"
|
|
||||||
if [[ $pecl_version =~ .*(alpha|beta|rc|snapshot|preview).* ]]; then
|
|
||||||
pecl_version=$(get_pecl_version "$extension" "$pecl_version")
|
|
||||||
fi
|
|
||||||
ext_version=$(php -r "echo phpversion('$extension');")
|
|
||||||
if [ "$ext_version" = "$pecl_version" ]; then
|
|
||||||
add_log "${tick:?}" "$extension" "Enabled"
|
|
||||||
else
|
|
||||||
disable_extension "$extension" >/dev/null 2>&1
|
|
||||||
delete_extension "$extension" >/dev/null 2>&1
|
|
||||||
pecl_install "$extension-$pecl_version"
|
|
||||||
add_extension_log "$extension-$pecl_version" "Installed and enabled"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to setup pre-release extensions using PECL.
|
# Function to setup pre-release extensions using PECL.
|
||||||
add_unstable_extension() {
|
add_unstable_extension() {
|
||||||
extension=$1
|
extension=$1
|
||||||
@ -206,8 +154,7 @@ add_unstable_extension() {
|
|||||||
get_tool_version() {
|
get_tool_version() {
|
||||||
tool=$1
|
tool=$1
|
||||||
param=$2
|
param=$2
|
||||||
alp="[a-zA-Z0-9]"
|
version_regex="[0-9]+((\.{1}[0-9]+)+)(\.{0})(-[a-zA-Z0-9]+){0,1}"
|
||||||
version_regex="[0-9]+((\.{1}$alp+)+)(\.{0})(-$alp+){0,1}"
|
|
||||||
if [ "$tool" = "composer" ]; then
|
if [ "$tool" = "composer" ]; then
|
||||||
if [ "$param" != "snapshot" ]; then
|
if [ "$param" != "snapshot" ]; then
|
||||||
composer_version="$(grep -Ea "const\sVERSION" "$tool_path_dir/composer" | grep -Eo "$version_regex")"
|
composer_version="$(grep -Ea "const\sVERSION" "$tool_path_dir/composer" | grep -Eo "$version_regex")"
|
||||||
@ -229,19 +176,10 @@ configure_composer() {
|
|||||||
add_log "$cross" "composer" "Could not download composer"
|
add_log "$cross" "composer" "Could not download composer"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if ! [ -d "$composer_home" ]; then
|
composer -q global config process-timeout 0
|
||||||
sudo -u "$(id -un)" -g "$(id -gn)" mkdir -p -m=00755 "$composer_home"
|
echo "$composer_bin" >> "$GITHUB_PATH"
|
||||||
else
|
|
||||||
sudo chown -R "$(id -un)":"$(id -gn)" "$composer_home"
|
|
||||||
fi
|
|
||||||
if ! [ -e "$composer_json" ]; then
|
|
||||||
echo '{}' | tee "$composer_json" >/dev/null
|
|
||||||
chmod 644 "$composer_json"
|
|
||||||
fi
|
|
||||||
composer -q config -g process-timeout 0
|
|
||||||
echo "$composer_bin" >>"$GITHUB_PATH"
|
|
||||||
if [ -n "$COMPOSER_TOKEN" ]; then
|
if [ -n "$COMPOSER_TOKEN" ]; then
|
||||||
composer -q config -g github-oauth.github.com "$COMPOSER_TOKEN"
|
composer -q global config github-oauth.github.com "$COMPOSER_TOKEN"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -251,21 +189,31 @@ add_tool() {
|
|||||||
tool=$2
|
tool=$2
|
||||||
ver_param=$3
|
ver_param=$3
|
||||||
tool_path="$tool_path_dir/$tool"
|
tool_path="$tool_path_dir/$tool"
|
||||||
if ! [[ "$PATH" =~ $tool_path_dir ]]; then
|
|
||||||
export PATH=$PATH:"$tool_path_dir"
|
|
||||||
echo "export PATH=\$PATH:$tool_path_dir" | sudo tee -a "$GITHUB_ENV" >/dev/null
|
|
||||||
fi
|
|
||||||
if [ ! -e "$tool_path" ]; then
|
if [ ! -e "$tool_path" ]; then
|
||||||
rm -rf "$tool_path"
|
rm -rf "$tool_path"
|
||||||
fi
|
fi
|
||||||
IFS="," read -r -a url <<<"$url"
|
IFS="," read -r -a url <<< "$url"
|
||||||
status_code=$(get -v -e "$tool_path" "${url[@]}")
|
status_code=$(get -v -e "$tool_path" "${url[@]}")
|
||||||
if [ "$status_code" != "200" ] && [[ "${url[0]}" =~ .*github.com.*releases.*latest.* ]]; then
|
if [ "$status_code" != "200" ] && [[ "${url[0]}" =~ .*github.com.*releases.*latest.* ]]; then
|
||||||
url[0]="${url[0]//releases\/latest\/download/releases/download/$(get -s -n "" "$(echo "${url[0]}" | cut -d '/' -f '1-5')/releases" | grep -Eo -m 1 "([0-9]+\.[0-9]+\.[0-9]+)/$(echo "${url[0]}" | sed -e "s/.*\///")" | cut -d '/' -f 1)}"
|
url[0]="${url[0]//releases\/latest\/download/releases/download/$(get -s -n "" "$(echo "${url[0]}" | cut -d '/' -f '1-5')/releases" | grep -Eo -m 1 "([0-9]+\.[0-9]+\.[0-9]+)/$(echo "${url[0]}" | sed -e "s/.*\///")" | cut -d '/' -f 1)}"
|
||||||
status_code=$(get -v -e "$tool_path" "${url[0]}")
|
status_code=$(get -v -e "$tool_path" "${url[0]}")
|
||||||
fi
|
fi
|
||||||
if [ "$status_code" = "200" ]; then
|
if [ "$status_code" = "200" ]; then
|
||||||
add_tools_helper "$tool"
|
if [ "$tool" = "composer" ]; then
|
||||||
|
configure_composer "$tool_path"
|
||||||
|
elif [ "$tool" = "cs2pr" ]; then
|
||||||
|
sudo sed -i 's/\r$//; s/exit(9)/exit(0)/' "$tool_path" 2>/dev/null ||
|
||||||
|
sudo sed -i '' 's/\r$//; s/exit(9)/exit(0)/' "$tool_path"
|
||||||
|
elif [ "$tool" = "phan" ]; then
|
||||||
|
add_extension fileinfo extension >/dev/null 2>&1
|
||||||
|
add_extension ast extension >/dev/null 2>&1
|
||||||
|
elif [ "$tool" = "phive" ]; then
|
||||||
|
add_extension curl extension >/dev/null 2>&1
|
||||||
|
add_extension mbstring extension >/dev/null 2>&1
|
||||||
|
add_extension xml extension >/dev/null 2>&1
|
||||||
|
elif [ "$tool" = "wp-cli" ]; then
|
||||||
|
sudo cp -p "$tool_path" "$tool_path_dir"/wp
|
||||||
|
fi
|
||||||
tool_version=$(get_tool_version "$tool" "$ver_param")
|
tool_version=$(get_tool_version "$tool" "$ver_param")
|
||||||
add_log "$tick" "$tool" "Added $tool $tool_version"
|
add_log "$tick" "$tool" "Added $tool $tool_version"
|
||||||
else
|
else
|
||||||
@ -287,13 +235,11 @@ add_composertool() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
(
|
(
|
||||||
sudo rm -f "$composer_lock" >/dev/null 2>&1 || true
|
composer global require "$prefix$release" >/dev/null 2>&1 &&
|
||||||
composer global require "$prefix$release" 2>&1 | tee /tmp/composer.log >/dev/null 2>&1
|
json=$(grep "$prefix$tool" "$composer_json") &&
|
||||||
log=$(grep "$prefix$tool" /tmp/composer.log) &&
|
tool_version=$(get_tool_version 'echo' "$json") &&
|
||||||
tool_version=$(get_tool_version 'echo' "$log") &&
|
|
||||||
add_log "$tick" "$tool" "Added $tool $tool_version"
|
add_log "$tick" "$tool" "Added $tool $tool_version"
|
||||||
) || add_log "$cross" "$tool" "Could not setup $tool"
|
) || add_log "$cross" "$tool" "Could not setup $tool"
|
||||||
add_tools_helper "$tool"
|
|
||||||
if [ -e "$composer_bin/composer" ]; then
|
if [ -e "$composer_bin/composer" ]; then
|
||||||
sudo cp -p "$tool_path_dir/composer" "$composer_bin"
|
sudo cp -p "$tool_path_dir/composer" "$composer_bin"
|
||||||
fi
|
fi
|
||||||
@ -301,14 +247,5 @@ 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"$version" -v | grep -Eo -m 1 "[0-9]+\.[0-9]+\.[0-9]+" | head -n 1
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get the tag for a php version.
|
|
||||||
php_src_tag() {
|
|
||||||
php_src_tag='master'
|
|
||||||
if ! [[ ${version:?} =~ $nightly_versions ]]; then
|
|
||||||
php_src_tag="php-$semver"
|
|
||||||
fi
|
|
||||||
echo "$php_src_tag"
|
|
||||||
}
|
}
|
@ -7,24 +7,12 @@ self_hosted_helper() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to delete extension.
|
|
||||||
delete_extension() {
|
|
||||||
extension=$1
|
|
||||||
sudo rm -rf "${scan_dir:?}"/*"$extension"* "${ext_dir:?}"/"$extension".so >/dev/null 2>&1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to disable extension.
|
|
||||||
disable_extension() {
|
|
||||||
extension=$1
|
|
||||||
sudo sed -Ei '' "/=(.*\/)?\"?$extension(.so)?$/d" "${ini_file:?}"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to remove extensions.
|
# Function to remove extensions.
|
||||||
remove_extension() {
|
remove_extension() {
|
||||||
extension=$1
|
extension=$1
|
||||||
if check_extension "$extension"; then
|
if check_extension "$extension"; then
|
||||||
disable_extension "$extension"
|
sudo sed -i '' "/$extension/d" "${ini_file:?}"
|
||||||
delete_extension "$extension"
|
sudo rm -rf "${scan_dir:?}"/*"$extension"* "${ext_dir:?}"/"$extension".so >/dev/null 2>&1
|
||||||
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Removed") ||
|
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Removed") ||
|
||||||
add_log "${cross:?}" ":$extension" "Could not remove $extension on PHP ${semver:?}"
|
add_log "${cross:?}" ":$extension" "Could not remove $extension on PHP ${semver:?}"
|
||||||
else
|
else
|
||||||
@ -32,53 +20,43 @@ remove_extension() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to fetch a brew tap.
|
# Function to install a specific version of PECL extension.
|
||||||
fetch_brew_tap() {
|
add_pecl_extension() {
|
||||||
tap=$1
|
extension=$1
|
||||||
tap_user=$(dirname "$tap")
|
pecl_version=$2
|
||||||
tap_name=$(basename "$tap")
|
prefix=$3
|
||||||
mkdir -p "$tap_dir/$tap_user"
|
enable_extension "$extension" "$prefix"
|
||||||
get -s -n "" "https://github.com/$tap/archive/master.tar.gz" | sudo tar -xzf - -C "$tap_dir/$tap_user"
|
if [[ $pecl_version =~ .*(alpha|beta|rc|snapshot|preview).* ]]; then
|
||||||
if [ -d "$tap_dir/$tap_user/$tap_name-master" ]; then
|
pecl_version=$(get_pecl_version "$extension" "$pecl_version")
|
||||||
sudo mv "$tap_dir/$tap_user/$tap_name-master" "$tap_dir/$tap_user/$tap_name"
|
|
||||||
fi
|
fi
|
||||||
}
|
ext_version=$(php -r "echo phpversion('$extension');")
|
||||||
|
if [ "$ext_version" = "$pecl_version" ]; then
|
||||||
# Function to add a brew tap.
|
add_log "${tick:?}" "$extension" "Enabled"
|
||||||
add_brew_tap() {
|
|
||||||
tap=$1
|
|
||||||
if ! [ -d "$tap_dir/$tap" ]; then
|
|
||||||
if [ "${runner:?}" = "self-hosted" ]; then
|
|
||||||
brew tap "$tap" >/dev/null 2>&1
|
|
||||||
else
|
else
|
||||||
fetch_brew_tap "$tap" >/dev/null 2>&1
|
remove_extension "$extension" >/dev/null 2>&1
|
||||||
if ! [ -d "$tap_dir/$tap" ]; then
|
pecl_install "$extension-$pecl_version"
|
||||||
brew tap "$tap" >/dev/null 2>&1
|
add_extension_log "$extension-$pecl_version" "Installed and enabled"
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to install a php extension from shivammathur/extensions tap.
|
# Function to install a php extension from shivammathur/extensions tap.
|
||||||
add_brew_extension() {
|
add_brew_extension() {
|
||||||
formula=$1
|
extension=$1
|
||||||
prefix=$2
|
prefix=$2
|
||||||
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
|
if ! brew tap | grep -q shivammathur/extensions; then
|
||||||
add_brew_tap shivammathur/homebrew-extensions
|
brew tap --shallow shivammathur/extensions >/dev/null 2>&1
|
||||||
sudo mv "$tap_dir"/shivammathur/homebrew-extensions/.github/deps/"$formula"/* "$tap_dir/homebrew/homebrew-core/Formula/" 2>/dev/null || true
|
fi
|
||||||
update_dependencies >/dev/null 2>&1
|
brew install "$extension@$version" >/dev/null 2>&1
|
||||||
brew install -f "$formula@$version" >/dev/null 2>&1
|
sudo cp "$(brew --prefix)/opt/$extension@$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"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to setup extensions.
|
# Function to setup extensions
|
||||||
add_extension() {
|
add_extension() {
|
||||||
extension=$1
|
extension=$1
|
||||||
prefix=$2
|
prefix=$2
|
||||||
@ -86,12 +64,9 @@ add_extension() {
|
|||||||
if check_extension "$extension"; then
|
if check_extension "$extension"; then
|
||||||
add_log "${tick:?}" "$extension" "Enabled"
|
add_log "${tick:?}" "$extension" "Enabled"
|
||||||
else
|
else
|
||||||
if [[ "$version" =~ ${old_versions:?} ]] && [ "$extension" = "imagick" ]; then
|
[[ "$version" =~ 5.[4-5] ]] && [ "$extension" = "imagick" ] && brew install pkg-config imagemagick >/dev/null 2>&1
|
||||||
run_script "php5-darwin" "${version/./}" "$extension" >/dev/null 2>&1
|
|
||||||
else
|
|
||||||
pecl_install "$extension" >/dev/null 2>&1 &&
|
pecl_install "$extension" >/dev/null 2>&1 &&
|
||||||
if [[ "$version" =~ ${old_versions:?} ]]; then echo "$prefix=$ext_dir/$extension.so" >>"$ini_file"; fi
|
if [[ "$version" =~ ${old_versions:?} ]]; then echo "$prefix=$ext_dir/$extension.so" >>"$ini_file"; fi
|
||||||
fi
|
|
||||||
add_extension_log "$extension" "Installed and enabled"
|
add_extension_log "$extension" "Installed and enabled"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -104,146 +79,73 @@ 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
|
|
||||||
pecl_version=$(get_tool_version "pecl" "version")
|
pecl_version=$(get_tool_version "pecl" "version")
|
||||||
add_log "${tick:?}" "PECL" "Found PECL $pecl_version"
|
add_log "${tick:?}" "PECL" "Found PECL $pecl_version"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to link all libraries of a formula.
|
|
||||||
link_libraries() {
|
|
||||||
formula=$1
|
|
||||||
formula_prefix="$(brew --prefix "$formula")"
|
|
||||||
sudo mkdir -p "$formula_prefix"/lib
|
|
||||||
for lib in "$formula_prefix"/lib/*.dylib; do
|
|
||||||
lib_name=$(basename "$lib")
|
|
||||||
sudo cp -a "$lib" "$brew_prefix/lib/$lib_name" 2>/dev/null || true
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
# Patch brew to overwrite packages.
|
|
||||||
patch_brew() {
|
|
||||||
formula_installer="$brew_repo"/Library/Homebrew/formula_installer.rb
|
|
||||||
code=" keg.link(verbose: verbose?"
|
|
||||||
sudo sed -i '' "s/$code)/$code, overwrite: true)/" "$formula_installer"
|
|
||||||
# shellcheck disable=SC2064
|
|
||||||
trap "sudo sed -i '' 's/$code, overwrite: true)/$code)/' $formula_installer" exit
|
|
||||||
}
|
|
||||||
|
|
||||||
# Helper function to update the dependencies.
|
|
||||||
update_dependencies_helper() {
|
|
||||||
dependency=$1
|
|
||||||
get -q -n "$tap_dir/homebrew/homebrew-core/Formula/$dependency.rb" "https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/$dependency.rb"
|
|
||||||
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 [[ "$version" =~ ${nightly_versions:?} ]] && [ "${runner:?}" != "self-hosted" ]; then
|
||||||
patch_brew
|
tap_dir="$(brew --prefix)/Homebrew/Library/Taps"
|
||||||
while read -r dependency; do
|
while read -r formula; do
|
||||||
update_dependencies_helper "$dependency" &
|
get -q -n "$tap_dir/homebrew/homebrew-core/Formula/$formula.rb" "https://raw.githubusercontent.com/Homebrew/homebrew-core/master/Formula/$formula.rb" &
|
||||||
to_wait+=($!)
|
to_wait+=($!)
|
||||||
done <"$tap_dir/shivammathur/homebrew-php/.github/deps/${ImageOS:?}_${ImageVersion:?}"
|
done <"$tap_dir/shivammathur/homebrew-php/.github/deps/${ImageOS:?}_${ImageVersion:?}"
|
||||||
wait "${to_wait[@]}"
|
wait "${to_wait[@]}"
|
||||||
echo '' | sudo tee /tmp/update_dependencies >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to fix dependencies on install PHP version.
|
|
||||||
fix_dependencies() {
|
|
||||||
broken_deps_paths=$(php -v 2>&1 | grep -Eo '/opt/[a-zA-Z0-9@\.]+')
|
|
||||||
if [ "x$broken_deps_paths" != "x" ]; then
|
|
||||||
update_dependencies
|
|
||||||
IFS=" " read -r -a formulae <<< "$(echo "$broken_deps_paths" | tr '\n' ' ' | sed 's|/opt/||g' 2>&1)$php_formula"
|
|
||||||
brew reinstall "${formulae[@]}"
|
|
||||||
brew link --force --overwrite "$php_formula" || true
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get PHP version if it is already installed using Homebrew.
|
|
||||||
get_brewed_php() {
|
|
||||||
php_cellar="$brew_prefix"/Cellar/php
|
|
||||||
if [ -d "$php_cellar" ] && ! [[ "$(find "$php_cellar" -maxdepth 1 -name "$version*" | wc -l 2>/dev/null)" -eq 0 ]]; then
|
|
||||||
php-config --version 2>/dev/null | cut -c 1-3
|
|
||||||
else
|
|
||||||
echo 'false';
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to setup PHP 5.6 and newer using Homebrew.
|
# Function to setup PHP 5.6 and newer using Homebrew.
|
||||||
add_php() {
|
add_php() {
|
||||||
action=$1
|
action=$1
|
||||||
existing_version=$2
|
if ! brew tap | grep -q shivammathur/php; then
|
||||||
add_brew_tap shivammathur/homebrew-php
|
brew tap --shallow shivammathur/php
|
||||||
|
fi
|
||||||
update_dependencies
|
update_dependencies
|
||||||
if [ "$existing_version" != "false" ]; then
|
if ! [[ "$(find "$(brew --cellar)"/php/ -maxdepth 1 -name "$version*" | wc -l 2>/dev/null)" -eq 0 ]] && [ "$action" != "upgrade" ]; then
|
||||||
([ "$action" = "upgrade" ] && brew upgrade -f "$php_formula") || brew unlink "$php_formula"
|
brew unlink shivammathur/php/php@"$version"
|
||||||
else
|
else
|
||||||
brew install -f "$php_formula"
|
brew upgrade "shivammathur/php/php@$version" 2>/dev/null || brew install "shivammathur/php/php@$version"
|
||||||
fi
|
fi
|
||||||
brew link --force --overwrite "$php_formula"
|
brew link --force --overwrite php@"$version"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to get extra version.
|
# Function to Setup PHP
|
||||||
php_extra_version() {
|
|
||||||
if [[ ${version:?} =~ ${nightly_versions:?} ]]; then
|
|
||||||
echo " ($(brew cat "$php_formula" | grep -Eo "commit=[0-9a-zA-Z]+" | cut -d'=' -f 2))"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to Setup PHP.
|
|
||||||
setup_php() {
|
setup_php() {
|
||||||
step_log "Setup PHP"
|
step_log "Setup PHP"
|
||||||
existing_version=$(get_brewed_php)
|
existing_version=$(php-config --version 2>/dev/null | cut -c 1-3)
|
||||||
if [[ "$version" =~ ${old_versions:?} ]]; then
|
if [[ "$version" =~ ${old_versions:?} ]]; then
|
||||||
run_script "php5-darwin" "${version/./}" >/dev/null 2>&1
|
run_script "php5-darwin" "${version/./}" >/dev/null 2>&1
|
||||||
status="Installed"
|
status="Installed"
|
||||||
elif [ "$existing_version" != "$version" ]; then
|
elif [ "$existing_version" != "$version" ]; then
|
||||||
add_php "install" "$existing_version" >/dev/null 2>&1
|
add_php "install" >/dev/null 2>&1
|
||||||
status="Installed"
|
status="Installed"
|
||||||
elif [ "$existing_version" = "$version" ] && [ "${update:?}" = "true" ]; then
|
elif [ "$existing_version" = "$version" ] && [ "${update:?}" = "true" ]; then
|
||||||
add_php "upgrade" "$existing_version" >/dev/null 2>&1
|
add_php "upgrade" >/dev/null 2>&1
|
||||||
status="Updated to"
|
status="Updated to"
|
||||||
else
|
else
|
||||||
status="Found"
|
status="Found"
|
||||||
fix_dependencies >/dev/null 2>&1
|
|
||||||
fi
|
fi
|
||||||
ini_file=$(php -d "date.timezone=UTC" --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g")
|
ini_file=$(php -d "date.timezone=UTC" --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g")
|
||||||
sudo chmod 777 "$ini_file" "${tool_path_dir:?}"
|
sudo chmod 777 "$ini_file" "${tool_path_dir:?}"
|
||||||
configure_php
|
echo -e "date.timezone=UTC\nmemory_limit=-1" >>"$ini_file"
|
||||||
ext_dir=$(php -i | grep -Ei "extension_dir => /" | sed -e "s|.*=> s*||")
|
ext_dir=$(php -i | grep -Ei "extension_dir => /" | sed -e "s|.*=> s*||")
|
||||||
scan_dir=$(php --ini | grep additional | sed -e "s|.*: s*||")
|
scan_dir=$(php --ini | grep additional | sed -e "s|.*: s*||")
|
||||||
sudo mkdir -m 777 -p "$ext_dir" "$HOME/.composer"
|
sudo mkdir -m 777 -p "$ext_dir" "$HOME/.composer"
|
||||||
semver=$(php_semver)
|
semver=$(php -v | head -n 1 | cut -f 2 -d ' ')
|
||||||
extra_version=$(php_extra_version)
|
if [[ ! "$version" =~ $old_versions ]]; then configure_pecl >/dev/null 2>&1; fi
|
||||||
if [ "${semver%.*}" != "$version" ]; then
|
|
||||||
add_log "$cross" "PHP" "Could not setup PHP $version"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
sudo cp "$dist"/../src/configs/*.json "$RUNNER_TOOL_CACHE/"
|
sudo cp "$dist"/../src/configs/*.json "$RUNNER_TOOL_CACHE/"
|
||||||
echo "::set-output name=php-version::$semver"
|
add_log "$tick" "PHP" "$status PHP $semver"
|
||||||
add_log "$tick" "PHP" "$status PHP $semver$extra_version"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
version=$1
|
version=$1
|
||||||
dist=$2
|
dist=$2
|
||||||
php_formula=shivammathur/php/php@"$version"
|
|
||||||
brew_prefix="$(brew --prefix)"
|
|
||||||
brew_repo="$(brew --repository)"
|
|
||||||
tap_dir="$brew_repo"/Library/Taps
|
|
||||||
scripts="${dist}"/../src/scripts
|
|
||||||
export HOMEBREW_CHANGE_ARCH_TO_ARM=1
|
|
||||||
export HOMEBREW_DEVELOPER=1
|
|
||||||
export HOMEBREW_NO_INSTALL_CLEANUP=1
|
export HOMEBREW_NO_INSTALL_CLEANUP=1
|
||||||
export HOMEBREW_NO_AUTO_UPDATE=1
|
export HOMEBREW_NO_AUTO_UPDATE=1
|
||||||
export HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK=1
|
|
||||||
|
|
||||||
# shellcheck source=.
|
# shellcheck source=.
|
||||||
. "${scripts:?}"/ext/source.sh
|
. "${dist}"/../src/scripts/common.sh
|
||||||
. "${scripts:?}"/tools/add_tools.sh
|
|
||||||
. "${scripts:?}"/common.sh
|
|
||||||
read_env
|
read_env
|
||||||
self_hosted_setup
|
self_hosted_setup
|
||||||
setup_php
|
setup_php
|
||||||
|
@ -10,12 +10,8 @@ Function Add-Blackfire() {
|
|||||||
$no_dot_version = $version.replace('.', '')
|
$no_dot_version = $version.replace('.', '')
|
||||||
$extension_version = $extension.split('-')[1]
|
$extension_version = $extension.split('-')[1]
|
||||||
if ($extension_version -notmatch "\S") {
|
if ($extension_version -notmatch "\S") {
|
||||||
if($version -lt '7.0') {
|
|
||||||
$extension_version = '1.50.0'
|
|
||||||
} else {
|
|
||||||
$extension_version = (Invoke-RestMethod https://blackfire.io/api/v1/releases).probe.php
|
$extension_version = (Invoke-RestMethod https://blackfire.io/api/v1/releases).probe.php
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (Test-Path $ext_dir\blackfire.dll) {
|
if (Test-Path $ext_dir\blackfire.dll) {
|
||||||
Enable-PhpExtension -Extension blackfire -Path $php_dir
|
Enable-PhpExtension -Extension blackfire -Path $php_dir
|
||||||
$status="Enabled"
|
$status="Enabled"
|
||||||
|
@ -5,15 +5,11 @@ add_blackfire() {
|
|||||||
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[@]}}"
|
blackfire_ini_file="${scan_dir:?}/50-blackfire.ini"
|
||||||
if [ ! -e "${ext_dir:?}/blackfire.so" ]; then
|
if [ ! -e "${ext_dir:?}/blackfire.so" ]; then
|
||||||
if [ "$extension_version" = "blackfire" ]; then
|
if [ "$extension_version" = "blackfire" ]; then
|
||||||
if [[ ${version:?} =~ 5.[3-6] ]]; then
|
|
||||||
extension_version='1.50.0'
|
|
||||||
else
|
|
||||||
extension_version=$(get -s -n "" https://blackfire.io/api/v1/releases | grep -Eo 'php":"([0-9]+.[0-9]+.[0-9]+)' | cut -d '"' -f 3)
|
extension_version=$(get -s -n "" https://blackfire.io/api/v1/releases | grep -Eo 'php":"([0-9]+.[0-9]+.[0-9]+)' | cut -d '"' -f 3)
|
||||||
fi
|
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
|
echo "extension=blackfire.so" | sudo tee -a "$blackfire_ini_file" >/dev/null 2>&1
|
||||||
|
@ -1,19 +1,20 @@
|
|||||||
# Function to install libraries required by couchbase
|
# Function to install libraries required by couchbase
|
||||||
add_couchbase_libs() {
|
add_couchbase_libs() {
|
||||||
if [ "$(uname -s)" = "Linux" ]; then
|
if [ "$(uname -s)" = "Linux" ]; then
|
||||||
trunk="https://github.com/couchbase/libcouchbase/releases"
|
if [[ ${version:?} =~ 5.6|7.[0-1] ]]; then
|
||||||
if [[ ${version:?} =~ 5.[3-6]|7.[0-1] ]]; then
|
trunk="http://packages.couchbase.com/ubuntu"
|
||||||
release="2.10.9"
|
list="deb $trunk ${DISTRIB_CODENAME:?} ${DISTRIB_CODENAME:?}/main"
|
||||||
else
|
else
|
||||||
release="$(curl -sL $trunk/latest | grep -Eo "libcouchbase-[0-9]+\.[0-9]+\.[0-9]+" | head -n 1 | cut -d'-' -f 2)"
|
trunk="http://packages.couchbase.com/clients/c/repos/deb"
|
||||||
|
list="deb $trunk/ubuntu${DISTRIB_RELEASE/./} ${DISTRIB_CODENAME:?} ${DISTRIB_CODENAME:?}/main"
|
||||||
fi
|
fi
|
||||||
deb_url="$trunk/download/$release/libcouchbase-${release}_ubuntu${VERSION_ID/./}_${VERSION_CODENAME}_amd64.tar"
|
add_pecl
|
||||||
get -q -n /tmp/libcouchbase.tar "$deb_url"
|
get -s -n "" "$trunk/couchbase.key" | sudo apt-key add
|
||||||
sudo tar -xf /tmp/libcouchbase.tar -C /tmp
|
echo "$list" | sudo tee /etc/apt/sources.list.d/couchbase.list
|
||||||
install_packages libev4 libevent-dev
|
sudo apt-get update
|
||||||
sudo dpkg -i /tmp/libcouchbase-*/*.deb
|
${apt_install:?} libcouchbase-dev
|
||||||
else
|
else
|
||||||
if [[ ${version:?} =~ 5.[3-6]|7.[0-1] ]]; then
|
if [[ ${version:?} =~ 5.6|7.[0-1] ]]; then
|
||||||
brew install libcouchbase@2
|
brew install libcouchbase@2
|
||||||
brew link --overwrite --force libcouchbase@2
|
brew link --overwrite --force libcouchbase@2
|
||||||
else
|
else
|
||||||
@ -29,12 +30,8 @@ add_couchbase() {
|
|||||||
if check_extension "couchbase"; then
|
if check_extension "couchbase"; then
|
||||||
add_log "${tick:?}" "couchbase" "Enabled"
|
add_log "${tick:?}" "couchbase" "Enabled"
|
||||||
else
|
else
|
||||||
if [[ "${version:?}" =~ ${old_versions:?} ]]; then
|
if [[ ${version:?} =~ 5.6|7.[0-1] ]]; then
|
||||||
pecl_install couchbase-2.2.3 >/dev/null 2>&1
|
|
||||||
elif [[ "${version:?}" =~ 5.6|7.[0-1] ]]; then
|
|
||||||
pecl_install couchbase-2.6.2 >/dev/null 2>&1
|
pecl_install couchbase-2.6.2 >/dev/null 2>&1
|
||||||
elif [[ "${version:?}" =~ 7.2 ]]; then
|
|
||||||
pecl_install couchbase-3.0.4 >/dev/null 2>&1
|
|
||||||
else
|
else
|
||||||
pecl_install couchbase >/dev/null 2>&1
|
pecl_install couchbase >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
|
@ -7,15 +7,6 @@ add_license_log() {
|
|||||||
echo "::endgroup::"
|
echo "::endgroup::"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to setup gcc-7 and g++-7
|
|
||||||
setup_compiler() {
|
|
||||||
if ! command -v gcc-7 >/dev/null || ! command -v g++-7 >/dev/null; then
|
|
||||||
add_ppa ubuntu-toolchain-r/test
|
|
||||||
add_packages gcc-7 g++-7 -y
|
|
||||||
fi
|
|
||||||
printf "gcc g++" | xargs -d ' ' -I {} sudo update-alternatives --install /usr/bin/{} {} /usr/bin/{}-7 7
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to set cubrid repo for the extension.
|
# Function to set cubrid repo for the extension.
|
||||||
set_cubrid_repo() {
|
set_cubrid_repo() {
|
||||||
case "${ext:?}" in
|
case "${ext:?}" in
|
||||||
@ -33,17 +24,19 @@ set_cubrid_branch() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
add_cubrid_helper() {
|
add_cubrid_helper() {
|
||||||
ext=$1
|
if ! [ -e "${ext_dir:?}/$ext.so" ]; then
|
||||||
enable_extension "$ext" extension
|
|
||||||
if ! check_extension "$ext"; then
|
|
||||||
status='Installed and enabled'
|
status='Installed and enabled'
|
||||||
set_cubrid_repo
|
set_cubrid_repo
|
||||||
set_cubrid_branch
|
set_cubrid_branch
|
||||||
patch_phpize
|
(
|
||||||
read -r "${ext}_PREFIX_CONFIGURE_OPTS" <<< "CFLAGS=-Wno-implicit-function-declaration"
|
git clone -b "$cubrid_branch" --recursive "https://github.com/CUBRID/$cubrid_repo" "/tmp/$cubrid_repo"
|
||||||
read -r "${ext}_CONFIGURE_OPTS" <<< "--with-php-config=$(command -v php-config)"
|
cd "/tmp/$cubrid_repo" || exit
|
||||||
add_extension_from_source "$ext" https://github.com CUBRID "$cubrid_repo" "$cubrid_branch" extension
|
! [[ "$version" =~ ${old_versions:?} ]] && add_devtools
|
||||||
restore_phpize
|
phpize && ./configure --with-php-config="$(command -v php-config)" --with-"${ext/_/-}"=shared
|
||||||
|
make -j"$(nproc)"
|
||||||
|
sudo make install
|
||||||
|
)
|
||||||
|
echo "extension=$ext.so" | sudo tee "${scan_dir:?}/$ext.ini"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,10 +44,7 @@ add_cubrid_helper() {
|
|||||||
add_cubrid() {
|
add_cubrid() {
|
||||||
ext=$1
|
ext=$1
|
||||||
status='Enabled'
|
status='Enabled'
|
||||||
add_cubrid_helper "$ext" >/dev/null 2>&1
|
add_cubrid_helper >/dev/null 2>&1
|
||||||
add_extension_log "$ext" "$status"
|
add_extension_log "$ext" "$status"
|
||||||
check_extension "$ext" && add_license_log
|
check_extension "$ext" && add_license_log
|
||||||
}
|
}
|
||||||
|
|
||||||
# shellcheck source=.
|
|
||||||
. "${scripts:?}"/ext/patches/phpize.sh
|
|
||||||
|
@ -1,20 +0,0 @@
|
|||||||
Function Add-Choco() {
|
|
||||||
try {
|
|
||||||
if($null -eq (Get-Command -Name choco.exe -ErrorAction SilentlyContinue)) {
|
|
||||||
# Source: https://docs.chocolatey.org/en-us/choco/setup
|
|
||||||
Set-ExecutionPolicy Bypass -Scope Process -Force
|
|
||||||
[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072
|
|
||||||
Invoke-Expression ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))
|
|
||||||
}
|
|
||||||
} catch { }
|
|
||||||
}
|
|
||||||
|
|
||||||
Function Add-Firebird() {
|
|
||||||
Add-Choco > $null 2>&1
|
|
||||||
choco install firebird -params '/ClientAndDevTools' -y --force > $null 2>&1
|
|
||||||
if((Get-ChildItem $env:ProgramFiles\**\**\fbclient.dll | Measure-Object).Count -eq 1) {
|
|
||||||
Add-Extension pdo_firebird
|
|
||||||
} else {
|
|
||||||
Add-Log $cross pdo_firebird "Could not install pdo_firebird on PHP $( $installed.FullVersion )"
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,35 +0,0 @@
|
|||||||
add_firebird_client_darwin() {
|
|
||||||
firebird_tag='R3_0_7'
|
|
||||||
pkg_name=$(get -s -n "" https://github.com/FirebirdSQL/firebird/releases/tag/"$firebird_tag" | grep -Eo "Firebird-.*.pkg" | head -n 1)
|
|
||||||
get -q -e "/tmp/firebird.pkg" https://github.com/FirebirdSQL/firebird/releases/download/"$firebird_tag"/"$pkg_name"
|
|
||||||
sudo installer -pkg /tmp/firebird.pkg -target /
|
|
||||||
sudo mkdir -p /opt/firebird/include /opt/firebird/lib
|
|
||||||
sudo find /Library/Frameworks/Firebird.framework -name '*.h' -exec cp "{}" /opt/firebird/include \;
|
|
||||||
sudo find /Library/Frameworks/Firebird.framework -name '*.dylib' -exec cp "{}" /opt/firebird/lib \;
|
|
||||||
}
|
|
||||||
|
|
||||||
add_firebird_helper() {
|
|
||||||
firebird_dir=$1
|
|
||||||
tag="$(php_src_tag)"
|
|
||||||
export PDO_FIREBIRD_CONFIGURE_OPTS="--with-pdo-firebird=$firebird_dir"
|
|
||||||
export PDO_FIREBIRD_LINUX_LIBS="firebird-dev"
|
|
||||||
export PDO_FIREBIRD_PATH="ext/pdo_firebird"
|
|
||||||
add_extension_from_source pdo_firebird https://github.com php php-src "$tag" extension get
|
|
||||||
}
|
|
||||||
|
|
||||||
add_firebird() {
|
|
||||||
enable_extension pdo_firebird
|
|
||||||
if ! check_extension pdo_firebird; then
|
|
||||||
if [ "$(uname -s)" = "Linux" ]; then
|
|
||||||
if [[ "${version:?}" =~ 5.3|${nightly_versions:?} ]]; then
|
|
||||||
add_firebird_helper /usr >/dev/null 2>&1
|
|
||||||
else
|
|
||||||
add_pdo_extension firebird >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
add_firebird_client_darwin >/dev/null 2>&1
|
|
||||||
add_firebird_helper /opt/firebird >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
add_extension_log pdo_firebird "Installed and enabled"
|
|
||||||
fi
|
|
||||||
}
|
|
@ -1,16 +1,17 @@
|
|||||||
# Helper function to add gearman extension.
|
# Helper function to add gearman extension.
|
||||||
add_gearman_helper() {
|
add_gearman_helper() {
|
||||||
add_ppa ondrej/pkg-gearman
|
sudo "${debconf_fix:?}" add-apt-repository ppa:ondrej/pkg-gearman -y
|
||||||
install_packages libgearman-dev
|
if [ -e "${ext_dir:?}/gearman.so" ] && [ "$DISTRIB_RELEASE" != "16.04" ]; then
|
||||||
enable_extension gearman extension
|
${apt_install:?} libgearman-dev
|
||||||
if ! check_extension gearman; then
|
echo "extension=gearman.so" | sudo tee -a "${scan_dir:?}/20-gearman.ini" >/dev/null 2>&1
|
||||||
status="Installed and enabled"
|
|
||||||
if [[ "${version:?}" =~ 5.[3-5] ]]; then
|
|
||||||
pecl_install gearman-1.1.2
|
|
||||||
else
|
else
|
||||||
install_packages php"${version:?}"-gearman || pecl_install gearman
|
status="Installed and enabled"
|
||||||
|
if [ "$DISTRIB_RELEASE" = "16.04" ]; then
|
||||||
|
sudo "${debconf_fix:?}" apt-get update -y
|
||||||
|
${apt_install:?} php"${version:?}"-gearman
|
||||||
|
else
|
||||||
|
${apt_install:?} libgearman-dev php"${version:?}"-gearman
|
||||||
fi
|
fi
|
||||||
enable_extension gearman extension
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,17 +0,0 @@
|
|||||||
# Helper function to compile and install geos
|
|
||||||
add_geos_helper() {
|
|
||||||
export GEOS_LINUX_LIBS='libgeos-dev'
|
|
||||||
export GEOS_DARWIN_LIBS='geos'
|
|
||||||
add_extension_from_source geos https://github.com libgeos php-geos 1.0.0 extension get
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add geos
|
|
||||||
add_geos() {
|
|
||||||
enable_extension "geos" "extension"
|
|
||||||
if check_extension "geos"; then
|
|
||||||
add_log "${tick:?}" "geos" "Enabled"
|
|
||||||
else
|
|
||||||
add_geos_helper >/dev/null 2>&1
|
|
||||||
add_extension_log "geos" "Installed and enabled"
|
|
||||||
fi
|
|
||||||
}
|
|
@ -1,55 +0,0 @@
|
|||||||
Function Get-ICUUrl() {
|
|
||||||
Param (
|
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
|
||||||
[ValidateNotNull()]
|
|
||||||
$icu_version,
|
|
||||||
[Parameter(Position = 1, Mandatory = $true)]
|
|
||||||
[ValidateNotNull()]
|
|
||||||
$arch,
|
|
||||||
[Parameter(Position = 2, Mandatory = $true)]
|
|
||||||
[ValidateNotNull()]
|
|
||||||
$vs_version
|
|
||||||
)
|
|
||||||
$trunk = "https://windows.php.net"
|
|
||||||
$urls=@("${trunk}/downloads/php-sdk/deps/${vs_version}/${arch}", "${trunk}/downloads/php-sdk/deps/archives/${vs_version}/${arch}")
|
|
||||||
foreach ($url in $urls) {
|
|
||||||
$web_content = Invoke-WebRequest -Uri $url
|
|
||||||
foreach ($link in $web_content.Links) {
|
|
||||||
if ($link -match "/.*ICU-${icu_version}.*/") {
|
|
||||||
return $trunk + $link.HREF
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Function Repair-ICU() {
|
|
||||||
$icu = deplister $ext_dir\php_http.dll | Select-String "icu[a-z]+(\d+).dll,([A-Z]+)" | Foreach-Object { $_.Matches }
|
|
||||||
if($icu -and $icu.Groups[2].Value -ne 'OK') {
|
|
||||||
$vs = "vs" + $installed.VCVersion
|
|
||||||
if ($installed.VCVersion -lt 16) {
|
|
||||||
$vs = "vc" + $installed.VCVersion
|
|
||||||
}
|
|
||||||
$zip_url = Get-ICUUrl $icu.Groups[1].Value $installed.Architecture $vs
|
|
||||||
if ($zip_url -ne '') {
|
|
||||||
New-Item -Path "$php_dir" -Name "icu" -ItemType "directory" | Out-Null
|
|
||||||
Invoke-WebRequest -Uri $zip_url -OutFile "$php_dir\icu\icu.zip"
|
|
||||||
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
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Function Add-Http() {
|
|
||||||
Add-Extension raphf >$null 2>&1
|
|
||||||
if($version -lt '8.0') {
|
|
||||||
Add-Extension propro >$null 2>&1
|
|
||||||
}
|
|
||||||
Add-Extension pecl_http >$null 2>&1
|
|
||||||
Repair-ICU
|
|
||||||
try {
|
|
||||||
php --ri "http" 2> $null | Out-Null
|
|
||||||
Add-Log $tick "http" "Installed and enabled"
|
|
||||||
} catch {
|
|
||||||
Add-Log $cross "http" "Could not install http on PHP $( $installed.FullVersion )"
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,120 +0,0 @@
|
|||||||
# Function to get http version for a PHP version.
|
|
||||||
get_http_version() {
|
|
||||||
if [[ ${version:?} =~ 5.[3-6] ]]; then
|
|
||||||
echo "pecl_http-2.6.0"
|
|
||||||
elif [[ ${version:?} =~ 7.[0-4] ]]; then
|
|
||||||
echo "pecl_http-3.2.4"
|
|
||||||
else
|
|
||||||
echo "pecl_http-$(get_pecl_version "pecl_http" "stable")"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to enable http extension.
|
|
||||||
enable_http() {
|
|
||||||
enable_extension propro extension
|
|
||||||
enable_extension raphf extension
|
|
||||||
if (! [[ ${version:?} =~ ${jit_versions:?} ]] && check_extension propro && check_extension raphf) ||
|
|
||||||
( [[ ${version:?} =~ ${jit_versions:?} ]] && check_extension raphf); then
|
|
||||||
enable_extension http extension
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to install extensions.
|
|
||||||
add_extension_helper() {
|
|
||||||
if [ "$os" = "Linux" ]; then
|
|
||||||
add_extension "$1" extension
|
|
||||||
else
|
|
||||||
add_brew_extension "$1" extension
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to install http dependencies.
|
|
||||||
add_http_dependencies() {
|
|
||||||
if [[ ${version:?} =~ ${old_versions:?} ]]; then
|
|
||||||
add_pecl_extension raphf 1.1.2 extension
|
|
||||||
add_pecl_extension propro 1.0.2 extension
|
|
||||||
elif [[ ${version:?} =~ 5.6|7.[0-4] ]]; then
|
|
||||||
add_extension_helper propro
|
|
||||||
add_extension_helper raphf
|
|
||||||
else
|
|
||||||
add_extension_helper raphf
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get configure options for http.
|
|
||||||
get_http_configure_opts() {
|
|
||||||
if [ "$os" = 'Linux' ]; then
|
|
||||||
for lib in zlib libbrotli libcurl libevent libicu libidn2 libidn libidnkit2 libidnkit; do
|
|
||||||
http_opts+=( "--with-http-$lib-dir=/usr" )
|
|
||||||
done
|
|
||||||
else
|
|
||||||
http_opts+=( "--with-http-zlib-dir=$(xcrun --show-sdk-path)/usr" )
|
|
||||||
http_opts+=( "--with-http-libbrotli-dir=$(brew --prefix brotli)" )
|
|
||||||
http_opts+=( "--with-http-libcurl-dir=$(brew --prefix curl)" )
|
|
||||||
http_opts+=( "--with-http-libicu-dir=$(brew --prefix icu4c)" )
|
|
||||||
http_opts+=( "--with-http-libevent-dir=$(brew --prefix libevent)" )
|
|
||||||
http_opts+=( "--with-http-libidn2-dir=$(brew --prefix libidn2)" )
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Compile and install http explicitly.
|
|
||||||
# This is done as pecl compiles raphf and propro as well.
|
|
||||||
add_http_helper() {
|
|
||||||
ext=$1
|
|
||||||
http_opts=() && get_http_configure_opts
|
|
||||||
export HTTP_PREFIX_CONFIGURE_OPTS="CFLAGS=-Wno-implicit-function-declaration"
|
|
||||||
http_configure_opts="--with-http --with-php-config=$(command -v php-config) ${http_opts[*]}"
|
|
||||||
export HTTP_CONFIGURE_OPTS="$http_configure_opts"
|
|
||||||
export HTTP_LINUX_LIBS="zlib1g libbrotli-dev libcurl4-openssl-dev libevent-dev libicu-dev libidn2-dev"
|
|
||||||
export HTTP_DARWIN_LIBS="brotli curl icu4c libevent libidn2"
|
|
||||||
if [[ "${version:?}" =~ ${nightly_versions:?} ]]; then
|
|
||||||
add_extension_from_source http https://github.com m6w6 ext-http master extension
|
|
||||||
else
|
|
||||||
add_extension_from_source pecl_http https://pecl.php.net http http "${ext##*-}" extension pecl
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to setup latest http extension.
|
|
||||||
add_http_latest() {
|
|
||||||
enable_http
|
|
||||||
if ! check_extension http; then
|
|
||||||
add_http_dependencies
|
|
||||||
if [ "$os" = "Linux" ]; then
|
|
||||||
if ! [[ "${version:?}" =~ ${old_versions:?}|${nightly_versions:?} ]]; then
|
|
||||||
install_packages "php$version-http"
|
|
||||||
else
|
|
||||||
add_http_helper "$(get_http_version)" "$os"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if ! [[ "${version:?}" =~ ${old_versions:?} ]]; then
|
|
||||||
add_brew_extension pecl_http extension
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
status="Installed and enabled"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to setup http extension given a version.
|
|
||||||
add_http_version() {
|
|
||||||
ext=$1
|
|
||||||
enable_http
|
|
||||||
if [ "x$(php -r "echo phpversion('http');")" != "x${ext##*-}" ]; then
|
|
||||||
remove_extension http >/dev/null
|
|
||||||
add_http_helper pecl_http-"${ext##*-}" "$os"
|
|
||||||
status="Installed and enabled"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to setup http extension
|
|
||||||
add_http() {
|
|
||||||
ext=$1
|
|
||||||
status="Enabled"
|
|
||||||
if [[ "$ext" =~ ^(pecl_http|http)$ ]]; then
|
|
||||||
add_http_latest >/dev/null 2>&1
|
|
||||||
else
|
|
||||||
add_http_version "$ext" >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
add_extension_log "http" "$status"
|
|
||||||
}
|
|
||||||
|
|
||||||
os="$(uname -s)"
|
|
@ -2,7 +2,7 @@
|
|||||||
install_icu() {
|
install_icu() {
|
||||||
icu=$1
|
icu=$1
|
||||||
if [ "$(php -i | grep "ICU version =>" | sed -e "s|.*=> s*||")" != "$icu" ]; then
|
if [ "$(php -i | grep "ICU version =>" | sed -e "s|.*=> s*||")" != "$icu" ]; then
|
||||||
get -q -n /tmp/icu.tar.zst "https://github.com/shivammathur/icu-intl/releases/download/icu4c/icu4c-$icu.tar.zst"
|
get -q -n /tmp/icu.tar.zst "https://dl.bintray.com/shivammathur/icu4c/icu4c-$icu.tar.zst"
|
||||||
sudo tar -I zstd -xf /tmp/icu.tar.zst -C /usr/local
|
sudo tar -I zstd -xf /tmp/icu.tar.zst -C /usr/local
|
||||||
sudo cp -r /usr/local/icu/lib/* /usr/lib/x86_64-linux-gnu/
|
sudo cp -r /usr/local/icu/lib/* /usr/lib/x86_64-linux-gnu/
|
||||||
fi
|
fi
|
||||||
@ -11,12 +11,12 @@ install_icu() {
|
|||||||
# Function to add ext-intl with the given version of ICU
|
# Function to add ext-intl with the given version of ICU
|
||||||
add_intl() {
|
add_intl() {
|
||||||
icu=$(echo "$1" | cut -d'-' -f 2)
|
icu=$(echo "$1" | cut -d'-' -f 2)
|
||||||
supported_version=$(get -s -n "" https://api.github.com/repos/shivammathur/icu-intl/releases | grep -Po "${icu//./\\.}" | head -n 1)
|
supported_version=$(get -s -n "" https://api.bintray.com/packages/shivammathur/icu4c/icu4c | grep -Po "$icu" | head -n 1)
|
||||||
if [ "$icu" != "$supported_version" ]; then
|
if [ "$icu" != "$supported_version" ]; then
|
||||||
add_log "${cross:?}" "intl" "ICU $icu is not supported"
|
add_log "${cross:?}" "intl" "ICU $icu is not supported"
|
||||||
else
|
else
|
||||||
install_icu "$icu" >/dev/null 2>&1
|
install_icu "$icu" >/dev/null 2>&1
|
||||||
get -q -n "${ext_dir:?}/intl.so" "https://github.com/shivammathur/icu-intl/releases/download/intl/php${version:?}-intl-$icu.so"
|
get -q -n "${ext_dir:?}/intl.so" "https://dl.bintray.com/shivammathur/icu4c/php${version:?}-intl-$icu.so"
|
||||||
enable_extension intl extension
|
enable_extension intl extension
|
||||||
add_extension_log intl "Installed and enabled with ICU $icu"
|
add_extension_log intl "Installed and enabled with ICU $icu"
|
||||||
fi
|
fi
|
||||||
|
@ -37,13 +37,11 @@ Function Add-Oci() {
|
|||||||
} else {
|
} else {
|
||||||
if(-not(Test-Path $ext_dir\php_oci8.dll)) {
|
if(-not(Test-Path $ext_dir\php_oci8.dll)) {
|
||||||
$status = 'Installed and enabled'
|
$status = 'Installed and enabled'
|
||||||
$ociVersion = Get-PeclPackageVersion oci8 -MinimumStability stable -MaximumStability stable | Select-Object -First 1
|
$ociVersion = '2.2.0'
|
||||||
if ($version -eq '7.0') {
|
if ($version -eq '7.0') {
|
||||||
$ociVersion = '2.1.8'
|
$ociVersion = '2.1.8'
|
||||||
} elseif ($version -lt '7.0') {
|
} elseif ($version -lt '7.0') {
|
||||||
$ociVersion = '2.0.12'
|
$ociVersion = '2.0.12'
|
||||||
} elseif ($version -lt '8.0') {
|
|
||||||
$ociVersion = '2.2.0'
|
|
||||||
}
|
}
|
||||||
$ociUrl = Get-PeclArchiveUrl oci8 $ociVersion $installed
|
$ociUrl = Get-PeclArchiveUrl oci8 $ociVersion $installed
|
||||||
Invoke-WebRequest -Uri $ociUrl -OutFile $php_dir\oci8.zip
|
Invoke-WebRequest -Uri $ociUrl -OutFile $php_dir\oci8.zip
|
||||||
|
@ -7,10 +7,21 @@ add_license_log() {
|
|||||||
echo "::endgroup::"
|
echo "::endgroup::"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to get the tag for a php version.
|
||||||
|
get_tag() {
|
||||||
|
tag='master'
|
||||||
|
if ! [[ ${version:?} =~ $nightly_versions ]]; then
|
||||||
|
tag="php-$(php -v | head -n 1 | cut -f 2 -d ' ' | cut -f 1 -d '-')"
|
||||||
|
elif [ "${version:?}" = '8.0' ]; then
|
||||||
|
tag="PHP-8.0"
|
||||||
|
fi
|
||||||
|
echo "$tag"
|
||||||
|
}
|
||||||
|
|
||||||
# Function to install instantclient and SDK.
|
# Function to install instantclient and SDK.
|
||||||
add_client() {
|
add_client() {
|
||||||
|
sudo mkdir -p -m 777 "$oracle_home"
|
||||||
if [ ! -e "$oracle_client" ]; then
|
if [ ! -e "$oracle_client" ]; then
|
||||||
sudo mkdir -p -m 777 "$oracle_home" "$oracle_client"
|
|
||||||
for package in basiclite sdk; do
|
for package in basiclite sdk; do
|
||||||
if [ "$os" = 'Linux' ]; then
|
if [ "$os" = 'Linux' ]; then
|
||||||
libs='/usr/lib/'
|
libs='/usr/lib/'
|
||||||
@ -24,12 +35,57 @@ add_client() {
|
|||||||
lib_ext='dylib'
|
lib_ext='dylib'
|
||||||
fi
|
fi
|
||||||
get -q -n "/opt/oracle/$package.zip" "https://download.oracle.com/otn_software/$os_name/instantclient/instantclient-$package-$arch.zip"
|
get -q -n "/opt/oracle/$package.zip" "https://download.oracle.com/otn_software/$os_name/instantclient/instantclient-$package-$arch.zip"
|
||||||
unzip -o "/opt/oracle/$package.zip" -d "$oracle_home"
|
unzip "/opt/oracle/$package.zip" -d "$oracle_home"
|
||||||
done
|
done
|
||||||
for icdir in /opt/oracle/instantclient_*; do
|
sudo ln -sf /opt/oracle/instantclient*/*.$lib_ext* $libs
|
||||||
sudo mv "$icdir"/* "$oracle_client"/
|
sudo ln -sf /opt/oracle/instantclient* "$oracle_client"
|
||||||
done
|
fi
|
||||||
sudo ln -sf /opt/oracle/instantclient/*.$lib_ext* $libs
|
}
|
||||||
|
|
||||||
|
# Function to get PHP source.
|
||||||
|
get_php() {
|
||||||
|
[ ! -d "/opt/oracle/php-src-$tag" ] && get -s -n "" "https://github.com/php/php-src/archive/$tag.tar.gz" | tar xzf - -C "$oracle_home/"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to get phpize location on darwin.
|
||||||
|
get_phpize() {
|
||||||
|
if [[ "$version" =~ 5.[3-5] ]]; then
|
||||||
|
echo '/opt/local/bin/phpize'
|
||||||
|
else
|
||||||
|
echo "/usr/local/bin/$(readlink /usr/local/bin/phpize)"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to patch phpize to link to php headers on darwin.
|
||||||
|
patch_phpize() {
|
||||||
|
if [ "$os" = "Darwin" ]; then
|
||||||
|
sudo cp "$phpize_orig" "$phpize_orig.bck"
|
||||||
|
sudo sed -i '' 's~includedir=.*~includedir="$(xcrun --show-sdk-path)/usr/include/php"~g' "$phpize_orig"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to restore phpize.
|
||||||
|
restore_phpize() {
|
||||||
|
if [ "$os" = "Darwin" ]; then
|
||||||
|
sudo mv "$phpize_orig.bck" "$phpize_orig" || true
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to patch pdo_oci.
|
||||||
|
patch_pdo_oci_config() {
|
||||||
|
get -q -n config.m4 https://raw.githubusercontent.com/php/php-src/PHP-8.0/ext/pdo_oci/config.m4
|
||||||
|
if [[ ${version:?} =~ 5.[3-6] ]]; then
|
||||||
|
sudo sed -i '' "/PHP_CHECK_PDO_INCLUDES/d" config.m4 2>/dev/null || sudo sed -i "/PHP_CHECK_PDO_INCLUDES/d" config.m4
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to install the dependencies.
|
||||||
|
add_dependencies() {
|
||||||
|
if [ "$os" = 'Linux' ]; then
|
||||||
|
if [ "${runner:?}" = "self-hosted" ]; then
|
||||||
|
${apt_install:?} --no-upgrade --no-install-recommends autoconf automake libaio-dev gcc g++
|
||||||
|
fi
|
||||||
|
! [[ ${version:?} =~ $nightly_versions ]] && add_devtools phpize
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -37,13 +93,20 @@ add_client() {
|
|||||||
add_oci_helper() {
|
add_oci_helper() {
|
||||||
if ! [ -e "${ext_dir:?}/$ext.so" ]; then
|
if ! [ -e "${ext_dir:?}/$ext.so" ]; then
|
||||||
status='Installed and enabled'
|
status='Installed and enabled'
|
||||||
read -r "${ext}_LINUX_LIBS" <<< "libaio-dev"
|
phpize_orig=$(get_phpize)
|
||||||
read -r "${ext}_CONFIGURE_OPTS" <<< "--with-php-config=$(command -v php-config) --with-${ext/_/-}=instantclient,$oracle_client"
|
tag=$(get_tag)
|
||||||
read -r "${ext}_PATH" <<< "ext/$ext"
|
get_php
|
||||||
patch_phpize
|
patch_phpize
|
||||||
add_extension_from_source "$ext" https://github.com php php-src "$(php_src_tag)" extension get
|
(
|
||||||
|
cd "/opt/oracle/php-src-$tag/ext/$ext" || exit 1
|
||||||
|
[ "$ext" = "pdo_oci" ] && patch_pdo_oci_config
|
||||||
|
sudo phpize && ./configure --with-php-config="$(command -v php-config)" --with-"${ext/_/-}"=instantclient,"$oracle_client"
|
||||||
|
sudo make -j"$(nproc)"
|
||||||
|
sudo cp ./modules/* "$ext_dir/"
|
||||||
|
)
|
||||||
restore_phpize
|
restore_phpize
|
||||||
fi
|
fi
|
||||||
|
echo "extension=$ext.so" | sudo tee "${scan_dir:?}/99-$ext.ini"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to add oci extension oci8 and pdo_oci.
|
# Function to add oci extension oci8 and pdo_oci.
|
||||||
@ -53,11 +116,10 @@ add_oci() {
|
|||||||
oracle_home='/opt/oracle'
|
oracle_home='/opt/oracle'
|
||||||
oracle_client=$oracle_home/instantclient
|
oracle_client=$oracle_home/instantclient
|
||||||
os=$(uname -s)
|
os=$(uname -s)
|
||||||
|
nightly_versions='8.[0-1]'
|
||||||
add_client >/dev/null 2>&1
|
add_client >/dev/null 2>&1
|
||||||
|
add_dependencies >/dev/null 2>&1
|
||||||
add_oci_helper >/dev/null 2>&1
|
add_oci_helper >/dev/null 2>&1
|
||||||
add_extension_log "$ext" "$status"
|
add_extension_log "$ext" "$status"
|
||||||
check_extension "$ext" && add_license_log
|
check_extension "$ext" && add_license_log
|
||||||
}
|
}
|
||||||
|
|
||||||
# shellcheck source=.
|
|
||||||
. "${scripts:?}"/ext/patches/phpize.sh
|
|
||||||
|
@ -1,11 +0,0 @@
|
|||||||
patch_firebird() {
|
|
||||||
if [[ "${version:?}" =~ ${old_versions:?} ]]; then
|
|
||||||
sudo sed -i '' '/PHP_CHECK_PDO_INCLUDES/d' config.m4 2>/dev/null || sudo sed -i '/PHP_CHECK_PDO_INCLUDES/d' config.m4
|
|
||||||
fi
|
|
||||||
lib_arch=$(gcc -dumpmachine)
|
|
||||||
lib_dir=/usr/lib/"$lib_arch"
|
|
||||||
if [ -d "$lib_dir" ]; then
|
|
||||||
sudo ln -sf "$lib_dir"/libfbclient.so.2 /usr/lib/libfbclient.so
|
|
||||||
sudo ln -sf "$lib_dir"/libib_util.so /usr/lib/
|
|
||||||
fi
|
|
||||||
}
|
|
@ -1,7 +0,0 @@
|
|||||||
patch_geos() {
|
|
||||||
if [ "$(php -r "echo PHP_VERSION_ID;")" -ge 70000 ]; then
|
|
||||||
sed -i~ -e "s/, ce->name/, ZSTR_VAL(ce->name)/; s/ulong /zend_ulong /" geos.c
|
|
||||||
fi
|
|
||||||
get -q -n /tmp/php8.patch https://git.remirepo.net/cgit/rpms/php/php-geos.git/plain/0003-add-all-arginfo-and-fix-build-with-PHP-8.patch
|
|
||||||
patch -p1 < /tmp/php8.patch 2>/dev/null || true
|
|
||||||
}
|
|
@ -1,11 +0,0 @@
|
|||||||
patch_pecl_http() {
|
|
||||||
if [ "$(uname -s)" = 'Darwin' ] && ! [[ ${version:?} =~ ${old_versions:?} ]]; then
|
|
||||||
if [[ ${version:?} =~ 5.6|7.[0-4] ]]; then
|
|
||||||
sed -i '' -e "s|ext/propro|$(brew --prefix propro@"${version:?}")/include/php/ext/propro@${version:?}|" "./src/php_http_api.h"
|
|
||||||
fi
|
|
||||||
sed -i '' -e "s|ext/raphf|$(brew --prefix raphf@"${version:?}")/include/php/ext/raphf@${version:?}|" "./src/php_http_api.h"
|
|
||||||
if [ "${version:?}" = "5.6" ]; then
|
|
||||||
sed -i '' -e "s|\$abs_srcdir|\$abs_srcdir ${brew_prefix:?}/include|" -e "s|/ext/propro|/php/ext/propro@5.6|" -e "s|/ext/raphf|/php/ext/raphf@5.6|" "./config9.m4"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
patch_pdo_oci() {
|
|
||||||
get -q -n config.m4 https://raw.githubusercontent.com/php/php-src/PHP-8.0/ext/pdo_oci/config.m4
|
|
||||||
if [[ ${version:?} =~ 5.[3-6] ]]; then
|
|
||||||
sudo sed -i '' "/PHP_CHECK_PDO_INCLUDES/d" config.m4 2>/dev/null || sudo sed -i "/PHP_CHECK_PDO_INCLUDES/d" config.m4
|
|
||||||
fi
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
# Function to get phpize location on darwin.
|
|
||||||
get_phpize() {
|
|
||||||
if [[ "${version:?}" =~ 5.[3-5] ]]; then
|
|
||||||
echo '/opt/local/bin/phpize'
|
|
||||||
else
|
|
||||||
echo "/usr/local/bin/$(readlink /usr/local/bin/phpize)"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to patch phpize to link to php headers on darwin.
|
|
||||||
patch_phpize() {
|
|
||||||
if [ "$(uname -s)" = "Darwin" ]; then
|
|
||||||
sudo cp "$phpize_orig" "$phpize_orig.bck"
|
|
||||||
sudo sed -i '' 's~includedir=.*~includedir="$(xcrun --show-sdk-path)/usr/include/php"~g' "$phpize_orig"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to restore phpize.
|
|
||||||
restore_phpize() {
|
|
||||||
if [ "$os" = "Darwin" ]; then
|
|
||||||
sudo mv "$phpize_orig.bck" "$phpize_orig" || true
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
os="$(uname -s)"
|
|
||||||
phpize_orig="$(get_phpize)"
|
|
@ -1,4 +0,0 @@
|
|||||||
patch_protobuf() {
|
|
||||||
mkdir -p third_party/wyhash
|
|
||||||
cp ../../../../third_party/wyhash/* third_party/wyhash
|
|
||||||
}
|
|
@ -1,11 +1,11 @@
|
|||||||
# Function to install phalcon
|
# Function to install phalcon
|
||||||
Function Add-PhalconHelper() {
|
Function Add-PhalconHelper() {
|
||||||
if ($extension_version -eq '4') {
|
if ($extension_version -eq '4') {
|
||||||
Install-Phpextension -Extension phalcon -MinimumStability stable -Path $php_dir
|
Install-Phpextension phalcon -MinimumStability stable -Path $php_dir
|
||||||
} else {
|
} else {
|
||||||
$domain = 'https://github.com'
|
$domain = 'https://github.com'
|
||||||
$nts = if (!$installed.ThreadSafe) { "_nts" } else { "" }
|
$nts = if (!$installed.ThreadSafe) { "_nts" } else { "" }
|
||||||
$match = Invoke-WebRequest -Uri "$domain/phalcon/cphalcon/releases/v3.4.5" | Select-String -Pattern "href=`"(.*phalcon_x64_.*_php${version}_${extension_version}.*[0-9]${nts}.zip)`""
|
$match = Invoke-WebRequest -Uri $domain/phalcon/cphalcon/releases | Select-String -Pattern "href=`"(.*phalcon_x64_.*_php${version}_${extension_version}.*[0-9]${nts}.zip)`""
|
||||||
$zip_file = $match.Matches[0].Groups[1].Value
|
$zip_file = $match.Matches[0].Groups[1].Value
|
||||||
Invoke-WebRequest -Uri $domain/$zip_file -OutFile $ENV:RUNNER_TOOL_CACHE\phalcon.zip > $null 2>&1
|
Invoke-WebRequest -Uri $domain/$zip_file -OutFile $ENV:RUNNER_TOOL_CACHE\phalcon.zip > $null 2>&1
|
||||||
Expand-Archive -Path $ENV:RUNNER_TOOL_CACHE\phalcon.zip -DestinationPath $ENV:RUNNER_TOOL_CACHE\phalcon -Force > $null 2>&1
|
Expand-Archive -Path $ENV:RUNNER_TOOL_CACHE\phalcon.zip -DestinationPath $ENV:RUNNER_TOOL_CACHE\phalcon -Force > $null 2>&1
|
||||||
@ -30,7 +30,7 @@ Function Add-Phalcon() {
|
|||||||
if (Test-Path $ext_dir\php_psr.dll) {
|
if (Test-Path $ext_dir\php_psr.dll) {
|
||||||
Enable-PhpExtension -Extension psr -Path $php_dir
|
Enable-PhpExtension -Extension psr -Path $php_dir
|
||||||
} else {
|
} else {
|
||||||
Install-Phpextension -Extension psr -MinimumStability stable -Path $php_dir
|
Install-Phpextension psr -MinimumStability stable -Path $php_dir
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,6 +49,7 @@ Function Add-Phalcon() {
|
|||||||
}
|
}
|
||||||
Add-Log $tick $extension $status
|
Add-Log $tick $extension $status
|
||||||
} catch [Exception] {
|
} catch [Exception] {
|
||||||
|
Write-Output $_.Exception|format-list -force
|
||||||
Add-Log $cross $extension "Could not install $extension on PHP $($installed.FullVersion)"
|
Add-Log $cross $extension "Could not install $extension on PHP $($installed.FullVersion)"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,20 @@
|
|||||||
# 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 [ "$os_name" = "Linux" ]; then
|
||||||
|
update_lists
|
||||||
if [ "$extension" = "phalcon4" ]; then
|
if [ "$extension" = "phalcon4" ]; then
|
||||||
install_packages "php${version:?}-psr" "php${version:?}-$extension"
|
${apt_install:?} "php${version:?}-psr" "php${version:?}-$extension"
|
||||||
else
|
else
|
||||||
install_packages "php${version:?}-$extension"
|
${apt_install:?} "php${version:?}-$extension"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
phalcon_ini_file=${ini_file:?}
|
||||||
|
sed -i '' '/extension.*psr/d' "${ini_file:?}"
|
||||||
|
brew tap shivammathur/homebrew-phalcon
|
||||||
|
brew install phalcon@"${version:?}"_"$extension_major_version"
|
||||||
|
sudo cp /usr/local/opt/psr@"${version:?}"/psr.so "${ext_dir:?}"
|
||||||
|
sudo cp /usr/local/opt/phalcon@"${version:?}"_"$extension_major_version"/phalcon.so "${ext_dir:?}"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +57,8 @@ add_phalcon4() {
|
|||||||
add_phalcon() {
|
add_phalcon() {
|
||||||
extension=$1
|
extension=$1
|
||||||
status='Enabled'
|
status='Enabled'
|
||||||
phalcon_ini_file="${pecl_file:-${ini_file[@]}}"
|
os_name=$(uname -s)
|
||||||
|
phalcon_ini_file="${scan_dir:?}/50-phalcon.ini"
|
||||||
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
|
||||||
|
@ -1,144 +0,0 @@
|
|||||||
# Function to parse extension environment variables
|
|
||||||
parse_args() {
|
|
||||||
extension=$1
|
|
||||||
suffix=$(echo "$2" | tr '[:lower:]' '[:upper:]')
|
|
||||||
up_ext_name=$(echo "$extension" | tr '[:lower:]' '[:upper:]')
|
|
||||||
var="${extension}_${suffix}"
|
|
||||||
up_var="${up_ext_name}_${suffix}"
|
|
||||||
! [[ "$suffix" =~ .*PREFIX|LIBS|PATH.* ]] && hyp='-'
|
|
||||||
output=$(echo "${!var} ${!up_var}" | sed "s/, *$hyp/ $hyp/g" | sed -E "s/^,|,$//g")
|
|
||||||
echo "$output" | xargs -n 1 | sort | uniq | xargs
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to log if a library is installed
|
|
||||||
add_lib_log() {
|
|
||||||
lib=$1
|
|
||||||
if check_lib "$lib"; then
|
|
||||||
add_log "${tick:?}" "$lib" "Installed"
|
|
||||||
else
|
|
||||||
add_log "${cross:?}" "$lib" "Could not install $lib"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to check if a library is installed
|
|
||||||
check_lib() {
|
|
||||||
lib=$1
|
|
||||||
if [ "$(uname -s)" = "Linux" ]; then
|
|
||||||
[ "x$(dpkg -s "$lib" 2>/dev/null | grep Status)" != "x" ]
|
|
||||||
else
|
|
||||||
[ "x$(find "${brew_prefix:?}"/Cellar -maxdepth 1 -name "$lib")" != "x" ]
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add a library on linux
|
|
||||||
add_linux_libs() {
|
|
||||||
lib=$1
|
|
||||||
if ! check_lib "$lib"; then
|
|
||||||
install_packages "$lib" >/dev/null 2>&1 || true
|
|
||||||
fi
|
|
||||||
add_lib_log "$lib"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add a library on macOS
|
|
||||||
add_darwin_libs() {
|
|
||||||
lib=$1
|
|
||||||
if ! check_lib "$lib"; then
|
|
||||||
brew install "$lib" >/dev/null 2>&1 || true
|
|
||||||
if [[ "$lib" = *@* ]]; then
|
|
||||||
brew link --overwrite --force "$lib" >/dev/null 2>&1 || true
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
add_lib_log "$lib"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add required libraries
|
|
||||||
add_libs() {
|
|
||||||
all_libs=("$@")
|
|
||||||
for lib in "${all_libs[@]}"; do
|
|
||||||
if [ "$(uname -s)" = "Linux" ]; then
|
|
||||||
add_linux_libs "$lib"
|
|
||||||
else
|
|
||||||
add_darwin_libs "$lib"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to run command in a group
|
|
||||||
run_group() {
|
|
||||||
command=$1
|
|
||||||
log=$2
|
|
||||||
echo "$command" | sudo tee ./run_group.sh >/dev/null 2>&1
|
|
||||||
echo "::group::$log"
|
|
||||||
. ./run_group.sh
|
|
||||||
rm ./run_group.sh
|
|
||||||
echo "::endgroup::"
|
|
||||||
}
|
|
||||||
|
|
||||||
patch_extension() {
|
|
||||||
extension=$1
|
|
||||||
if [ -e "${scripts:?}"/ext/patches/"$extension".sh ]; then
|
|
||||||
# shellcheck source=.
|
|
||||||
. "${scripts:?}"/ext/patches/"$extension".sh
|
|
||||||
patch_"${extension}"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
fetch_extension() {
|
|
||||||
fetch=$1
|
|
||||||
if [ "$fetch" = "clone" ]; then
|
|
||||||
run_group "git clone -nv $url/$org/$repo /tmp/$repo-$release" "git clone"
|
|
||||||
cd /tmp/"$repo-$release" || exit 1
|
|
||||||
git checkout -q "$release"
|
|
||||||
cd "$sub_dir" || exit 1
|
|
||||||
if [ -e .gitmodules ]; then
|
|
||||||
jobs="$(grep -c "\[submodule" .gitmodules)"
|
|
||||||
run_group "git submodule update --jobs $jobs --init --recursive" "git submodule"
|
|
||||||
fi
|
|
||||||
elif [ "$fetch" = "get" ]; then
|
|
||||||
get -q -n /tmp/"$extension".tar.gz "$url/$org/$repo/archive/$release.tar.gz"
|
|
||||||
tar -xzf /tmp/"$extension".tar.gz -C /tmp
|
|
||||||
cd /tmp/"$repo"-"$release"/"$sub_dir" || exit
|
|
||||||
elif [ "$fetch" = "pecl" ]; then
|
|
||||||
source="pecl"
|
|
||||||
pecl_name=${extension/http/pecl_http}
|
|
||||||
get -q -n /tmp/"$pecl_name".tgz https://pecl.php.net/get/"$pecl_name"-"$release".tgz
|
|
||||||
tar -xzf /tmp/"$pecl_name".tgz -C /tmp
|
|
||||||
cd /tmp/"$pecl_name"-"$release" || exit
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to install extension from a git repository
|
|
||||||
add_extension_from_source() {
|
|
||||||
extension="${1/pecl_/}"
|
|
||||||
url=$2
|
|
||||||
org=$3
|
|
||||||
repo=$4
|
|
||||||
release=$5
|
|
||||||
prefix=$6
|
|
||||||
fetch=${7:-clone}
|
|
||||||
slug="$extension-$release"
|
|
||||||
source="$url/$org/$repo"
|
|
||||||
libraries="$(parse_args "$extension" LIBS) $(parse_args "$extension" "$(uname -s)"_LIBS)"
|
|
||||||
opts="$(parse_args "$extension" CONFIGURE_OPTS)"
|
|
||||||
prefix_opts="$(parse_args "$extension" CONFIGURE_PREFIX_OPTS)"
|
|
||||||
suffix_opts="$(parse_args "$extension" CONFIGURE_SUFFIX_OPTS)"
|
|
||||||
sub_dir="$(parse_args "$extension" PATH)"
|
|
||||||
step_log "Setup $slug"
|
|
||||||
(
|
|
||||||
add_devtools phpize >/dev/null 2>&1
|
|
||||||
delete_extension "$extension"
|
|
||||||
fetch_extension "$fetch"
|
|
||||||
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"
|
|
||||||
else
|
|
||||||
[[ -n "${libraries// }" ]] && run_group "add_libs $libraries" "add libraries"
|
|
||||||
patch_extension "$extension" >/dev/null 2>&1
|
|
||||||
run_group "phpize" "phpize"
|
|
||||||
run_group "sudo $prefix_opts ./configure $suffix_opts $opts" "configure"
|
|
||||||
run_group "sudo make -j$(nproc 2>/dev/null || sysctl -n hw.ncpu)" "make"
|
|
||||||
run_group "sudo make install" "make install"
|
|
||||||
enable_extension "$extension" "$prefix"
|
|
||||||
fi
|
|
||||||
)
|
|
||||||
add_extension_log "$slug" "Installed from $source and enabled"
|
|
||||||
}
|
|
@ -1,37 +1,59 @@
|
|||||||
# Function to setup environment for self-hosted runners.
|
# Function to setup environment for self-hosted runners.
|
||||||
self_hosted_helper() {
|
self_hosted_helper() {
|
||||||
if ! command -v sudo >/dev/null; then
|
|
||||||
apt-get update
|
|
||||||
apt-get install -y sudo || add_log "${cross:?}" "sudo" "Could not install sudo"
|
|
||||||
fi
|
|
||||||
if ! command -v apt-fast >/dev/null; then
|
if ! command -v apt-fast >/dev/null; then
|
||||||
sudo ln -sf /usr/bin/apt-get /usr/bin/apt-fast
|
sudo ln -sf /usr/bin/apt-get /usr/bin/apt-fast
|
||||||
trap "sudo rm -f /usr/bin/apt-fast 2>/dev/null" exit
|
|
||||||
fi
|
fi
|
||||||
install_packages apt-transport-https ca-certificates curl file make jq unzip autoconf automake gcc g++ gnupg
|
install_packages curl make software-properties-common unzip
|
||||||
|
add_ppa
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to backup and cleanup package lists.
|
||||||
|
cleanup_lists() {
|
||||||
|
if [ ! -e /etc/apt/sources.list.d.save ]; then
|
||||||
|
sudo mv /etc/apt/sources.list.d /etc/apt/sources.list.d.save
|
||||||
|
sudo mkdir /etc/apt/sources.list.d
|
||||||
|
sudo mv /etc/apt/sources.list.d.save/*ondrej*.list /etc/apt/sources.list.d/
|
||||||
|
sudo mv /etc/apt/sources.list.d.save/*dotdeb*.list /etc/apt/sources.list.d/ 2>/dev/null || true
|
||||||
|
trap "sudo mv /etc/apt/sources.list.d.save/*.list /etc/apt/sources.list.d/ 2>/dev/null" exit
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to add ppa:ondrej/php.
|
||||||
|
add_ppa() {
|
||||||
|
if ! apt-cache policy | grep -q ondrej/php; then
|
||||||
|
cleanup_lists
|
||||||
|
LC_ALL=C.UTF-8 sudo apt-add-repository ppa:ondrej/php -y
|
||||||
|
if [ "$DISTRIB_RELEASE" = "16.04" ]; then
|
||||||
|
sudo "$debconf_fix" apt-get update
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to update the package lists.
|
||||||
|
update_lists() {
|
||||||
|
if [ ! -e /tmp/setup_php ]; then
|
||||||
|
[ "$DISTRIB_RELEASE" = "20.04" ] && add_ppa >/dev/null 2>&1
|
||||||
|
cleanup_lists
|
||||||
|
sudo "$debconf_fix" apt-get update >/dev/null 2>&1
|
||||||
|
echo '' | sudo tee /tmp/setup_php >/dev/null 2>&1
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# 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 delete extensions.
|
||||||
disable_extension() {
|
|
||||||
extension=$1
|
|
||||||
sudo sed -Ei "/=(.*\/)?\"?$extension(.so)?$/d" "${ini_file[@]}"
|
|
||||||
sudo sed -Ei "/=(.*\/)?\"?$extension(.so)?$/d" "$pecl_file"
|
|
||||||
sudo find "$ini_dir"/.. -name "*$extension.ini" -delete >/dev/null 2>&1 || true
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to delete an extension.
|
|
||||||
delete_extension() {
|
delete_extension() {
|
||||||
extension=$1
|
extension=$1
|
||||||
disable_extension "$extension"
|
sudo sed -i "/$extension/d" "${ini_file:?}"
|
||||||
sudo rm -rf "$ext_dir"/"$extension".so >/dev/null 2>&1
|
sudo sed -i "/$extension/d" "${pecl_file:?}"
|
||||||
sudo sed -i "/Package: php$version-$extension/,/^$/d" /var/lib/dpkg/status
|
sudo rm -rf "${scan_dir:?}"/*"$extension"* "${ext_dir:?}"/"$extension".so >/dev/null 2>&1
|
||||||
|
if [ "${runner:?}" = "self-hosted" ]; then
|
||||||
|
$apt_remove "php-$extension" "php$version-$extension" >/dev/null 2>&1 || true
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to disable and delete extensions.
|
# Function to disable and delete extensions.
|
||||||
@ -40,6 +62,7 @@ remove_extension() {
|
|||||||
if check_extension "$extension"; then
|
if check_extension "$extension"; then
|
||||||
if [[ ! "$version" =~ ${old_versions:?} ]] && [ -e /etc/php/"$version"/mods-available/"$extension".ini ]; then
|
if [[ ! "$version" =~ ${old_versions:?} ]] && [ -e /etc/php/"$version"/mods-available/"$extension".ini ]; then
|
||||||
sudo phpdismod -v "$version" "$extension" >/dev/null 2>&1
|
sudo phpdismod -v "$version" "$extension" >/dev/null 2>&1
|
||||||
|
echo "$extension" | sudo tee -a /tmp/setup_php_dismod >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
delete_extension "$extension"
|
delete_extension "$extension"
|
||||||
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Removed") ||
|
(! check_extension "$extension" && add_log "${tick:?}" ":$extension" "Removed") ||
|
||||||
@ -56,24 +79,14 @@ add_pdo_extension() {
|
|||||||
if check_extension "$pdo_ext"; then
|
if check_extension "$pdo_ext"; then
|
||||||
add_log "${tick:?}" "$pdo_ext" "Enabled"
|
add_log "${tick:?}" "$pdo_ext" "Enabled"
|
||||||
else
|
else
|
||||||
ext=$1
|
ext=$1; ext_name=$1;
|
||||||
ext_name=$1
|
sudo rm -rf "$scan_dir"/*pdo.ini >/dev/null 2>&1
|
||||||
if [ -e "$ext_dir"/pdo.so ]; then
|
if ! check_extension "pdo" 2>/dev/null; then echo "extension=pdo.so" >>"$ini_file"; fi
|
||||||
disable_extension pdo
|
|
||||||
echo "extension=pdo.so" | sudo tee "${ini_file[@]/php.ini/conf.d/10-pdo.ini}" >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
if [ "$ext" = "mysql" ]; then
|
if [ "$ext" = "mysql" ]; then
|
||||||
enable_extension "mysqlnd" "extension"
|
enable_extension "mysqlnd" "extension"
|
||||||
ext_name='mysqli'
|
ext_name="mysqli"
|
||||||
elif [ "$ext" = "dblib" ]; then
|
|
||||||
ext_name="sybase"
|
|
||||||
elif [ "$ext" = "firebird" ]; then
|
|
||||||
install_packages libfbclient2 >/dev/null 2>&1
|
|
||||||
enable_extension "pdo_firebird" "extension"
|
|
||||||
ext_name="interbase"
|
|
||||||
elif [ "$ext" = "sqlite" ]; then
|
elif [ "$ext" = "sqlite" ]; then
|
||||||
ext="sqlite3"
|
ext="sqlite3"; ext_name="sqlite3";
|
||||||
ext_name="sqlite3"
|
|
||||||
fi
|
fi
|
||||||
add_extension "$ext_name" "extension" >/dev/null 2>&1
|
add_extension "$ext_name" "extension" >/dev/null 2>&1
|
||||||
add_extension "$pdo_ext" "extension" >/dev/null 2>&1
|
add_extension "$pdo_ext" "extension" >/dev/null 2>&1
|
||||||
@ -89,14 +102,54 @@ add_extension() {
|
|||||||
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
|
if [[ "$version" =~ 5.[4-5] ]]; then
|
||||||
|
install_packages "php5-$extension=$release_version"
|
||||||
|
elif [[ "$version" =~ ${nightly_versions:?} ]]; then
|
||||||
pecl_install "$extension"
|
pecl_install "$extension"
|
||||||
else
|
else
|
||||||
install_packages "php$version-$extension" || pecl_install "$extension"
|
install_packages "php$version-$extension" || pecl_install "$extension"
|
||||||
fi
|
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"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to install a PECL version.
|
||||||
|
add_pecl_extension() {
|
||||||
|
extension=$1
|
||||||
|
pecl_version=$2
|
||||||
|
prefix=$3
|
||||||
|
if [[ $pecl_version =~ .*(alpha|beta|rc|snapshot|preview).* ]]; then
|
||||||
|
pecl_version=$(get_pecl_version "$extension" "$pecl_version")
|
||||||
|
fi
|
||||||
|
enable_extension "$extension" "$prefix"
|
||||||
|
ext_version=$(php -r "echo phpversion('$extension');")
|
||||||
|
if [ "$ext_version" = "$pecl_version" ]; then
|
||||||
|
add_log "${tick:?}" "$extension" "Enabled"
|
||||||
|
else
|
||||||
|
delete_extension "$extension"
|
||||||
|
pecl_install "$extension-$pecl_version"
|
||||||
|
add_extension_log "$extension-$pecl_version" "Installed and enabled"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to install extension from source
|
||||||
|
add_extension_from_source() {
|
||||||
|
extension=$1
|
||||||
|
repo=$2
|
||||||
|
release=$3
|
||||||
|
args=$4
|
||||||
|
prefix=$5
|
||||||
|
(
|
||||||
|
add_devtools phpize
|
||||||
|
delete_extension "$extension"
|
||||||
|
get -q -n "/tmp/$extension.tar.gz" "https://github.com/$repo/archive/$release.tar.gz"
|
||||||
|
tar xf /tmp/"$extension".tar.gz -C /tmp
|
||||||
|
cd /tmp/"$extension-$release" || exit 1
|
||||||
|
phpize && ./configure "$args" && make -j"$(nproc)" && sudo make install
|
||||||
|
enable_extension "$extension" "$prefix"
|
||||||
|
) >/dev/null 2>&1
|
||||||
|
add_extension_log "$extension-$release" "Installed and enabled"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to setup phpize and php-config.
|
# Function to setup phpize and php-config.
|
||||||
@ -105,18 +158,24 @@ add_devtools() {
|
|||||||
if ! command -v "$tool$version" >/dev/null; then
|
if ! command -v "$tool$version" >/dev/null; then
|
||||||
install_packages "php$version-dev" "php$version-xml"
|
install_packages "php$version-dev" "php$version-xml"
|
||||||
fi
|
fi
|
||||||
switch_version "phpize" "php-config"
|
sudo update-alternatives --set php-config /usr/bin/php-config"$version" >/dev/null 2>&1
|
||||||
|
sudo update-alternatives --set phpize /usr/bin/phpize"$version" >/dev/null 2>&1
|
||||||
|
if command -v pecl >/dev/null; then
|
||||||
|
configure_pecl >/dev/null 2>&1
|
||||||
|
fi
|
||||||
add_log "${tick:?}" "$tool" "Added $tool $semver"
|
add_log "${tick:?}" "$tool" "Added $tool $semver"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to setup the nightly build from shivammathur/php-builder
|
# Function to setup the nightly build from shivammathur/php-builder
|
||||||
setup_nightly() {
|
setup_nightly() {
|
||||||
run_script "php-builder" "${runner:?}" "$version"
|
run_script "php-builder" "$runner" "$version"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to setup PHP 5.3, PHP 5.4 and PHP 5.5.
|
# Function to setup PHP 5.3, PHP 5.4 and PHP 5.5.
|
||||||
setup_old_versions() {
|
setup_old_versions() {
|
||||||
run_script "php5-ubuntu" "$version"
|
run_script "php5-ubuntu" "$version"
|
||||||
|
configure_pecl
|
||||||
|
release_version=$(php -v | head -n 1 | cut -d' ' -f 2)
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to add PECL.
|
# Function to add PECL.
|
||||||
@ -132,12 +191,10 @@ add_pecl() {
|
|||||||
|
|
||||||
# Function to switch versions of PHP binaries.
|
# Function to switch versions of PHP binaries.
|
||||||
switch_version() {
|
switch_version() {
|
||||||
tools=("$@") && ! (( ${#tools[@]} )) && tools+=(pear pecl php phar phar.phar php-cgi php-config phpize phpdbg)
|
for tool in pear pecl php phar phar.phar php-cgi php-config phpize phpdbg; do
|
||||||
to_wait=()
|
|
||||||
for tool in "${tools[@]}"; do
|
|
||||||
if [ -e "/usr/bin/$tool$version" ]; then
|
if [ -e "/usr/bin/$tool$version" ]; then
|
||||||
sudo update-alternatives --set "$tool" /usr/bin/"$tool$version" &
|
sudo update-alternatives --set $tool /usr/bin/"$tool$version" &
|
||||||
to_wait+=($!)
|
to_wait+=( $! )
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
wait "${to_wait[@]}"
|
wait "${to_wait[@]}"
|
||||||
@ -148,7 +205,7 @@ 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
|
update_lists
|
||||||
IFS=' ' read -r -a packages <<<"$(echo "cli curl mbstring xml intl" | sed "s/[^ ]*/php$version-&/g")"
|
IFS=' ' read -r -a packages <<<"$(echo "cli curl mbstring xml intl" | sed "s/[^ ]*/php$version-&/g")"
|
||||||
install_packages "${packages[@]}"
|
$apt_install "${packages[@]}"
|
||||||
else
|
else
|
||||||
run_script "php-ubuntu" "$version"
|
run_script "php-ubuntu" "$version"
|
||||||
fi
|
fi
|
||||||
@ -157,7 +214,7 @@ add_packaged_php() {
|
|||||||
# Function to update PHP.
|
# Function to update PHP.
|
||||||
update_php() {
|
update_php() {
|
||||||
initial_version=$(php_semver)
|
initial_version=$(php_semver)
|
||||||
add_packaged_php
|
use_package_cache="false" add_packaged_php
|
||||||
updated_version=$(php_semver)
|
updated_version=$(php_semver)
|
||||||
if [ "$updated_version" != "$initial_version" ]; then
|
if [ "$updated_version" != "$initial_version" ]; then
|
||||||
status="Updated to"
|
status="Updated to"
|
||||||
@ -178,22 +235,6 @@ add_php() {
|
|||||||
status="Installed"
|
status="Installed"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to ini file for pear and link it to each SAPI.
|
|
||||||
link_pecl_file() {
|
|
||||||
echo '' | sudo tee "$pecl_file" >/dev/null 2>&1
|
|
||||||
for file in "${ini_file[@]}"; do
|
|
||||||
sapi_scan_dir="$(realpath -m "$(dirname "$file")")/conf.d"
|
|
||||||
[ "$sapi_scan_dir" != "$scan_dir" ] && ! [ -h "$sapi_scan_dir" ] && sudo ln -sf "$pecl_file" "$sapi_scan_dir/99-pecl.ini"
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get extra version.
|
|
||||||
php_extra_version() {
|
|
||||||
if [[ ${version:?} =~ ${nightly_versions:?} ]]; then
|
|
||||||
echo " ($(cat "/etc/php/$version/COMMIT"))"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to Setup PHP
|
# Function to Setup PHP
|
||||||
setup_php() {
|
setup_php() {
|
||||||
step_log "Setup PHP"
|
step_log "Setup PHP"
|
||||||
@ -218,39 +259,28 @@ setup_php() {
|
|||||||
status="Found"
|
status="Found"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if ! command -v php"$version" >/dev/null; then
|
|
||||||
add_log "$cross" "PHP" "Could not setup PHP $version"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
semver=$(php_semver)
|
semver=$(php_semver)
|
||||||
extra_version=$(php_extra_version)
|
|
||||||
ext_dir=$(php -i | grep "extension_dir => /" | sed -e "s|.*=> s*||")
|
ext_dir=$(php -i | grep "extension_dir => /" | sed -e "s|.*=> s*||")
|
||||||
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_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g")
|
||||||
pecl_file="$scan_dir"/99-pecl.ini
|
pecl_file="$scan_dir"/99-pecl.ini
|
||||||
mapfile -t ini_file < <(sudo find "$ini_dir/.." -name "php.ini" -exec readlink -m {} +)
|
echo '' | sudo tee "$pecl_file" >/dev/null 2>&1
|
||||||
link_pecl_file
|
|
||||||
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/*.json "$RUNNER_TOOL_CACHE/"
|
||||||
echo "::set-output name=php-version::$semver"
|
add_log "${tick:?}" "PHP" "$status PHP $semver"
|
||||||
add_log "${tick:?}" "PHP" "$status PHP $semver$extra_version"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
version=$1
|
version=$1
|
||||||
dist=$2
|
dist=$2
|
||||||
debconf_fix="DEBIAN_FRONTEND=noninteractive"
|
debconf_fix="DEBIAN_FRONTEND=noninteractive"
|
||||||
apt_install="sudo $debconf_fix apt-fast install -y --no-install-recommends"
|
apt_install="sudo $debconf_fix apt-fast install -y"
|
||||||
scripts="${dist}"/../src/scripts
|
apt_remove="sudo $debconf_fix apt-fast remove -y"
|
||||||
|
|
||||||
. /etc/os-release
|
|
||||||
# shellcheck source=.
|
# shellcheck source=.
|
||||||
. "${scripts:?}"/ext/source.sh
|
. "${dist}"/../src/scripts/common.sh
|
||||||
. "${scripts:?}"/tools/ppa.sh
|
. /etc/lsb-release
|
||||||
. "${scripts:?}"/tools/add_tools.sh
|
|
||||||
. "${scripts:?}"/common.sh
|
|
||||||
read_env
|
read_env
|
||||||
self_hosted_setup
|
self_hosted_setup
|
||||||
setup_php
|
setup_php
|
||||||
|
@ -1,26 +0,0 @@
|
|||||||
Function Add-ToolsHelper() {
|
|
||||||
Param (
|
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
|
||||||
[ValidateNotNull()]
|
|
||||||
$tool
|
|
||||||
)
|
|
||||||
if($tool -eq "codeception") {
|
|
||||||
Copy-Item $composer_bin\codecept.bat -Destination $composer_bin\codeception.bat
|
|
||||||
} elseif($tool -eq "composer") {
|
|
||||||
Edit-ComposerConfig $bin_dir\$tool
|
|
||||||
} elseif($tool -eq "cs2pr") {
|
|
||||||
(Get-Content $bin_dir/cs2pr).replace('exit(9)', 'exit(0)') | Set-Content $bin_dir/cs2pr
|
|
||||||
} elseif($tool -eq "phan") {
|
|
||||||
Add-Extension fileinfo >$null 2>&1
|
|
||||||
Add-Extension ast >$null 2>&1
|
|
||||||
} elseif($tool -eq "phive") {
|
|
||||||
Add-Extension xml >$null 2>&1
|
|
||||||
} elseif($tool -eq "symfony-cli") {
|
|
||||||
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"
|
|
||||||
} elseif($tool -match "vapor-cli") {
|
|
||||||
Copy-Item $composer_bin\vapor.bat -Destination $composer_bin\vapor-cli.bat
|
|
||||||
} elseif($tool -eq "wp-cli") {
|
|
||||||
Copy-Item $bin_dir\wp-cli.bat -Destination $bin_dir\wp.bat
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,20 +0,0 @@
|
|||||||
add_tools_helper() {
|
|
||||||
tool=$1
|
|
||||||
if [ "$tool" = "codeception" ]; then
|
|
||||||
sudo ln -s "${composer_bin:?}"/codecept "${composer_bin:?}"/codeception
|
|
||||||
elif [ "$tool" = "composer" ]; then
|
|
||||||
configure_composer "${tool_path:?}"
|
|
||||||
elif [ "$tool" = "cs2pr" ]; then
|
|
||||||
sudo sed -i 's/\r$//; s/exit(9)/exit(0)/' "${tool_path:?}" 2>/dev/null ||
|
|
||||||
sudo sed -i '' 's/\r$//; s/exit(9)/exit(0)/' "${tool_path:?}"
|
|
||||||
elif [ "$tool" = "phan" ]; then
|
|
||||||
add_extension fileinfo extension >/dev/null 2>&1
|
|
||||||
add_extension ast extension >/dev/null 2>&1
|
|
||||||
elif [ "$tool" = "phive" ]; then
|
|
||||||
add_extension curl extension >/dev/null 2>&1
|
|
||||||
add_extension mbstring extension >/dev/null 2>&1
|
|
||||||
add_extension xml extension >/dev/null 2>&1
|
|
||||||
elif [[ "$tool" =~ (symfony|vapor|wp)-cli ]]; then
|
|
||||||
sudo ln -s "${tool_path:?}" "${tool_path_dir:?}"/${tool%-*}
|
|
||||||
fi
|
|
||||||
}
|
|
@ -1,19 +1,21 @@
|
|||||||
# Function to add blackfire cli.
|
# Function to add blackfire and blackfire-agent.
|
||||||
Function Add-Blackfire() {
|
Function Add-Blackfire() {
|
||||||
$arch_name ='amd64'
|
$arch_name ='amd64'
|
||||||
if(-not([Environment]::Is64BitOperatingSystem) -or $version -lt '7.0') {
|
if(-not([Environment]::Is64BitOperatingSystem) -or $version -lt '7.0') {
|
||||||
$arch_name = '386'
|
$arch_name = '386'
|
||||||
}
|
}
|
||||||
$cli_version = (Invoke-RestMethod https://blackfire.io/api/v1/releases).cli
|
$agent_version = (Invoke-RestMethod https://blackfire.io/api/v1/releases).agent
|
||||||
$url = "https://packages.blackfire.io/binaries/blackfire/${cli_version}/blackfire-windows_${arch_name}.zip"
|
$url = "https://packages.blackfire.io/binaries/blackfire-agent/${agent_version}/blackfire-agent-windows_${arch_name}.zip"
|
||||||
Invoke-WebRequest -Uri $url -OutFile $bin_dir\blackfire.zip >$null 2>&1
|
Invoke-WebRequest -Uri $url -OutFile $bin_dir\blackfire.zip >$null 2>&1
|
||||||
Expand-Archive -Path $bin_dir\blackfire.zip -DestinationPath $bin_dir -Force >$null 2>&1
|
Expand-Archive -Path $bin_dir\blackfire.zip -DestinationPath $bin_dir -Force >$null 2>&1
|
||||||
Add-ToProfile $current_profile 'blackfire' "New-Alias blackfire $bin_dir\blackfire.exe"
|
Add-ToProfile $current_profile 'blackfire' "New-Alias blackfire $bin_dir\blackfire.exe"
|
||||||
|
Add-ToProfile $current_profile 'blackfire-agent' "New-Alias blackfire-agent $bin_dir\blackfire-agent.exe"
|
||||||
if ((Test-Path env:BLACKFIRE_SERVER_ID) -and (Test-Path env:BLACKFIRE_SERVER_TOKEN)) {
|
if ((Test-Path env:BLACKFIRE_SERVER_ID) -and (Test-Path env:BLACKFIRE_SERVER_TOKEN)) {
|
||||||
blackfire agent:config --server-id=$env:BLACKFIRE_SERVER_ID --server-token=$env:BLACKFIRE_SERVER_TOKEN >$null 2>&1
|
blackfire-agent --register --server-id=$env:BLACKFIRE_SERVER_ID --server-token=$env:BLACKFIRE_SERVER_TOKEN >$null 2>&1
|
||||||
}
|
}
|
||||||
if ((Test-Path env:BLACKFIRE_CLIENT_ID) -and (Test-Path env:BLACKFIRE_CLIENT_TOKEN)) {
|
if ((Test-Path env:BLACKFIRE_CLIENT_ID) -and (Test-Path env:BLACKFIRE_CLIENT_TOKEN)) {
|
||||||
blackfire client:config --client-id=$env:BLACKFIRE_CLIENT_ID --client-token=$env:BLACKFIRE_CLIENT_TOKEN --ca-cert=$php_dir\ssl\cacert.pem >$null 2>&1
|
blackfire config --client-id=$env:BLACKFIRE_CLIENT_ID --client-token=$env:BLACKFIRE_CLIENT_TOKEN --ca-cert=$php_dir\ssl\cacert.pem >$null 2>&1
|
||||||
}
|
}
|
||||||
Add-Log $tick "blackfire" "Added blackfire $cli_version"
|
Add-Log $tick "blackfire" "Added blackfire $agent_version"
|
||||||
|
Add-Log $tick "blackfire-agent" "Added blackfire-agent $agent_version"
|
||||||
}
|
}
|
||||||
|
@ -1,34 +1,29 @@
|
|||||||
add_blackfire_linux() {
|
add_blackfire_linux() {
|
||||||
sudo mkdir -p /var/run/blackfire
|
sudo mkdir -p /var/run/blackfire
|
||||||
add_list debian/blackfire http://packages.blackfire.io/debian https://packages.blackfire.io/gpg.key any main
|
get -s -n "" https://packages.blackfire.io/gpg.key | sudo apt-key add -
|
||||||
install_packages blackfire
|
echo "deb http://packages.blackfire.io/debian any main" | sudo tee /etc/apt/sources.list.d/blackfire.list
|
||||||
|
sudo "${debconf_fix:?}" apt-get update
|
||||||
|
${apt_install:?} blackfire-agent
|
||||||
}
|
}
|
||||||
|
|
||||||
add_blackfire_darwin() {
|
add_blackfire_darwin() {
|
||||||
sudo mkdir -p /usr/local/var/run
|
sudo mkdir -p /usr/local/var/run
|
||||||
add_brew_tap blackfireio/homebrew-blackfire
|
brew tap --shallow blackfireio/homebrew-blackfire
|
||||||
brew install blackfire
|
brew install blackfire-agent
|
||||||
}
|
}
|
||||||
|
|
||||||
blackfire_config() {
|
blackfire_config() {
|
||||||
if [[ -n $BLACKFIRE_SERVER_ID ]] && [[ -n $BLACKFIRE_SERVER_TOKEN ]]; then
|
if [[ -n $BLACKFIRE_SERVER_ID ]] && [[ -n $BLACKFIRE_SERVER_TOKEN ]]; then
|
||||||
blackfire agent:config --server-id="$BLACKFIRE_SERVER_ID" --server-token="$BLACKFIRE_SERVER_TOKEN"
|
sudo blackfire-agent --register --server-id="$BLACKFIRE_SERVER_ID" --server-token="$BLACKFIRE_SERVER_TOKEN"
|
||||||
if [ "$os" = "Linux" ]; then
|
[ "$os" = "Linux" ] && sudo /etc/init.d/blackfire-agent restart
|
||||||
if [ -d /run/systemd/system ]; then
|
[ "$os" = "Darwin" ] && brew services start blackfire-agent
|
||||||
sudo systemctl start blackfire-agent
|
|
||||||
else
|
|
||||||
sudo service blackfire-agent start
|
|
||||||
fi
|
|
||||||
elif [ "$os" = "Darwin" ]; then
|
|
||||||
brew services start blackfire
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
if [[ -n $BLACKFIRE_CLIENT_ID ]] && [[ -n $BLACKFIRE_CLIENT_TOKEN ]]; then
|
if [[ -n $BLACKFIRE_CLIENT_ID ]] && [[ -n $BLACKFIRE_CLIENT_TOKEN ]]; then
|
||||||
blackfire client:config --client-id="$BLACKFIRE_CLIENT_ID" --client-token="$BLACKFIRE_CLIENT_TOKEN"
|
blackfire config --client-id="$BLACKFIRE_CLIENT_ID" --client-token="$BLACKFIRE_CLIENT_TOKEN"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to add blackfire cli.
|
# Function to add blackfire and blackfire-agent.
|
||||||
add_blackfire() {
|
add_blackfire() {
|
||||||
os="$(uname -s)"
|
os="$(uname -s)"
|
||||||
[ "$os" = "Linux" ] && add_blackfire_linux >/dev/null 2>&1
|
[ "$os" = "Linux" ] && add_blackfire_linux >/dev/null 2>&1
|
||||||
@ -36,4 +31,5 @@ add_blackfire() {
|
|||||||
blackfire_config >/dev/null 2>&1
|
blackfire_config >/dev/null 2>&1
|
||||||
tool_version=$(get_tool_version "blackfire" "version")
|
tool_version=$(get_tool_version "blackfire" "version")
|
||||||
add_log "${tick:?}" "blackfire" "Added blackfire $tool_version"
|
add_log "${tick:?}" "blackfire" "Added blackfire $tool_version"
|
||||||
|
add_log "${tick:?}" "blackfire-agent" "Added blackfire-agent $tool_version"
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
add_bazel() {
|
add_bazel() {
|
||||||
if ! command -v bazel; then
|
if ! command -v bazel; then
|
||||||
if [ "$(uname -s)" = "Linux" ]; then
|
if [ "$(uname -s)" = "Linux" ]; then
|
||||||
add_list bazel/apt https://storage.googleapis.com/bazel-apt https://bazel.build/bazel-release.pub.gpg stable jdk1.8
|
${apt_install:?} curl gnupg
|
||||||
install_packages bazel
|
get -s -n "" https://bazel.build/bazel-release.pub.gpg | sudo apt-key add -
|
||||||
|
echo "deb [arch=amd64] https://storage.googleapis.com/bazel-apt stable jdk1.8" | sudo tee /etc/apt/sources.list.d/bazel.list
|
||||||
|
sudo "${debconf_fix:?}" apt-get update -y
|
||||||
|
${apt_install:?} bazel
|
||||||
else
|
else
|
||||||
brew install bazel
|
brew install bazel
|
||||||
fi
|
fi
|
||||||
@ -11,48 +14,36 @@ add_bazel() {
|
|||||||
|
|
||||||
get_grpc_tag() {
|
get_grpc_tag() {
|
||||||
if [ "$grpc_tag" = "latest" ]; then
|
if [ "$grpc_tag" = "latest" ]; then
|
||||||
grpc_tag=$(get -s -n "" https://github.com/grpc/grpc/releases/latest | grep -Eo -m 1 "v[0-9]+\.[0-9]+\.[0-9]+" | head -n 1)
|
grpc_tag=$(get -s -n "" https://grpc.io/release)
|
||||||
else
|
else
|
||||||
if [[ ${grpc_tag:0:1} != "v" ]] ; then grpc_tag="v$grpc_tag"; fi
|
status_code=$(get -v -n /tmp/grpc.tmp "https://github.com/grpc/grpc/releases/tag/v$grpc_tag")
|
||||||
status_code=$(get -v -n /tmp/grpc.tmp "https://github.com/grpc/grpc/releases/tag/$grpc_tag")
|
if [ "$status_code" = "200" ]; then
|
||||||
if [ "$status_code" != "200" ]; then
|
grpc_tag="v$grpc_tag"
|
||||||
grpc_tag=$(get -s -n "" https://github.com/grpc/grpc/releases/latest | grep -Eo -m 1 "v[0-9]+\.[0-9]+\.[0-9]+" | head -n 1)
|
else
|
||||||
|
grpc_tag=$(get -s -n "" https://grpc.io/release)
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
add_grpc_php_plugin_brew() {
|
|
||||||
brew install grpc
|
|
||||||
brew link --force --overwrite grpc >/dev/null 2>&1
|
|
||||||
grpc_tag="v$(brew info grpc | grep "grpc:" | grep -Eo "[0-9]+\.[0-9]+\.[0-9]+")"
|
|
||||||
license_path="$(brew --prefix grpc)/LICENSE"
|
|
||||||
}
|
|
||||||
|
|
||||||
add_grpc_php_plugin_compile() {
|
|
||||||
get_grpc_tag
|
|
||||||
get -s -n "" "https://github.com/grpc/grpc/archive/$grpc_tag.tar.gz" | tar -xz -C /tmp
|
|
||||||
export DISABLE_BAZEL_WRAPPER=1
|
|
||||||
(
|
|
||||||
cd "/tmp/grpc-${grpc_tag:1}" || exit
|
|
||||||
add_bazel
|
|
||||||
./tools/bazel build src/compiler:grpc_php_plugin
|
|
||||||
sudo mv ./bazel-bin/src/compiler/grpc_php_plugin /usr/local/bin/grpc_php_plugin
|
|
||||||
sudo chmod a+x /usr/local/bin/grpc_php_plugin
|
|
||||||
license_path="/tmp/grpc-${grpc_tag:1}/LICENSE"
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
add_grpc_php_plugin() {
|
add_grpc_php_plugin() {
|
||||||
grpc_tag=$1
|
grpc_tag=$1
|
||||||
license_path=""
|
get_grpc_tag
|
||||||
if [ "$grpc_tag" = "latest" ]; then
|
(
|
||||||
add_grpc_php_plugin_brew >/dev/null 2>&1
|
get -s -n "" "https://github.com/grpc/grpc/archive/$grpc_tag.tar.gz" | tar -xz -C /tmp
|
||||||
|
cd "/tmp/grpc-${grpc_tag:1}" || exit
|
||||||
|
add_bazel
|
||||||
|
[ "$(uname -s)" = "Darwin" ] && sudo xcode-select -s /Applications/Xcode_11.7.app
|
||||||
|
if [ "$DISTRIB_RELEASE" = "16.04" ]; then
|
||||||
|
CC="$(command -v gcc)" CXX="$(command -v g++)" ./tools/bazel build src/compiler:grpc_php_plugin
|
||||||
else
|
else
|
||||||
add_grpc_php_plugin_compile >/dev/null 2>&1
|
./tools/bazel build src/compiler:grpc_php_plugin
|
||||||
fi
|
fi
|
||||||
echo "::set-output name=grpc_php_plugin_path::$(command -v grpc_php_plugin)"
|
sudo mv ./bazel-bin/src/compiler/grpc_php_plugin /usr/local/bin/grpc_php_plugin
|
||||||
|
sudo chmod a+x /usr/local/bin/grpc_php_plugin
|
||||||
|
) >/dev/null 2>&1
|
||||||
|
echo "::set-output name=grpc_php_plugin_path::/usr/local/bin/grpc_php_plugin"
|
||||||
add_log "${tick:?}" "grpc_php_plugin" "Added grpc_php_plugin ${grpc_tag:1}"
|
add_log "${tick:?}" "grpc_php_plugin" "Added grpc_php_plugin ${grpc_tag:1}"
|
||||||
printf "::group::\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "grpc_php_plugin" "Click to read the grpc_php_plugin related license information"
|
printf "::group::\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "grpc_php_plugin" "Click to read the grpc_php_plugin related license information"
|
||||||
cat "$license_path"
|
cat "/tmp/grpc-${grpc_tag:1}/LICENSE"
|
||||||
echo "::endgroup::"
|
echo "::endgroup::"
|
||||||
}
|
}
|
||||||
|
@ -1,151 +0,0 @@
|
|||||||
# Function to try to set ubuntu or debian version.
|
|
||||||
set_base_version_id() {
|
|
||||||
[[ "$ID" =~ ubuntu|debian ]] && return;
|
|
||||||
if ! [ -d "$dist_info_dir" ]; then
|
|
||||||
sudo mkdir -p "$dist_info_dir"
|
|
||||||
get -q -n "$dist_info_dir"/os_releases.csv https://raw.githubusercontent.com/shivammathur/setup-php/develop/src/configs/os_releases.csv
|
|
||||||
fi
|
|
||||||
for base in ubuntu debian; do
|
|
||||||
[[ "$ID_LIKE" =~ $base ]] && ID="$base" && VERSION_ID="$(grep -hr -m 1 "$VERSION_CODENAME" /usr/share/distro-info | cut -d ',' -f 1 | cut -d ' ' -f 1)" && break
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to try to set ubuntu or debian codename.
|
|
||||||
set_base_version_codename() {
|
|
||||||
[[ "$ID" =~ ubuntu|debian ]] && return;
|
|
||||||
if [[ "$ID_LIKE" =~ ubuntu ]]; then
|
|
||||||
[[ -n "$UBUNTU_CODENAME" ]] && VERSION_CODENAME="$UBUNTU_CODENAME" && return;
|
|
||||||
[ -e "$upstream_lsb" ] && VERSION_CODENAME=$(grep 'CODENAME' "$upstream_lsb" | cut -d '=' -f 2) && return;
|
|
||||||
VERSION_CODENAME=$(grep -E -m1 'deb .*ubuntu.com' "$list_file" | cut -d ' ' -f 3) && VERSION_CODENAME=${VERSION_CODENAME%-*}
|
|
||||||
elif [[ "$ID_LIKE" =~ debian ]] || command -v dpkg >/dev/null; then
|
|
||||||
ID_LIKE=debian
|
|
||||||
[[ -n "$DEBIAN_CODENAME" ]] && VERSION_CODENAME="$DEBIAN_CODENAME" && return;
|
|
||||||
update_lists && VERSION_CODENAME=$(apt-cache show tzdata | grep -m 1 Provides | cut -d '-' -f 2)
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to set base os details
|
|
||||||
set_base_version() {
|
|
||||||
if [ -e /tmp/os-release ]; then
|
|
||||||
. /tmp/os-release
|
|
||||||
else
|
|
||||||
set_base_version_codename
|
|
||||||
set_base_version_id
|
|
||||||
printf "ID=%s\nVERSION_ID=%s\nVERSION_CODENAME=%s\n" "$ID" "$VERSION_ID" "$VERSION_CODENAME" | tee /tmp/os-release >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Helper function to update package lists.
|
|
||||||
update_lists_helper() {
|
|
||||||
list=$1
|
|
||||||
command -v sudo >/dev/null && SUDO=sudo
|
|
||||||
if [[ -n "$list" ]]; then
|
|
||||||
${SUDO} apt-get update -o Dir::Etc::sourcelist="$list" -o Dir::Etc::sourceparts="-" -o APT::Get::List-Cleanup="0"
|
|
||||||
else
|
|
||||||
${SUDO} apt-get update
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to update the package lists.
|
|
||||||
update_lists() {
|
|
||||||
local ppa=${1:-}
|
|
||||||
local ppa_search=${2:-}
|
|
||||||
if [ ! -e /tmp/setup_php ] || [[ -n $ppa && -n $ppa_search ]]; then
|
|
||||||
if [[ -n "$ppa" && -n "$ppa_search" ]]; then
|
|
||||||
list="$list_dir"/"$(basename "$(grep -lr "$ppa_search" "$list_dir")")"
|
|
||||||
elif grep -Eq '^deb ' "$list_file"; then
|
|
||||||
list="$list_file"
|
|
||||||
fi
|
|
||||||
update_lists_helper "$list" >/dev/null 2>&1
|
|
||||||
echo '' | tee /tmp/setup_php >/dev/null 2>&1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get fingerprint from an Ubuntu PPA.
|
|
||||||
ubuntu_fingerprint() {
|
|
||||||
ppa=$1
|
|
||||||
get -s -n "" "$lp_api"/~"${ppa%/*}"/+archive/"${ppa##*/}" | jq -r '.signing_key_fingerprint'
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get fingerprint from a Debian PPA.
|
|
||||||
debian_fingerprint() {
|
|
||||||
ppa=$1
|
|
||||||
ppa_url=$2
|
|
||||||
package_dist=$3
|
|
||||||
release_pub=/tmp/"${ppa/\//-}".gpg
|
|
||||||
get -q -n "$release_pub" "$ppa_url"/dists/"$package_dist"/Release.gpg
|
|
||||||
gpg --list-packets "$release_pub" | grep -Eo 'fpr\sv4\s.*[a-zA-Z0-9]+' | head -n 1 | cut -d ' ' -f 3
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add a GPG key.
|
|
||||||
add_key() {
|
|
||||||
ppa=${1:-ondrej/php}
|
|
||||||
ppa_url=$2
|
|
||||||
package_dist=$3
|
|
||||||
key_source=$4
|
|
||||||
key_file=$5
|
|
||||||
key_urls=("$key_source")
|
|
||||||
if [[ "$key_source" =~ launchpad.net|debian.org|setup-php.com ]]; then
|
|
||||||
fingerprint="$("${ID}"_fingerprint "$ppa" "$ppa_url" "$package_dist")"
|
|
||||||
sks_params="op=get&options=mr&exact=on&search=0x$fingerprint"
|
|
||||||
key_urls=("${sks[@]/%/\/pks\/lookup\?"$sks_params"}")
|
|
||||||
fi
|
|
||||||
[ ! -e "$key_source" ] && get -q -n "$key_file" "${key_urls[@]}"
|
|
||||||
if [[ "$(file "$key_file")" =~ .*('Public-Key (old)'|'Secret-Key') ]]; then
|
|
||||||
sudo gpg --batch --yes --dearmor "$key_file" >/dev/null 2>&1 && sudo mv "$key_file".gpg "$key_file"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add a sources list.
|
|
||||||
add_list() {
|
|
||||||
ppa=${1-ondrej/php}
|
|
||||||
ppa_url=${2:-"$lp_ppa/$ppa/ubuntu"}
|
|
||||||
key_source=${3:-"$ppa_url"}
|
|
||||||
package_dist=${4:-"$VERSION_CODENAME"}
|
|
||||||
branches=${5:-main}
|
|
||||||
ppa_search="deb .*$ppa_url $package_dist .*$branches"
|
|
||||||
grep -Eqr "$ppa_search" "$list_dir" && echo "Repository $ppa already exists" && return;
|
|
||||||
arch=$(dpkg --print-architecture)
|
|
||||||
[ -e "$key_source" ] && key_file=$key_source || key_file="$key_dir"/"${ppa/\//-}"-keyring.gpg
|
|
||||||
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
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to remove a PPA.
|
|
||||||
remove_list() {
|
|
||||||
ppa=${1-ondrej/php}
|
|
||||||
ppa_url=${2:-"$lp_ppa/$ppa/ubuntu"}
|
|
||||||
grep -lr "$ppa_url" "$list_dir" | xargs -n1 sudo rm -f
|
|
||||||
sudo rm -f "$key_dir"/"${ppa/\//-}"-keyring || true
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to add a PPA.
|
|
||||||
add_ppa() {
|
|
||||||
set_base_version
|
|
||||||
ppa=${1:-ondrej/php}
|
|
||||||
if [[ "$ID" = "ubuntu" || "$ID_LIKE" =~ ubuntu ]] && [[ "$ppa" =~ "ondrej/" ]]; then
|
|
||||||
add_list "$ppa"
|
|
||||||
elif [[ "$ID" = "debian" || "$ID_LIKE" =~ debian ]] && [[ "$ppa" =~ "ondrej/" ]]; then
|
|
||||||
add_list "$ppa" "$sury"/"${ppa##*/}"/ "$sury"/"${ppa##*/}"/apt.gpg
|
|
||||||
else
|
|
||||||
add_list "$ppa"
|
|
||||||
fi
|
|
||||||
. /etc/os-release
|
|
||||||
}
|
|
||||||
|
|
||||||
# Variables
|
|
||||||
list_file='/etc/apt/sources.list'
|
|
||||||
list_dir="$list_file.d"
|
|
||||||
upstream_lsb='/etc/upstream-release/lsb-release'
|
|
||||||
lp_api='https://api.launchpad.net/1.0'
|
|
||||||
lp_ppa='http://ppa.launchpad.net'
|
|
||||||
key_dir='/usr/share/keyrings'
|
|
||||||
dist_info_dir='/usr/share/distro-info'
|
|
||||||
sury='https://packages.sury.org'
|
|
||||||
sks=(
|
|
||||||
'https://keyserver.ubuntu.com'
|
|
||||||
'https://pgp.mit.edu'
|
|
||||||
'https://keys.openpgp.org'
|
|
||||||
)
|
|
@ -19,7 +19,7 @@ add_protoc() {
|
|||||||
[ "$(uname -s)" = "Darwin" ] && platform='osx'
|
[ "$(uname -s)" = "Darwin" ] && platform='osx'
|
||||||
get -q -n /tmp/protobuf.zip "https://github.com/protocolbuffers/protobuf/releases/download/$protobuf_tag/protoc-${protobuf_tag:1}-$platform-x86_64.zip"
|
get -q -n /tmp/protobuf.zip "https://github.com/protocolbuffers/protobuf/releases/download/$protobuf_tag/protoc-${protobuf_tag:1}-$platform-x86_64.zip"
|
||||||
sudo unzip /tmp/protobuf.zip -d /usr/local/
|
sudo unzip /tmp/protobuf.zip -d /usr/local/
|
||||||
sudo chmod -R 777 /usr/local/bin/protoc /usr/local/include/google
|
sudo chmod 777 /usr/local/bin/protoc -R /usr/local/include/google
|
||||||
) >/dev/null 2>&1
|
) >/dev/null 2>&1
|
||||||
add_log "${tick:?}" "protoc" "Added protoc ${protobuf_tag:1}"
|
add_log "${tick:?}" "protoc" "Added protoc ${protobuf_tag:1}"
|
||||||
printf "::group::\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "protoc" "Click to read the protoc related license information"
|
printf "::group::\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "protoc" "Click to read the protoc related license information"
|
||||||
|
@ -3,12 +3,15 @@ param (
|
|||||||
[ValidateNotNull()]
|
[ValidateNotNull()]
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
[string]
|
[string]
|
||||||
$version = '8.0',
|
$version = '7.4',
|
||||||
[Parameter(Position = 1, Mandatory = $true)]
|
[Parameter(Position = 1, Mandatory = $true)]
|
||||||
[ValidateNotNull()]
|
[ValidateNotNull()]
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
[ValidateLength(1, [int]::MaxValue)]
|
||||||
[string]
|
[string]
|
||||||
$dist
|
$dist,
|
||||||
|
[Parameter(Position = 2, Mandatory = $false)]
|
||||||
|
[string]
|
||||||
|
$fail_fast = 'false'
|
||||||
)
|
)
|
||||||
|
|
||||||
# Function to log start of a operation.
|
# Function to log start of a operation.
|
||||||
@ -22,7 +25,7 @@ Function Add-Log($mark, $subject, $message) {
|
|||||||
printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" $mark $subject $message
|
printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" $mark $subject $message
|
||||||
} else {
|
} else {
|
||||||
printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" $mark $subject $message
|
printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" $mark $subject $message
|
||||||
if($env:fail_fast -eq 'true') {
|
if($fail_fast -eq 'true') {
|
||||||
exit 1;
|
exit 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -101,9 +104,7 @@ Function Install-PSPackage() {
|
|||||||
[Parameter(Position = 1, Mandatory = $true)]
|
[Parameter(Position = 1, Mandatory = $true)]
|
||||||
$psm1_path,
|
$psm1_path,
|
||||||
[Parameter(Position = 2, Mandatory = $true)]
|
[Parameter(Position = 2, Mandatory = $true)]
|
||||||
$url,
|
$url
|
||||||
[Parameter(Position = 3, Mandatory = $true)]
|
|
||||||
$cmdlet
|
|
||||||
)
|
)
|
||||||
$module_path = "$bin_dir\$psm1_path.psm1"
|
$module_path = "$bin_dir\$psm1_path.psm1"
|
||||||
if(-not (Test-Path $module_path -PathType Leaf)) {
|
if(-not (Test-Path $module_path -PathType Leaf)) {
|
||||||
@ -113,52 +114,6 @@ Function Install-PSPackage() {
|
|||||||
}
|
}
|
||||||
Import-Module $module_path
|
Import-Module $module_path
|
||||||
Add-ToProfile $current_profile "$package-search" "Import-Module $module_path"
|
Add-ToProfile $current_profile "$package-search" "Import-Module $module_path"
|
||||||
|
|
||||||
if($null -eq (Get-Command $cmdlet -ErrorAction SilentlyContinue)) {
|
|
||||||
Install-Module -Name $cmdlet -Force
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to link dependencies to PHP directory.
|
|
||||||
Function Set-ExtensionPrerequisites
|
|
||||||
{
|
|
||||||
Param (
|
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
|
||||||
[ValidateNotNull()]
|
|
||||||
[ValidateLength(1, [int]::MaxValue)]
|
|
||||||
[string]
|
|
||||||
$deps_dir
|
|
||||||
)
|
|
||||||
$deps = Get-ChildItem -Recurse -Path $deps_dir
|
|
||||||
if ($deps.Count -ne 0) {
|
|
||||||
# Symlink dependencies instead of adding the directory to PATH ...
|
|
||||||
# as other actions change the PATH thus breaking extensions.
|
|
||||||
$deps | ForEach-Object {
|
|
||||||
New-Item -Itemtype SymbolicLink -Path $php_dir -Name $_.Name -Target $_.FullName -Force > $null 2>&1
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Remove-Item $deps_dir -Recurse -Force
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
# Function to get extension pre-requisites.
|
|
||||||
# https://windows.php.net/downloads/pecl/deps
|
|
||||||
# Currently only imagick is supported using this Cmdlet.
|
|
||||||
Function Get-ExtensionPrerequisites{
|
|
||||||
Param (
|
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
|
||||||
[ValidateNotNull()]
|
|
||||||
[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.
|
||||||
@ -191,21 +146,18 @@ Function Add-Extension {
|
|||||||
Add-Log $tick $extension "Enabled"
|
Add-Log $tick $extension "Enabled"
|
||||||
}
|
}
|
||||||
default {
|
default {
|
||||||
$deps_dir = Get-ExtensionPrerequisites $extension
|
|
||||||
Enable-PhpExtension -Extension $extension_info.Handle -Path $php_dir
|
Enable-PhpExtension -Extension $extension_info.Handle -Path $php_dir
|
||||||
Set-ExtensionPrerequisites $deps_dir
|
|
||||||
Add-Log $tick $extension "Enabled"
|
Add-Log $tick $extension "Enabled"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$deps_dir = Get-ExtensionPrerequisites $extension
|
|
||||||
$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
|
Install-PhpExtension -Extension $extension -Version $extension_version -MinimumStability $stability -MaximumStability $stability -Path $php_dir
|
||||||
|
} else {
|
||||||
|
Install-PhpExtension -Extension $extension -MinimumStability $stability -MaximumStability $stability -Path $php_dir
|
||||||
}
|
}
|
||||||
Install-PhpExtension @params
|
|
||||||
Set-ExtensionPrerequisites $deps_dir
|
|
||||||
Add-Log $tick $extension "Installed and enabled"
|
Add-Log $tick $extension "Installed and enabled"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -238,7 +190,6 @@ Function Remove-Extension() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Function to configure composer.
|
|
||||||
Function Edit-ComposerConfig() {
|
Function Edit-ComposerConfig() {
|
||||||
Param(
|
Param(
|
||||||
[Parameter(Position = 0, Mandatory = $true)]
|
[Parameter(Position = 0, Mandatory = $true)]
|
||||||
@ -253,13 +204,10 @@ Function Edit-ComposerConfig() {
|
|||||||
Add-Log "$cross" "composer" "Could not download composer"
|
Add-Log "$cross" "composer" "Could not download composer"
|
||||||
exit 1;
|
exit 1;
|
||||||
}
|
}
|
||||||
if (-not(Test-Path $composer_json)) {
|
composer -q global config process-timeout 0
|
||||||
Set-Content -Path $composer_json -Value "{}"
|
|
||||||
}
|
|
||||||
composer -q config -g process-timeout 0
|
|
||||||
Write-Output $composer_bin | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8
|
Write-Output $composer_bin | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8
|
||||||
if (Test-Path env:COMPOSER_TOKEN) {
|
if (Test-Path env:COMPOSER_TOKEN) {
|
||||||
composer -q config -g github-oauth.github.com $env:COMPOSER_TOKEN
|
composer -q global config github-oauth.github.com $env:COMPOSER_TOKEN
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -271,16 +219,15 @@ Function Get-ToolVersion() {
|
|||||||
[Parameter(Position = 1, Mandatory = $true)]
|
[Parameter(Position = 1, Mandatory = $true)]
|
||||||
$param
|
$param
|
||||||
)
|
)
|
||||||
$alp = "[a-zA-Z0-9]"
|
$version_regex = "[0-9]+((\.{1}[0-9]+)+)(\.{0})(-[a-z0-9]+){0,1}"
|
||||||
$version_regex = "[0-9]+((\.{1}$alp+)+)(\.{0})(-$alp+){0,1}"
|
|
||||||
if($tool -eq 'composer') {
|
if($tool -eq 'composer') {
|
||||||
if ($param -eq 'snapshot') {
|
if ($param -eq 'snapshot') {
|
||||||
$composer_version = (Select-String -Pattern "const\sBRANCH_ALIAS_VERSION" -Path $bin_dir\composer -Raw | Select-String -Pattern $version_regex | ForEach-Object { $_.matches.Value }) + '+' + (Select-String -Pattern "const\sVERSION" -Path $bin_dir\composer -Raw | Select-String -Pattern "[a-zA-Z0-9]+" -AllMatches | ForEach-Object { $_.matches[2].Value })
|
$trunk = Select-String -Pattern "const\sBRANCH_ALIAS_VERSION" -Path $bin_dir\composer -Raw | Select-String -Pattern $version_regex | ForEach-Object { $_.matches.Value }
|
||||||
|
$commit = Select-String -Pattern "const\sVERSION" -Path $bin_dir\composer -Raw | Select-String -Pattern "[a-zA-Z0-9]+" -AllMatches | ForEach-Object { $_.matches[2].Value }
|
||||||
|
return "$trunk+$commit"
|
||||||
} else {
|
} else {
|
||||||
$composer_version = Select-String -Pattern "const\sVERSION" -Path $bin_dir\composer -Raw | Select-String -Pattern $version_regex | ForEach-Object { $_.matches.Value }
|
return Select-String -Pattern "const\sVERSION" -Path $bin_dir\composer -Raw | Select-String -Pattern $version_regex | ForEach-Object { $_.matches.Value }
|
||||||
}
|
}
|
||||||
Set-Variable -Name 'composer_version' -Value $composer_version -Scope Global
|
|
||||||
return "$composer_version"
|
|
||||||
}
|
}
|
||||||
return . $tool $param 2> $null | ForEach-Object { $_ -replace "composer $version_regex", '' } | Select-String -Pattern $version_regex | Select-Object -First 1 | ForEach-Object { $_.matches.Value }
|
return . $tool $param 2> $null | ForEach-Object { $_ -replace "composer $version_regex", '' } | Select-String -Pattern $version_regex | Select-Object -First 1 | ForEach-Object { $_.matches.Value }
|
||||||
}
|
}
|
||||||
@ -301,23 +248,22 @@ Function Add-Tool() {
|
|||||||
if (Test-Path $bin_dir\$tool) {
|
if (Test-Path $bin_dir\$tool) {
|
||||||
Remove-Item $bin_dir\$tool
|
Remove-Item $bin_dir\$tool
|
||||||
}
|
}
|
||||||
if($url.Count -gt 1) {
|
if($url.Count -gt 1) { $url = $url[0] }
|
||||||
$url = $url[0]
|
if ($tool -eq "symfony") {
|
||||||
}
|
Invoke-WebRequest -Uri $url -OutFile $bin_dir\$tool.exe
|
||||||
$tool_path = "$bin_dir\$tool"
|
Add-ToProfile $current_profile $tool "New-Alias $tool $bin_dir\$tool.exe" >$null 2>&1
|
||||||
if (($url | Split-Path -Extension) -eq ".exe") {
|
} else {
|
||||||
$tool_path = "$tool_path.exe"
|
|
||||||
}
|
|
||||||
try {
|
try {
|
||||||
Invoke-WebRequest -Uri $url -OutFile $tool_path
|
Invoke-WebRequest -Uri $url -OutFile $bin_dir\$tool
|
||||||
} catch {
|
} catch {
|
||||||
if($url -match '.*github.com.*releases.*latest.*') {
|
if($url -match '.*github.com.*releases.*latest.*') {
|
||||||
try {
|
try {
|
||||||
$url = $url.replace("releases/latest/download", "releases/download/" + ([regex]::match((Invoke-WebRequest -Uri ($url.split('/release')[0] + "/releases")).Content, "([0-9]+\.[0-9]+\.[0-9]+)/" + ($url.Substring($url.LastIndexOf("/") + 1))).Groups[0].Value).split('/')[0])
|
$url = $url.replace("releases/latest/download", "releases/download/" + ([regex]::match((Invoke-WebRequest -Uri ($url.split('/release')[0] + "/releases")).Content, "([0-9]+\.[0-9]+\.[0-9]+)/" + ($url.Substring($url.LastIndexOf("/") + 1))).Groups[0].Value).split('/')[0])
|
||||||
Invoke-WebRequest -Uri $url -OutFile $tool_path
|
Invoke-WebRequest -Uri $url -OutFile $bin_dir\$tool
|
||||||
} catch { }
|
} catch { }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (((Get-ChildItem -Path $bin_dir/* | Where-Object Name -Match "^$tool(.exe|.phar)*$").Count -gt 0)) {
|
if (((Get-ChildItem -Path $bin_dir/* | Where-Object Name -Match "^$tool(.exe|.phar)*$").Count -gt 0)) {
|
||||||
$bat_content = @()
|
$bat_content = @()
|
||||||
$bat_content += "@ECHO off"
|
$bat_content += "@ECHO off"
|
||||||
@ -325,8 +271,19 @@ Function Add-Tool() {
|
|||||||
$bat_content += "SET BIN_TARGET=%~dp0/" + $tool
|
$bat_content += "SET BIN_TARGET=%~dp0/" + $tool
|
||||||
$bat_content += "php %BIN_TARGET% %*"
|
$bat_content += "php %BIN_TARGET% %*"
|
||||||
Set-Content -Path $bin_dir\$tool.bat -Value $bat_content
|
Set-Content -Path $bin_dir\$tool.bat -Value $bat_content
|
||||||
Add-ToolsHelper $tool
|
|
||||||
Add-ToProfile $current_profile $tool "New-Alias $tool $bin_dir\$tool.bat" >$null 2>&1
|
Add-ToProfile $current_profile $tool "New-Alias $tool $bin_dir\$tool.bat" >$null 2>&1
|
||||||
|
if($tool -eq "phan") {
|
||||||
|
Add-Extension fileinfo >$null 2>&1
|
||||||
|
Add-Extension ast >$null 2>&1
|
||||||
|
} elseif($tool -eq "phive") {
|
||||||
|
Add-Extension xml >$null 2>&1
|
||||||
|
} elseif($tool -eq "cs2pr") {
|
||||||
|
(Get-Content $bin_dir/cs2pr).replace('exit(9)', 'exit(0)') | Set-Content $bin_dir/cs2pr
|
||||||
|
} elseif($tool -eq "composer") {
|
||||||
|
Edit-ComposerConfig $bin_dir\$tool
|
||||||
|
} elseif($tool -eq "wp-cli") {
|
||||||
|
Copy-Item $bin_dir\wp-cli.bat -Destination $bin_dir\wp.bat
|
||||||
|
}
|
||||||
$tool_version = Get-ToolVersion $tool $ver_param
|
$tool_version = Get-ToolVersion $tool $ver_param
|
||||||
Add-Log $tick $tool "Added $tool $tool_version"
|
Add-Log $tick $tool "Added $tool $tool_version"
|
||||||
} else {
|
} else {
|
||||||
@ -353,23 +310,13 @@ Function Add-Composertool() {
|
|||||||
[string]
|
[string]
|
||||||
$prefix
|
$prefix
|
||||||
)
|
)
|
||||||
if($tool -match "prestissimo|composer-prefetcher" -and $composer_version.split('.')[0] -ne "1") {
|
composer global require $prefix$release 2>&1 | out-null
|
||||||
Write-Output "::warning:: Skipping $tool, as it does not support Composer $composer_version. Specify composer:v1 in tools to use $tool"
|
|
||||||
Add-Log $cross $tool "Skipped"
|
|
||||||
Return
|
|
||||||
}
|
|
||||||
if(Test-Path $composer_lock) {
|
|
||||||
Remove-Item -Path $composer_lock -Force
|
|
||||||
}
|
|
||||||
(composer global require $prefix$release 2>&1 | Tee-Object -FilePath $env:APPDATA\Composer\composer.log) >$null 2>&1
|
|
||||||
$json = findstr $prefix$tool $env:APPDATA\Composer\composer.json
|
$json = findstr $prefix$tool $env:APPDATA\Composer\composer.json
|
||||||
$log = findstr $prefix$tool $env:APPDATA\Composer\composer.log
|
|
||||||
if(Test-Path $composer_bin\composer) {
|
if(Test-Path $composer_bin\composer) {
|
||||||
Copy-Item -Path "$bin_dir\composer" -Destination "$composer_bin\composer" -Force
|
Copy-Item -Path "$bin_dir\composer" -Destination "$composer_bin\composer" -Force
|
||||||
}
|
}
|
||||||
Add-ToolsHelper $tool
|
|
||||||
if($json) {
|
if($json) {
|
||||||
$tool_version = Get-ToolVersion "Write-Output" "$log"
|
$tool_version = Get-ToolVersion "Write-Output" "$json"
|
||||||
Add-Log $tick $tool "Added $tool $tool_version"
|
Add-Log $tick $tool "Added $tool $tool_version"
|
||||||
} else {
|
} else {
|
||||||
Add-Log $cross $tool "Could not setup $tool"
|
Add-Log $cross $tool "Could not setup $tool"
|
||||||
@ -387,15 +334,12 @@ $cross = ([char]10007)
|
|||||||
$php_dir = 'C:\tools\php'
|
$php_dir = 'C:\tools\php'
|
||||||
$ext_dir = "$php_dir\ext"
|
$ext_dir = "$php_dir\ext"
|
||||||
$bin_dir = $php_dir
|
$bin_dir = $php_dir
|
||||||
|
$bintray = 'https://dl.bintray.com/shivammathur/php'
|
||||||
$github = 'https://github.com'
|
$github = 'https://github.com'
|
||||||
$php_builder = "$github/shivammathur/php-builder-windows"
|
|
||||||
$composer_bin = "$env:APPDATA\Composer\vendor\bin"
|
$composer_bin = "$env:APPDATA\Composer\vendor\bin"
|
||||||
$composer_json = "$env:APPDATA\Composer\composer.json"
|
|
||||||
$composer_lock = "$env:APPDATA\Composer\composer.lock"
|
|
||||||
$current_profile = "$env:TEMP\setup-php.ps1"
|
$current_profile = "$env:TEMP\setup-php.ps1"
|
||||||
$ProgressPreference = 'SilentlyContinue'
|
$ProgressPreference = 'SilentlyContinue'
|
||||||
$jit_versions = '8.[0-9]'
|
$nightly_version = '8.[0-9]'
|
||||||
$nightly_versions = '8.[1-9]'
|
|
||||||
$cert_source='CurrentUser'
|
$cert_source='CurrentUser'
|
||||||
$enable_extensions = ('openssl', 'curl', 'mbstring')
|
$enable_extensions = ('openssl', 'curl', 'mbstring')
|
||||||
|
|
||||||
@ -434,11 +378,9 @@ if($env:RUNNER -eq 'self-hosted') {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
. $dist\..\src\scripts\tools\add_tools.ps1
|
|
||||||
|
|
||||||
Add-Printf >$null 2>&1
|
Add-Printf >$null 2>&1
|
||||||
Step-Log "Setup PhpManager"
|
Step-Log "Setup PhpManager"
|
||||||
Install-PSPackage PhpManager PhpManager\PhpManager "$github/mlocati/powershell-phpmanager/releases/latest/download/PhpManager.zip" Get-Php >$null 2>&1
|
Install-PSPackage PhpManager PhpManager\PhpManager "$github/mlocati/powershell-phpmanager/releases/latest/download/PhpManager.zip" >$null 2>&1
|
||||||
Add-Log $tick "PhpManager" "Installed"
|
Add-Log $tick "PhpManager" "Installed"
|
||||||
|
|
||||||
Step-Log "Setup PHP"
|
Step-Log "Setup PHP"
|
||||||
@ -449,24 +391,17 @@ if (Test-Path -LiteralPath $php_dir -PathType Container) {
|
|||||||
} catch { }
|
} catch { }
|
||||||
}
|
}
|
||||||
$status = "Installed"
|
$status = "Installed"
|
||||||
$extra_version = ""
|
|
||||||
if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version -replace '^(\d+(\.\d+)*).*', '$1.'))) -or $ts -ne $installed.ThreadSafe) {
|
if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version -replace '^(\d+(\.\d+)*).*', '$1.'))) -or $ts -ne $installed.ThreadSafe) {
|
||||||
if ($version -lt '7.0' -and (Get-InstalledModule).Name -notcontains 'VcRedist') {
|
if ($version -lt '7.0' -and (Get-InstalledModule).Name -notcontains 'VcRedist') {
|
||||||
Install-PSPackage VcRedist VcRedist-main\VcRedist\VcRedist "$github/aaronparker/VcRedist/archive/main.zip" Get-VcList >$null 2>&1
|
Install-PSPackage VcRedist VcRedist-main\VcRedist\VcRedist "$github/aaronparker/VcRedist/archive/main.zip" >$null 2>&1
|
||||||
}
|
}
|
||||||
try {
|
if ($version -match $nightly_version) {
|
||||||
if ($version -match $nightly_versions) {
|
Invoke-WebRequest -Uri $bintray/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 -Version $version > $null 2>&1
|
||||||
& $php_dir\Get-PhpNightly.ps1 -Architecture $arch -ThreadSafe $ts -Path $php_dir > $null 2>&1
|
|
||||||
$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 { }
|
|
||||||
} else {
|
} else {
|
||||||
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 }
|
|
||||||
}
|
|
||||||
if($env:update -eq 'true') {
|
if($env:update -eq 'true') {
|
||||||
Update-Php $php_dir >$null 2>&1
|
Update-Php $php_dir >$null 2>&1
|
||||||
$status = "Updated to"
|
$status = "Updated to"
|
||||||
@ -476,13 +411,9 @@ if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version
|
|||||||
}
|
}
|
||||||
|
|
||||||
$installed = Get-Php -Path $php_dir
|
$installed = Get-Php -Path $php_dir
|
||||||
if($installed.MajorMinorVersion -ne $version) {
|
('date.timezone=UTC', 'memory_limit=-1') | foreach { $p=$_.split('='); Set-PhpIniKey -Key $p[0] -Value $p[1] -Path $php_dir }
|
||||||
Add-Log $cross "PHP" "Could not setup PHP $version"
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
('date.timezone=UTC', 'memory_limit=-1', 'xdebug.mode=coverage') | ForEach-Object { $p=$_.split('='); Set-PhpIniKey -Key $p[0] -Value $p[1] -Path $php_dir }
|
|
||||||
if($version -lt "5.5") {
|
if($version -lt "5.5") {
|
||||||
('libeay32.dll', 'ssleay32.dll') | ForEach-Object { Invoke-WebRequest -Uri "$php_builder/releases/download/openssl-1.0.2u/$_" -OutFile $php_dir\$_ >$null 2>&1 }
|
('libeay32.dll', 'ssleay32.dll') | ForEach { Invoke-WebRequest -Uri $bintray/$_ -OutFile $php_dir\$_ >$null 2>&1 }
|
||||||
} else {
|
} else {
|
||||||
$enable_extensions += ('opcache')
|
$enable_extensions += ('opcache')
|
||||||
}
|
}
|
||||||
@ -490,5 +421,4 @@ Enable-PhpExtension -Extension $enable_extensions -Path $php_dir
|
|||||||
Update-PhpCAInfo -Path $php_dir -Source $cert_source
|
Update-PhpCAInfo -Path $php_dir -Source $cert_source
|
||||||
Copy-Item -Path $dist\..\src\configs\*.json -Destination $env:RUNNER_TOOL_CACHE
|
Copy-Item -Path $dist\..\src\configs\*.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 2>&1 | Out-Null
|
||||||
Write-Output "::set-output name=php-version::$($installed.FullVersion)"
|
Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)"
|
||||||
Add-Log $tick "PHP" "$status PHP $($installed.FullVersion)$extra_version"
|
|
||||||
|
948
src/tools.ts
948
src/tools.ts
File diff suppressed because it is too large
Load Diff
133
src/utils.ts
133
src/utils.ts
@ -1,8 +1,5 @@
|
|||||||
import {IncomingMessage, OutgoingHttpHeaders} from 'http';
|
|
||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
import * as https from 'https';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as url from 'url';
|
|
||||||
import * as core from '@actions/core';
|
import * as core from '@actions/core';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -11,16 +8,13 @@ import * as core from '@actions/core';
|
|||||||
* @param property
|
* @param property
|
||||||
*/
|
*/
|
||||||
export async function readEnv(property: string): Promise<string> {
|
export async function readEnv(property: string): Promise<string> {
|
||||||
const property_lc: string = property.toLowerCase();
|
const value = process.env[property];
|
||||||
const property_uc: string = property.toUpperCase();
|
switch (value) {
|
||||||
return (
|
case undefined:
|
||||||
process.env[property] ||
|
return '';
|
||||||
process.env[property_lc] ||
|
default:
|
||||||
process.env[property_uc] ||
|
return value;
|
||||||
process.env[property_lc.replace('_', '-')] ||
|
}
|
||||||
process.env[property_uc.replace('_', '-')] ||
|
|
||||||
''
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -47,63 +41,15 @@ export async function getInput(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Function to fetch an URL
|
|
||||||
*
|
|
||||||
* @param input_url
|
|
||||||
* @param auth_token
|
|
||||||
*/
|
|
||||||
export async function fetch(
|
|
||||||
input_url: string,
|
|
||||||
auth_token?: string
|
|
||||||
): Promise<Record<string, string>> {
|
|
||||||
const fetch_promise: Promise<Record<string, string>> = new Promise(
|
|
||||||
resolve => {
|
|
||||||
const url_object: url.UrlObject = new url.URL(input_url);
|
|
||||||
const headers: OutgoingHttpHeaders = {
|
|
||||||
'User-Agent': `Mozilla/5.0 (${process.platform} ${process.arch}) setup-php`
|
|
||||||
};
|
|
||||||
if (auth_token) {
|
|
||||||
headers.authorization = 'Bearer ' + auth_token;
|
|
||||||
}
|
|
||||||
const options: https.RequestOptions = {
|
|
||||||
hostname: url_object.hostname,
|
|
||||||
path: url_object.pathname,
|
|
||||||
headers: headers
|
|
||||||
};
|
|
||||||
const req = https.get(options, (res: IncomingMessage) => {
|
|
||||||
if (res.statusCode != 200) {
|
|
||||||
resolve({error: `${res.statusCode}: ${res.statusMessage}`});
|
|
||||||
} else {
|
|
||||||
let body = '';
|
|
||||||
res.setEncoding('utf8');
|
|
||||||
res.on('data', chunk => (body += chunk));
|
|
||||||
res.on('end', () => resolve({data: `${body}`}));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
req.end();
|
|
||||||
}
|
|
||||||
);
|
|
||||||
return await fetch_promise;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Function to get manifest URL
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
export async function getManifestURL(): Promise<string> {
|
|
||||||
return 'https://raw.githubusercontent.com/shivammathur/setup-php/develop/src/configs/php-versions.json';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function to parse PHP version.
|
* Function to parse PHP version.
|
||||||
*
|
*
|
||||||
* @param version
|
* @param version
|
||||||
*/
|
*/
|
||||||
export async function parseVersion(version: string): Promise<string> {
|
export async function parseVersion(version: string): Promise<string> {
|
||||||
const manifest = await getManifestURL();
|
switch (version) {
|
||||||
switch (true) {
|
case 'latest':
|
||||||
case /^(latest|\d+\.x)$/.test(version):
|
return '7.4';
|
||||||
return JSON.parse((await fetch(manifest))['data'])[version];
|
|
||||||
default:
|
default:
|
||||||
switch (true) {
|
switch (true) {
|
||||||
case version.length > 1:
|
case version.length > 1:
|
||||||
@ -239,14 +185,10 @@ export async function addLog(
|
|||||||
* Read the scripts
|
* Read the scripts
|
||||||
*
|
*
|
||||||
* @param filename
|
* @param filename
|
||||||
* @param directory
|
|
||||||
*/
|
*/
|
||||||
export async function readFile(
|
export async function readScript(filename: string): Promise<string> {
|
||||||
filename: string,
|
|
||||||
directory: string
|
|
||||||
): Promise<string> {
|
|
||||||
return fs.readFileSync(
|
return fs.readFileSync(
|
||||||
path.join(__dirname, '../' + directory, filename),
|
path.join(__dirname, '../src/scripts/' + filename),
|
||||||
'utf8'
|
'utf8'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -283,13 +225,11 @@ export async function extensionArray(
|
|||||||
return extension_csv
|
return extension_csv
|
||||||
.split(',')
|
.split(',')
|
||||||
.map(function (extension: string) {
|
.map(function (extension: string) {
|
||||||
if (/.+-.+\/.+@.+/.test(extension)) {
|
|
||||||
return extension;
|
|
||||||
}
|
|
||||||
return extension
|
return extension
|
||||||
.trim()
|
.trim()
|
||||||
.toLowerCase()
|
.toLowerCase()
|
||||||
.replace(/^php[-_]/, '');
|
.replace('php-', '')
|
||||||
|
.replace('php_', '');
|
||||||
})
|
})
|
||||||
.filter(Boolean);
|
.filter(Boolean);
|
||||||
}
|
}
|
||||||
@ -308,12 +248,9 @@ export async function CSVArray(values_csv: string): Promise<Array<string>> {
|
|||||||
return [];
|
return [];
|
||||||
default:
|
default:
|
||||||
return values_csv
|
return values_csv
|
||||||
.split(/,(?=(?:(?:[^"']*["']){2})*[^"']*$)/)
|
.split(',')
|
||||||
.map(function (value) {
|
.map(function (value: string) {
|
||||||
return value
|
return value.trim();
|
||||||
.trim()
|
|
||||||
.replace(/^["']|["']$|(?<==)["']/g, '')
|
|
||||||
.replace(/=(((?!E_).)*[?{}|&~![()^]+((?!E_).)+)/, "='$1'");
|
|
||||||
})
|
})
|
||||||
.filter(Boolean);
|
.filter(Boolean);
|
||||||
}
|
}
|
||||||
@ -325,11 +262,18 @@ export async function CSVArray(values_csv: string): Promise<Array<string>> {
|
|||||||
* @param extension
|
* @param extension
|
||||||
*/
|
*/
|
||||||
export async function getExtensionPrefix(extension: string): Promise<string> {
|
export async function getExtensionPrefix(extension: string): Promise<string> {
|
||||||
switch (true) {
|
const zend: Array<string> = [
|
||||||
|
'xdebug',
|
||||||
|
'xdebug3',
|
||||||
|
'opcache',
|
||||||
|
'ioncube',
|
||||||
|
'eaccelerator'
|
||||||
|
];
|
||||||
|
switch (zend.indexOf(extension)) {
|
||||||
default:
|
default:
|
||||||
return 'extension';
|
|
||||||
case /xdebug([2-3])?$|opcache|ioncube|eaccelerator/.test(extension):
|
|
||||||
return 'zend_extension';
|
return 'zend_extension';
|
||||||
|
case -1:
|
||||||
|
return 'extension';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -468,7 +412,7 @@ export async function customPackage(
|
|||||||
version: string,
|
version: string,
|
||||||
os_version: string
|
os_version: string
|
||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
const pkg_name: string = pkg.replace(/\d+|(pdo|pecl)[_-]/, '');
|
const pkg_name: string = pkg.replace(/\d+|pdo[_-]/, '');
|
||||||
const script_extension: string = await scriptExtension(os_version);
|
const script_extension: string = await scriptExtension(os_version);
|
||||||
const script: string = path.join(
|
const script: string = path.join(
|
||||||
__dirname,
|
__dirname,
|
||||||
@ -477,24 +421,3 @@ export async function customPackage(
|
|||||||
const command: string = await getCommand(os_version, pkg_name);
|
const command: string = await getCommand(os_version, pkg_name);
|
||||||
return '\n. ' + script + '\n' + command + version;
|
return '\n. ' + script + '\n' + command + version;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Function to extension input for installation from source.
|
|
||||||
*
|
|
||||||
* @param extension
|
|
||||||
* @param prefix
|
|
||||||
*/
|
|
||||||
export async function parseExtensionSource(
|
|
||||||
extension: string,
|
|
||||||
prefix: string
|
|
||||||
): Promise<string> {
|
|
||||||
// Groups: extension, domain url, org, repo, release
|
|
||||||
const regex = /(\w+)-(.+:\/\/.+(?:[.:].+)+\/)?([\w.-]+)\/([\w.-]+)@(.+)/;
|
|
||||||
const matches = regex.exec(extension) as RegExpExecArray;
|
|
||||||
matches[2] = matches[2] ? matches[2].slice(0, -1) : 'https://github.com';
|
|
||||||
return await joins(
|
|
||||||
'\nadd_extension_from_source',
|
|
||||||
...matches.splice(1, matches.length),
|
|
||||||
prefix
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
@ -1,18 +1,63 @@
|
|||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"esModuleInterop": true,
|
/* Basic Options */
|
||||||
"lib": [
|
// "incremental": true, /* Enable incremental compilation */
|
||||||
"ES2020"
|
"target": "ES2019", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */
|
||||||
],
|
"module": "commonjs", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */
|
||||||
"module": "commonjs",
|
// "allowJs": true, /* Allow javascript files to be compiled. */
|
||||||
"moduleResolution": "node",
|
// "checkJs": true, /* Report errors in .js files. */
|
||||||
"noImplicitAny": true,
|
// "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */
|
||||||
"outDir": "./lib",
|
// "declaration": true, /* Generates corresponding '.d.ts' file. */
|
||||||
"removeComments": true,
|
// "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */
|
||||||
"rootDir": "./src",
|
// "sourceMap": true, /* Generates corresponding '.map' file. */
|
||||||
"sourceMap": true,
|
// "outFile": "./", /* Concatenate and emit output to single file. */
|
||||||
"strict": true,
|
"outDir": "./lib", /* Redirect output structure to the directory. */
|
||||||
"target": "ES2019"
|
"rootDir": "./src", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */
|
||||||
|
// "composite": true, /* Enable project compilation */
|
||||||
|
// "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */
|
||||||
|
// "removeComments": true, /* Do not emit comments to output. */
|
||||||
|
// "noEmit": true, /* Do not emit outputs. */
|
||||||
|
// "importHelpers": true, /* Import emit helpers from 'tslib'. */
|
||||||
|
// "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
|
||||||
|
// "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */
|
||||||
|
|
||||||
|
/* Strict Type-Checking Options */
|
||||||
|
"strict": true, /* Enable all strict type-checking options. */
|
||||||
|
// "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */
|
||||||
|
// "strictNullChecks": true, /* Enable strict null checks. */
|
||||||
|
// "strictFunctionTypes": true, /* Enable strict checking of function types. */
|
||||||
|
// "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */
|
||||||
|
// "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */
|
||||||
|
// "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */
|
||||||
|
// "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */
|
||||||
|
|
||||||
|
/* Additional Checks */
|
||||||
|
// "noUnusedLocals": true, /* Report errors on unused locals. */
|
||||||
|
// "noUnusedParameters": true, /* Report errors on unused parameters. */
|
||||||
|
// "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */
|
||||||
|
// "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */
|
||||||
|
|
||||||
|
/* Module Resolution Options */
|
||||||
|
// "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */
|
||||||
|
// "baseUrl": "./", /* Base directory to resolve non-absolute module names. */
|
||||||
|
// "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */
|
||||||
|
// "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */
|
||||||
|
// "typeRoots": [], /* List of folders to include type definitions from. */
|
||||||
|
// "types": [], /* Type declaration files to be included in compilation. */
|
||||||
|
// "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */
|
||||||
|
"esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
|
||||||
|
// "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */
|
||||||
|
// "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */
|
||||||
|
|
||||||
|
/* Source Map Options */
|
||||||
|
// "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */
|
||||||
|
// "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */
|
||||||
|
// "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */
|
||||||
|
// "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */
|
||||||
|
|
||||||
|
/* Experimental Options */
|
||||||
|
// "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */
|
||||||
|
// "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */
|
||||||
},
|
},
|
||||||
"exclude": ["__tests__", "lib", "node_modules"]
|
"exclude": ["node_modules", "**/*.test.ts"]
|
||||||
}
|
}
|
Reference in New Issue
Block a user