From b44e5e009fa7f99378ce02ddb5cba90a2e5da2a8 Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Mon, 20 Jan 2020 21:07:51 +0530 Subject: [PATCH 1/9] Use ppa:ondrej/php for phalcon except for PHP7.4 --- __tests__/extensions.test.ts | 16 ++-------------- dist/index.js | 4 ++-- src/extensions.ts | 4 ++-- 3 files changed, 6 insertions(+), 18 deletions(-) diff --git a/__tests__/extensions.test.ts b/__tests__/extensions.test.ts index a89ed03f1..b17043a8b 100644 --- a/__tests__/extensions.test.ts +++ b/__tests__/extensions.test.ts @@ -41,22 +41,10 @@ describe('Extension tests', () => { linux = await extensions.addExtension('gearman', '7.1', 'linux'); expect(linux).toContain('gearman.sh 7.1'); - linux = await extensions.addExtension( - 'phalcon3, phalcon4, gearman', - '7.2', - 'linux' - ); - expect(linux).toContain('phalcon.sh phalcon3 7.2'); - expect(linux).toContain('phalcon.sh phalcon4 7.2'); + linux = await extensions.addExtension('gearman', '7.2', 'linux'); expect(linux).toContain('gearman.sh 7.2'); - linux = await extensions.addExtension( - 'phalcon3, phalcon4, gearman', - '7.3', - 'linux' - ); - expect(linux).toContain('phalcon.sh phalcon3 7.3'); - expect(linux).toContain('phalcon.sh phalcon4 7.3'); + linux = await extensions.addExtension('gearman', '7.3', 'linux'); expect(linux).toContain('gearman.sh 7.3'); linux = await extensions.addExtension('phalcon4, gearman', '7.4', 'linux'); diff --git a/dist/index.js b/dist/index.js index 82270d74b..3f0f69c6b 100644 --- a/dist/index.js +++ b/dist/index.js @@ -2676,8 +2676,8 @@ function addExtensionLinux(extension_csv, version, pipe) { '\n' + (yield utils.addLog('$tick', 'xdebug', 'Enabled', 'linux')); return; - // match 7.0phalcon3..7.3phalcon3 and 7.2phalcon4...7.4phalcon4 - case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): + // match 7.4phalcon4 + case /^7.4phalcon4$/.test(version_extension): script += '\nsh ' + path.join(__dirname, '../src/scripts/ext/phalcon.sh') + diff --git a/src/extensions.ts b/src/extensions.ts index dba19eda0..137a256eb 100644 --- a/src/extensions.ts +++ b/src/extensions.ts @@ -129,8 +129,8 @@ export async function addExtensionLinux( '\n' + (await utils.addLog('$tick', 'xdebug', 'Enabled', 'linux')); return; - // match 7.0phalcon3..7.3phalcon3 and 7.2phalcon4...7.4phalcon4 - case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): + // match 7.4phalcon4 + case /^7.4phalcon4$/.test(version_extension): script += '\nsh ' + path.join(__dirname, '../src/scripts/ext/phalcon.sh') + From e9c783eef06b9e1e1e4d8dde425101f072d32de8 Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Mon, 20 Jan 2020 21:50:44 +0530 Subject: [PATCH 2/9] Add support for specifying nts/ts builds on windows --- src/bin/php_pcov.dll | Bin 31744 -> 31744 bytes src/bin/php_ts_pcov.dll | Bin 0 -> 31744 bytes src/scripts/win32.ps1 | 16 ++++++++++++---- 3 files changed, 12 insertions(+), 4 deletions(-) create mode 100644 src/bin/php_ts_pcov.dll diff --git a/src/bin/php_pcov.dll b/src/bin/php_pcov.dll index f6becd738a53f397678bcdcad39ca238fef2198b..8c21d116c556388066303e0b8b99697a6bff44d9 100644 GIT binary patch literal 31744 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 XJ3IGv?(aO%8S4bgzdrvTH1NLx$!5Xk literal 31744 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

`y8>^x_^csKfnG;- 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 L^3Ui0q6GdI`&dAv literal 0 HcmV?d00001 diff --git a/src/scripts/win32.ps1 b/src/scripts/win32.ps1 index 0dea59bbd..e3b3f289a 100644 --- a/src/scripts/win32.ps1 +++ b/src/scripts/win32.ps1 @@ -156,7 +156,11 @@ $php_dir = 'C:\tools\php' $ext_dir = $php_dir + '\ext' $ProgressPreference = 'SilentlyContinue' $master_version = '8.0' -$arch='x64' +$arch = 'x64' +$ts = $false +if((Test-Path env:PHPTS) -and $env:PHPTS -eq 'ts') { + $ts = $true +} Step-Log "Setup PhpManager" Install-Module -Name PhpManager -Force -Scope CurrentUser @@ -172,7 +176,7 @@ if (Test-Path -LiteralPath $php_dir -PathType Container) { } Step-Log "Setup PHP" $status = "Installed" -if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version -replace '^(\d+(\.\d+)*).*', '$1.')))) { +if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version -replace '^(\d+(\.\d+)*).*', '$1.'))) -or $ts -ne $installed.ThreadSafe) { if ($version -lt '7.0') { Install-Module -Name VcRedist -Force $arch='x86' @@ -181,7 +185,7 @@ if ($null -eq $installed -or -not("$($installed.Version).".StartsWith(($version $version = 'master' } - Install-Php -Version $version -Architecture $arch -ThreadSafe $true -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 } else { $updated = Update-Php $php_dir >$null 2>&1 if($updated -eq $False) { @@ -194,7 +198,11 @@ Set-PhpIniKey -Key 'date.timezone' -Value 'UTC' -Path $php_dir Enable-PhpExtension -Extension openssl, curl, opcache -Path $php_dir Update-PhpCAInfo -Path $php_dir -Source CurrentUser if ($version -eq 'master') { - Copy-Item $dir"\..\src\bin\php_pcov.dll" -Destination $ext_dir"\php_pcov.dll" + if($installed.ThreadSafe) { + Copy-Item $dir"\..\src\bin\php_ts_pcov.dll" -Destination $ext_dir"\php_pcov.dll" + } else { + Copy-Item $dir"\..\src\bin\php_pcov.dll" -Destination $ext_dir"\php_pcov.dll" + } Set-PhpIniKey -Key 'opcache.jit_buffer_size' -Value '256M' -Path $php_dir Set-PhpIniKey -Key 'opcache.jit' -Value '1235' -Path $php_dir } From e58c704985c4140b785153975722cccea4e149ba Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Tue, 21 Jan 2020 00:50:38 +0530 Subject: [PATCH 3/9] Use ppa:ondrej/php for phalcon4 on PHP7.4 --- __tests__/extensions.test.ts | 3 +-- dist/index.js | 13 ------------- src/extensions.ts | 18 ------------------ 3 files changed, 1 insertion(+), 33 deletions(-) diff --git a/__tests__/extensions.test.ts b/__tests__/extensions.test.ts index b17043a8b..d00d51d6f 100644 --- a/__tests__/extensions.test.ts +++ b/__tests__/extensions.test.ts @@ -47,8 +47,7 @@ describe('Extension tests', () => { linux = await extensions.addExtension('gearman', '7.3', 'linux'); expect(linux).toContain('gearman.sh 7.3'); - linux = await extensions.addExtension('phalcon4, gearman', '7.4', 'linux'); - expect(linux).toContain('phalcon.sh phalcon4 7.4'); + linux = await extensions.addExtension('gearman', '7.4', 'linux'); expect(linux).toContain('gearman.sh 7.4'); linux = await extensions.addExtension('xdebug', '7.2', 'fedora'); diff --git a/dist/index.js b/dist/index.js index 3f0f69c6b..4315e3cc9 100644 --- a/dist/index.js +++ b/dist/index.js @@ -2676,19 +2676,6 @@ function addExtensionLinux(extension_csv, version, pipe) { '\n' + (yield utils.addLog('$tick', 'xdebug', 'Enabled', 'linux')); return; - // match 7.4phalcon4 - case /^7.4phalcon4$/.test(version_extension): - script += - '\nsh ' + - path.join(__dirname, '../src/scripts/ext/phalcon.sh') + - ' ' + - extension + - ' ' + - version + - pipe + - '\n' + - (yield utils.addLog('$tick', extension, 'Installed and enabled', 'linux')); - return; default: install_command = 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y php' + diff --git a/src/extensions.ts b/src/extensions.ts index 137a256eb..383a15d67 100644 --- a/src/extensions.ts +++ b/src/extensions.ts @@ -129,24 +129,6 @@ export async function addExtensionLinux( '\n' + (await utils.addLog('$tick', 'xdebug', 'Enabled', 'linux')); return; - // match 7.4phalcon4 - case /^7.4phalcon4$/.test(version_extension): - script += - '\nsh ' + - path.join(__dirname, '../src/scripts/ext/phalcon.sh') + - ' ' + - extension + - ' ' + - version + - pipe + - '\n' + - (await utils.addLog( - '$tick', - extension, - 'Installed and enabled', - 'linux' - )); - return; default: install_command = 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y php' + From 5108c81610a66cd1c39f93da20cc1335eff8c4d9 Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Tue, 21 Jan 2020 01:06:31 +0530 Subject: [PATCH 4/9] Add support for ext-imagick on darwin --- __tests__/extensions.test.ts | 8 ++++++++ dist/index.js | 7 +++++++ src/extensions.ts | 7 +++++++ 3 files changed, 22 insertions(+) diff --git a/__tests__/extensions.test.ts b/__tests__/extensions.test.ts index d00d51d6f..e48feb2ee 100644 --- a/__tests__/extensions.test.ts +++ b/__tests__/extensions.test.ts @@ -90,6 +90,14 @@ describe('Extension tests', () => { darwin = await extensions.addExtension('redis', '7.2', 'darwin'); expect(darwin).toContain('sudo pecl install redis'); + darwin = await extensions.addExtension('imagick', '5.6', 'darwin'); + expect(darwin).toContain('brew install pkg-config imagemagick'); + expect(darwin).toContain('sudo pecl install imagick'); + + darwin = await extensions.addExtension('imagick', '7.4', 'darwin'); + expect(darwin).toContain('brew install pkg-config imagemagick'); + expect(darwin).toContain('sudo pecl install imagick'); + darwin = await extensions.addExtension( 'does_not_exist', '7.2', diff --git a/dist/index.js b/dist/index.js index 4315e3cc9..60003b766 100644 --- a/dist/index.js +++ b/dist/index.js @@ -2577,6 +2577,13 @@ function addExtensionDarwin(extension_csv, version, pipe) { case /5\.6redis/.test(version_extension): install_command = 'sudo pecl install redis-2.2.8' + pipe; break; + case /[5-9]\.\dimagick/.test(version_extension): + install_command = + 'brew install pkg-config imagemagick' + + pipe + + ' && sudo pecl install imagick' + + pipe; + break; case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): install_command = 'sh ' + diff --git a/src/extensions.ts b/src/extensions.ts index 383a15d67..6b47e1193 100644 --- a/src/extensions.ts +++ b/src/extensions.ts @@ -30,6 +30,13 @@ export async function addExtensionDarwin( case /5\.6redis/.test(version_extension): install_command = 'sudo pecl install redis-2.2.8' + pipe; break; + case /[5-9]\.\dimagick/.test(version_extension): + install_command = + 'brew install pkg-config imagemagick' + + pipe + + ' && sudo pecl install imagick' + + pipe; + break; case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): install_command = 'sh ' + From 9d6b61c5af801dd3642ba6b53eeb8667b09d92cc Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Tue, 21 Jan 2020 01:40:24 +0530 Subject: [PATCH 5/9] Add support for phive --- __tests__/tools.test.ts | 30 +++++++++++++++++++++++++++--- dist/index.js | 28 ++++++++++++++++++++++++++++ src/scripts/darwin.sh | 5 +++++ src/scripts/linux.sh | 5 +++++ src/scripts/win32.ps1 | 5 +++++ src/tools.ts | 33 +++++++++++++++++++++++++++++++++ 6 files changed, 103 insertions(+), 3 deletions(-) diff --git a/__tests__/tools.test.ts b/__tests__/tools.test.ts index 4ccf9658c..dfb632a07 100644 --- a/__tests__/tools.test.ts +++ b/__tests__/tools.test.ts @@ -160,6 +160,18 @@ describe('Tools tests', () => { ); }); + it('checking addPhive', async () => { + let script: string = await tools.addPhive('1.2.3', 'linux'); + expect(script).toContain( + 'add_tool https://github.com/phar-io/phive/releases/download/1.2.3/phive-1.2.3.phar phive' + ); + + script = await tools.addPhive('latest', 'win32'); + expect(script).toContain( + 'Add-Tool https://phar.io/releases/phive.phar phive' + ); + }); + it('checking getPhpunitUri', async () => { expect(await tools.getPhpunitUrl('tool', 'latest')).toBe( 'https://phar.phpunit.de/tool.phar' @@ -289,7 +301,7 @@ describe('Tools tests', () => { it('checking addTools on linux', async () => { const script: string = await tools.addTools( - 'php-cs-fixer, phpstan, phpunit, pecl, phinx, phinx:1.2.3, php-config, phpize', + 'php-cs-fixer, phpstan, phpunit, pecl, phinx, phinx:1.2.3, phive, php-config, phpize', '7.4', 'linux' ); @@ -302,6 +314,9 @@ describe('Tools tests', () => { expect(script).toContain( 'add_tool https://github.com/phpstan/phpstan/releases/latest/download/phpstan.phar phpstan' ); + expect(script).toContain( + 'add_tool https://phar.io/releases/phive.phar phive' + ); expect(script).toContain( 'add_tool https://phar.phpunit.de/phpunit.phar phpunit' ); @@ -314,7 +329,7 @@ describe('Tools tests', () => { }); it('checking addTools on darwin', async () => { const script: string = await tools.addTools( - 'phpcs, phpcbf, phpcpd, phpmd, psalm, phinx, composer-prefetcher:1.2.3, phpize, php-config', + 'phpcs, phpcbf, phpcpd, phpmd, psalm, phinx, phive:1.2.3, composer-prefetcher:1.2.3, phpize, php-config', '7.4', 'darwin' ); @@ -337,6 +352,9 @@ describe('Tools tests', () => { 'https://github.com/vimeo/psalm/releases/latest/download/psalm.phar psalm' ); expect(script).toContain('add_composer_tool phinx phinx robmorgan/'); + expect(script).toContain( + 'add_tool https://github.com/phar-io/phive/releases/download/1.2.3/phive-1.2.3.phar phive' + ); expect(script).toContain( 'add_composer_tool composer-prefetcher composer-prefetcher:1.2.3 narrowspark/automatic-' ); @@ -345,7 +363,7 @@ describe('Tools tests', () => { }); it('checking addTools on windows', async () => { const script: string = await tools.addTools( - 'codeception, deployer, prestissimo, phpmd, phinx, php-config, phpize, does_not_exit', + 'codeception, deployer, prestissimo, phpmd, phinx, phive:0.13.2, php-config, phpize, does_not_exit', '7.4', 'win32' ); @@ -358,7 +376,13 @@ describe('Tools tests', () => { expect(script).toContain( 'Add-Composer-Tool prestissimo prestissimo hirak/' ); + expect(script).toContain( + 'Add-Tool https://github.com/phpmd/phpmd/releases/latest/download/phpmd.phar phpmd' + ); expect(script).toContain('Add-Composer-Tool phinx phinx robmorgan/'); + expect(script).toContain( + 'Add-Tool https://github.com/phar-io/phive/releases/download/0.13.2/phive-0.13.2.phar phive' + ); expect(script).toContain('phpize is not a windows tool'); expect(script).toContain('php-config is not a windows tool'); expect(script).toContain('Tool does_not_exit is not supported'); diff --git a/dist/index.js b/dist/index.js index 60003b766..b35cd40ed 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1731,6 +1731,31 @@ function getCodeceptionUri(version, php_version) { }); } exports.getCodeceptionUri = getCodeceptionUri; +/** + * Helper function to get script to setup phive + * + * @param tool + * @param version + * @param url + * @param os_version + */ +function addPhive(version, os_version) { + return __awaiter(this, void 0, void 0, function* () { + switch (version) { + case 'latest': + return ((yield getArchiveCommand(os_version)) + + 'https://phar.io/releases/phive.phar phive'); + default: + return ((yield getArchiveCommand(os_version)) + + 'https://github.com/phar-io/phive/releases/download/' + + version + + '/phive-' + + version + + '.phar phive'); + } + }); +} +exports.addPhive = addPhive; /** * Function to get the PHPUnit url * @@ -1888,6 +1913,9 @@ function addTools(tools_csv, php_version, os_version) { url = github + 'squizlabs/PHP_CodeSniffer/' + uri; script += yield addArchive(tool, version, url, os_version); break; + case 'phive': + script += yield addPhive(version, os_version); + break; case 'phpstan': url = github + 'phpstan/phpstan/' + uri; script += yield addArchive(tool, version, url, os_version); diff --git a/src/scripts/darwin.sh b/src/scripts/darwin.sh index 37e942385..c584da3af 100644 --- a/src/scripts/darwin.sh +++ b/src/scripts/darwin.sh @@ -67,6 +67,11 @@ add_tool() { add_log "$cross" "$tool" "Could not setup $tool" fi fi + if [ "$tool" = "phive" ]; then + add_extension curl >/dev/null 2>&1 + add_extension mbstring >/dev/null 2>&1 + add_extension xml >/dev/null 2>&1 + fi } add_composer_tool() { diff --git a/src/scripts/linux.sh b/src/scripts/linux.sh index 89ea04be9..fe2d28159 100644 --- a/src/scripts/linux.sh +++ b/src/scripts/linux.sh @@ -83,6 +83,11 @@ add_tool() { if [ "$tool" = "composer" ]; then composer -q global config process-timeout 0 fi + if [ "$tool" = "phive" ]; then + add_extension curl >/dev/null 2>&1 + add_extension mbstring >/dev/null 2>&1 + add_extension xml >/dev/null 2>&1 + fi } add_composer_tool() { diff --git a/src/scripts/win32.ps1 b/src/scripts/win32.ps1 index e3b3f289a..19772ade6 100644 --- a/src/scripts/win32.ps1 +++ b/src/scripts/win32.ps1 @@ -115,6 +115,11 @@ Function Add-Tool() { Add-Log $cross $tool "Could not add $tool" } } + if($tool -eq "phive") { + Add-Extension curl >$null 2>&1 + Add-Extension mbstring >$null 2>&1 + Add-Extension xml >$null 2>&1 + } } Function Add-Composer-Tool() { diff --git a/src/tools.ts b/src/tools.ts index d88e285c9..3a60f5f62 100644 --- a/src/tools.ts +++ b/src/tools.ts @@ -180,6 +180,36 @@ export async function getCodeceptionUri( } } +/** + * Helper function to get script to setup phive + * + * @param tool + * @param version + * @param url + * @param os_version + */ +export async function addPhive( + version: string, + os_version: string +): Promise { + switch (version) { + case 'latest': + return ( + (await getArchiveCommand(os_version)) + + 'https://phar.io/releases/phive.phar phive' + ); + default: + return ( + (await getArchiveCommand(os_version)) + + 'https://github.com/phar-io/phive/releases/download/' + + version + + '/phive-' + + version + + '.phar phive' + ); + } +} + /** * Function to get the PHPUnit url * @@ -354,6 +384,9 @@ export async function addTools( url = github + 'squizlabs/PHP_CodeSniffer/' + uri; script += await addArchive(tool, version, url, os_version); break; + case 'phive': + script += await addPhive(version, os_version); + break; case 'phpstan': url = github + 'phpstan/phpstan/' + uri; script += await addArchive(tool, version, url, os_version); From 747c8838bced7e7a6f9a10335079ac1e95138106 Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Tue, 21 Jan 2020 08:01:10 +0530 Subject: [PATCH 6/9] Add phive and ts support to readme --- README.md | 28 ++++++++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 40dae5ece..16c07f49f 100644 --- a/README.md +++ b/README.md @@ -28,7 +28,8 @@ Setup PHP with required extensions, php.ini configuration, code-coverage support - [Usage](#memo-usage) - [Basic Setup](#basic-setup) - [Matrix Setup](#matrix-setup) - - [Experimental Setup](#experimental-setup) + - [Experimental Setup](#experimental-setup) + - [Thread Safe Setup](#thread-safe-setup) - [Cache dependencies](#cache-dependencies) - [Problem Matchers](#problem-matchers) - [Examples](#examples) @@ -72,7 +73,7 @@ Setup PHP with required extensions, php.ini configuration, code-coverage support These tools can be setup globally using the `tools` input. -`codeception`, `composer`, `composer-prefetcher`, `deployer`, `pecl`, `phinx`, `phpcbf`, `phpcpd`, `php-config`, `php-cs-fixer`, `phpcs`, `phpize`, `phpmd`, `phpstan`, `phpunit`, `prestissimo`, `psalm` +`codeception`, `composer`, `composer-prefetcher`, `deployer`, `pecl`, `phinx`, `phive`, `phpcbf`, `phpcpd`, `php-config`, `php-cs-fixer`, `phpcs`, `phpize`, `phpmd`, `phpstan`, `phpunit`, `prestissimo`, `psalm` ```yaml uses: shivammathur/setup-php@v1 @@ -226,6 +227,29 @@ steps: tools: php-cs-fixer, phpunit #optional, setup tools globally ``` +### Thread Safe Setup + +- `NTS` versions are setup 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: Checkout + uses: actions/checkout@v2 + + - name: Setup PHP + uses: shivammathur/setup-php@v1 + with: + php-version: '7.4' + env: + PHPTS: ts # specify ts or nts +``` + ### Cache dependencies You can persist composer's internal cache directory using the [`action/cache`](https://github.com/actions/cache "GitHub Action to cache files") GitHub Action. Dependencies cached are loaded directly instead of downloading them while installation. The files cached are available across check-runs and will reduce the workflow execution time. From 898b6fa1f9b530e0d94f16ede4c66b00b4cab03e Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Tue, 21 Jan 2020 08:25:14 +0530 Subject: [PATCH 7/9] macOS-latest -> macos-latest --- .github/workflows/experimental-workflow.yml | 2 +- .github/workflows/workflow.yml | 2 +- README.md | 4 ++-- examples/cakephp.yml | 2 +- examples/codeigniter.yml | 2 +- examples/laravel.yml | 2 +- examples/lumen.yml | 2 +- examples/slim-framework.yml | 2 +- examples/symfony.yml | 2 +- examples/zend-framework.yml | 2 +- 10 files changed, 11 insertions(+), 11 deletions(-) diff --git a/.github/workflows/experimental-workflow.yml b/.github/workflows/experimental-workflow.yml index 4b3cc93a4..e18163947 100644 --- a/.github/workflows/experimental-workflow.yml +++ b/.github/workflows/experimental-workflow.yml @@ -25,7 +25,7 @@ jobs: strategy: fail-fast: false matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['8.0'] steps: - name: Checkout diff --git a/.github/workflows/workflow.yml b/.github/workflows/workflow.yml index e0a398ad8..35927cc6a 100644 --- a/.github/workflows/workflow.yml +++ b/.github/workflows/workflow.yml @@ -23,7 +23,7 @@ jobs: strategy: fail-fast: false matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4'] steps: - name: Checkout diff --git a/README.md b/README.md index 16c07f49f..882149029 100644 --- a/README.md +++ b/README.md @@ -60,7 +60,7 @@ Setup PHP with required extensions, php.ini configuration, code-coverage support |Windows Server 2019|`windows-latest` or `windows-2019`| |Ubuntu 18.04|`ubuntu-latest` or `ubuntu-18.04`| |Ubuntu 16.04|`ubuntu-16.04`| -|macOS X Catalina 10.15|`macOS-latest` or `macOS-10.15`| +|macOS X Catalina 10.15|`macos-latest` or `macOS-10.15`| ## :heavy_plus_sign: PHP Extension Support - On `ubuntu` by default extensions which are available as a package can be installed. If the extension is not available as a package but it is on `PECL`, it can be installed by specifying `pecl` in the tools input. @@ -185,7 +185,7 @@ jobs: runs-on: ${{ matrix.operating-system }} strategy: matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4'] name: PHP ${{ matrix.php-versions }} Test on ${{ matrix.operating-system }} steps: diff --git a/examples/cakephp.yml b/examples/cakephp.yml index e296a41f9..14a252cf9 100644 --- a/examples/cakephp.yml +++ b/examples/cakephp.yml @@ -6,7 +6,7 @@ jobs: tests: strategy: matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.2', '7.3', '7.4'] runs-on: ${{ matrix.operating-system }} steps: diff --git a/examples/codeigniter.yml b/examples/codeigniter.yml index 5ce0f81c3..2c0c535d0 100644 --- a/examples/codeigniter.yml +++ b/examples/codeigniter.yml @@ -5,7 +5,7 @@ jobs: build: strategy: matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.2', '7.3', '7.4'] runs-on: ${{ matrix.operating-system }} steps: diff --git a/examples/laravel.yml b/examples/laravel.yml index cf93fae04..d5b84465a 100644 --- a/examples/laravel.yml +++ b/examples/laravel.yml @@ -8,7 +8,7 @@ jobs: strategy: fail-fast: false matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.2', '7.3', '7.4'] steps: - name: Checkout diff --git a/examples/lumen.yml b/examples/lumen.yml index 389c1ed4e..0b7ae9bcd 100644 --- a/examples/lumen.yml +++ b/examples/lumen.yml @@ -8,7 +8,7 @@ jobs: strategy: fail-fast: false matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.2', '7.3', '7.4'] steps: - name: Checkout diff --git a/examples/slim-framework.yml b/examples/slim-framework.yml index 2716dfdf6..bea311602 100644 --- a/examples/slim-framework.yml +++ b/examples/slim-framework.yml @@ -5,7 +5,7 @@ jobs: build: strategy: matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.2', '7.3', '7.4'] runs-on: ${{ matrix.operating-system }} steps: diff --git a/examples/symfony.yml b/examples/symfony.yml index 25d40fde7..f171e9b64 100644 --- a/examples/symfony.yml +++ b/examples/symfony.yml @@ -8,7 +8,7 @@ jobs: strategy: fail-fast: false matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.3', '7.4'] steps: - name: Checkout diff --git a/examples/zend-framework.yml b/examples/zend-framework.yml index aad2f943d..150ee631b 100644 --- a/examples/zend-framework.yml +++ b/examples/zend-framework.yml @@ -5,7 +5,7 @@ jobs: build: strategy: matrix: - operating-system: [ubuntu-latest, windows-latest, macOS-latest] + operating-system: [ubuntu-latest, windows-latest, macos-latest] php-versions: ['7.2', '7.3', '7.4'] runs-on: ${{ matrix.operating-system }} steps: From 63c4aea452b5ab08840ed28c8f06182a952cc742 Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Tue, 21 Jan 2020 17:58:09 +0530 Subject: [PATCH 8/9] Refactor scripts to enable pre-existing ext-phalcon --- __tests__/extensions.test.ts | 4 ++ dist/index.js | 9 ++++ src/extensions.ts | 9 ++++ src/scripts/ext/phalcon.ps1 | 52 +++++++++++++----- src/scripts/ext/phalcon.sh | 90 +++++++++++++++++++++++++------ src/scripts/ext/phalcon_darwin.sh | 21 +++++++- 6 files changed, 152 insertions(+), 33 deletions(-) diff --git a/__tests__/extensions.test.ts b/__tests__/extensions.test.ts index e48feb2ee..1ffe93a56 100644 --- a/__tests__/extensions.test.ts +++ b/__tests__/extensions.test.ts @@ -52,6 +52,10 @@ describe('Extension tests', () => { linux = await extensions.addExtension('xdebug', '7.2', 'fedora'); expect(linux).toContain('Platform fedora is not supported'); + + linux = await extensions.addExtension('phalcon3, phalcon4', '7.3', 'linux'); + expect(linux).toContain('phalcon.sh phalcon3 7.3'); + expect(linux).toContain('phalcon.sh phalcon4 7.3'); }); it('checking addExtensionOnDarwin', async () => { diff --git a/dist/index.js b/dist/index.js index b35cd40ed..06fe5c7b4 100644 --- a/dist/index.js +++ b/dist/index.js @@ -2703,6 +2703,15 @@ function addExtensionLinux(extension_csv, version, pipe) { version + pipe; break; + case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): + script += + '\nsh ' + + path.join(__dirname, '../src/scripts/ext/phalcon.sh') + + ' ' + + extension + + ' ' + + version; + return; // match 7.0xdebug..7.4xdebug case /^7\.[0-4]xdebug$/.test(version_extension): script += diff --git a/src/extensions.ts b/src/extensions.ts index 6b47e1193..4168cfcdf 100644 --- a/src/extensions.ts +++ b/src/extensions.ts @@ -128,6 +128,15 @@ export async function addExtensionLinux( version + pipe; break; + case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): + script += + '\nsh ' + + path.join(__dirname, '../src/scripts/ext/phalcon.sh') + + ' ' + + extension + + ' ' + + version; + return; // match 7.0xdebug..7.4xdebug case /^7\.[0-4]xdebug$/.test(version_extension): script += diff --git a/src/scripts/ext/phalcon.ps1 b/src/scripts/ext/phalcon.ps1 index fb1dbe957..cc34f01b5 100644 --- a/src/scripts/ext/phalcon.ps1 +++ b/src/scripts/ext/phalcon.ps1 @@ -10,22 +10,46 @@ Param ( [string] $version ) + +Function Install-Phalcon() { + if ($extension_version -eq '4') { + Install-Phpextension phalcon -MinimumStability stable -Path $php_dir + } else { + $installed = Get-Php -Path $php_dir + $nts = if (!$installed.ThreadSafe) { "_nts" } else { "" } + $match = Invoke-WebRequest -UseBasicParsing -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 + Invoke-WebRequest -UseBasicParsing -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 + New-Item -ItemType SymbolicLink -Path $ext_dir\php_phalcon.dll -Target $ENV:RUNNER_TOOL_CACHE\phalcon\php_phalcon.dll > $null 2>&1 + Enable-PhpExtension -Extension phalcon -Path $php_dir + } + printf "\033[%s;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "32" $tick $extension "Installed and enabled" +} + $tick = ([char]8730) $domain = 'https://github.com' $php_dir = 'C:\tools\php' $ext_dir = $php_dir + '\ext' -Install-Phpextension psr -MinimumStability stable -Path $php_dir -if($extension -eq "phalcon4") { - Install-Phpextension phalcon -MinimumStability stable -Path $php_dir -} else { - $installed = Get-Php -Path $php_dir - $extension_version = $extension.substring($extension.Length - 1) - $nts = if(! $installed.ThreadSafe ) { "_nts" } else { "" } - $match = Invoke-WebRequest -UseBasicParsing -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 - Invoke-WebRequest -UseBasicParsing -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 - New-Item -ItemType SymbolicLink -Path $ext_dir\php_phalcon.dll -Target $ENV:RUNNER_TOOL_CACHE\phalcon\php_phalcon.dll >$null 2>&1 - Enable-PhpExtension -Extension phalcon -Path $php_dir +$extension_version = $extension.substring($extension.Length - 1) + +if($extension_version -eq '4') { + if (Test-Path $ext_dir\php_psr.dll) { + Enable-PhpExtension -Extension psr -Path $php_dir + } else { + Install-Phpextension psr -MinimumStability stable -Path $php_dir + } } -printf "\033[%s;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "32" $tick $extension "Installed and enabled" \ No newline at end of file + +if(Test-Path $ext_dir\php_phalcon.dll) { + $phalcon = Get-PhpExtension $ext_dir\php_phalcon.dll + if($phalcon.Version[0] -eq $extension_version) { + Enable-PhpExtension -Extension phalcon -Path $php_dir + printf "\033[%s;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s \033[0m\n" "32" $tick $extension "Enabled" + } else { + Remove-Item $ext_dir\php_phalcon.dll + Install-Phalcon + } +} else { + Install-Phalcon +} \ No newline at end of file diff --git a/src/scripts/ext/phalcon.sh b/src/scripts/ext/phalcon.sh index 92118fe6b..0783b7c88 100644 --- a/src/scripts/ext/phalcon.sh +++ b/src/scripts/ext/phalcon.sh @@ -1,22 +1,78 @@ +add_log() { + mark=$1 + subject=$2 + message=$3 + if [ "$mark" = "$tick" ]; then + printf "\033[32;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" + else + printf "\033[31;1m%s \033[0m\033[34;1m%s \033[0m\033[90;1m%s\033[0m\n" "$mark" "$subject" "$message" + fi +} + +update_ppa() { + if [ "$ppa_updated" = "false" ]; then + find /etc/apt/sources.list.d -type f -name 'ondrej-ubuntu-php*.list' -exec sudo DEBIAN_FRONTEND=noninteractive apt-get update -o Dir::Etc::sourcelist="{}" ';' >/dev/null 2>&1 + ppa_updated="true" + fi +} + +install_phalcon() { + extension=$1 + version=$2 + (sudo DEBIAN_FRONTEND=noninteractive apt-get install -y "php$version-$extension" >/dev/null 2>&1 && add_log "$tick" "$extension" "Installed and enabled") || + (update_ppa && sudo DEBIAN_FRONTEND=noninteractive apt-get install -y "php$version-$extension" >/dev/null 2>&1 && add_log "$tick" "$extension" "Installed and enabled") || + add_log "$cross" "$extension" "Could not install $extension on PHP $semver" +} + +remove_extension() { + extension=$1 + sudo sed -i "/$extension/d" "$ini_file" + rm -rf "$ext_dir/$extension.so" +} + ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") -find /etc/apt/sources.list.d -type f -name 'ondrej-ubuntu-php*.list' -exec sudo DEBIAN_FRONTEND=noninteractive apt-fast update -o Dir::Etc::sourcelist="{}" ';' >/dev/null 2>&1 -curl -s https://packagecloud.io/install/repositories/phalcon/stable/script.deb.sh | sudo bash -sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$2"-psr +ext_dir=$(php -i | grep "extension_dir => /usr" | sed -e "s|.*=> s*||") +semver=$(php -v | head -n 1 | cut -f 2 -d ' ' | cut -f 1 -d '-') +extension_major_version=$(echo "$1" | grep -i -Po '\d') +ppa_updated="false" +tick="✓" +cross="✗" -if [ ! "$(apt-cache search php"$2"-psr)" ]; then - sudo DEBIAN_FRONTEND=noninteractive apt-fast install -y php"$2"-dev - for tool in php-config phpize; do - if [ -e "/usr/bin/$tool$2" ]; then - sudo update-alternatives --set $tool /usr/bin/"$tool$2" +if [ "$extension_major_version" = "4" ]; then + if [ -e "$ext_dir/psr.so" ]; then + echo "extension=psr" >>"$ini_file" + fi + + if [ -e "$ext_dir/phalcon.so" ]; then + if php -m | grep -i -q -w psr; then + echo "extension=phalcon" >>"$ini_file" + phalcon_version=$(php -r "echo phpversion('phalcon');" | cut -d'.' -f 1) + if [ "$phalcon_version" != "$extension_major_version" ]; then + remove_extension "psr" >/dev/null 2>&1 + remove_extension "phalcon" >/dev/null 2>&1 + install_phalcon "$1" "$2" + else + add_log "$tick" "$1" "Enabled" + fi + else + install_phalcon "$1" "$2" fi - done - cd ~ && git clone --depth=1 https://github.com/jbboehr/php-psr.git - cd php-psr && sudo /usr/bin/phpize"$2" - ./configure --with-php-config=/usr/bin/php-config"$2" - make -j2 && sudo make -j2 install - echo "extension=psr.so" >> "$ini_file" + else + install_phalcon "$1" "$2" + fi fi -extension_major_version=$(echo "$1" | grep -i -Po '\d') -extension_version=$(apt-cache policy -- *phalcon | grep -i -Po "$extension_major_version\.\d\.\d.*php$2" | head -n 1) -sudo DEBIAN_FRONTEND=noninteractive apt-fast -o Dpkg::Options::="--force-overwrite" install -y php"$2"-phalcon="$extension_version" \ No newline at end of file +if [ "$extension_major_version" = "3" ]; then + if [ -e "$ext_dir/phalcon.so" ]; then + echo "extension=phalcon" >>"$ini_file" + phalcon_version=$(php -r "echo phpversion('phalcon');" | cut -d'.' -f 1) + if [ "$phalcon_version" != "$extension_major_version" ]; then + remove_extension "phalcon" >/dev/null 2>&1 + install_phalcon "$1" "$2" + else + add_log "$tick" "$1" "Enabled" + fi + else + install_phalcon "$1" "$2" + fi +fi diff --git a/src/scripts/ext/phalcon_darwin.sh b/src/scripts/ext/phalcon_darwin.sh index 3ad34a6c7..777ebd0be 100644 --- a/src/scripts/ext/phalcon_darwin.sh +++ b/src/scripts/ext/phalcon_darwin.sh @@ -1,5 +1,22 @@ extension=$1 extension_major=${extension: -1} php_version=$2 -brew tap shivammathur/homebrew-phalcon -brew install phalcon@"$php_version"_"$extension_major" \ No newline at end of file +ini_file=$(php -d "date.timezone=UTC" --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g") +ext_dir=$(php -i | grep "extension_dir => /usr" | sed -e "s|.*=> s*||") +if [ -e "$ext_dir/psr.so" ] && [ -e "$ext_dir/phalcon.so" ]; then + echo "extension=psr" >>"$ini_file" + echo "extension=phalcon" >>"$ini_file" + phalcon_semver=$(php -r "echo phpversion('phalcon');") + phalcon_version=$(echo "$phalcon_semver" | cut -d'.' -f 1) + if [ "$phalcon_version" != "$extension_major" ]; then + sudo sed -i '' "/psr/d" "$ini_file" + sudo sed -i '' "/phalcon/d" "$ini_file" + rm -rf "$ext_dir"/psr.so + rm -rf "$ext_dir"/phalcon.so + brew tap shivammathur/homebrew-phalcon + brew install phalcon@"$php_version"_"$extension_major" + fi +else + brew tap shivammathur/homebrew-phalcon + brew install phalcon@"$php_version"_"$extension_major" +fi \ No newline at end of file From 47335179aa3424ec39f660f4fb86db383f106bc6 Mon Sep 17 00:00:00 2001 From: Shivam Mathur Date: Wed, 22 Jan 2020 01:00:13 +0530 Subject: [PATCH 9/9] Bump version to 1.7.4 --- action.yml | 2 +- dist/index.js | 1 + package-lock.json | 82 +++++++++++++++++-------------------- package.json | 2 +- src/extensions.ts | 1 + src/scripts/ext/phalcon.ps1 | 1 + src/scripts/ext/phalcon.sh | 4 ++ 7 files changed, 46 insertions(+), 47 deletions(-) diff --git a/action.yml b/action.yml index 9799f0e85..335cb97ce 100644 --- a/action.yml +++ b/action.yml @@ -1,6 +1,6 @@ name: 'Setup PHP Action' author: shivammathur -description: 'GitHub action to setup PHP with required extensions, php.ini configuration, code-coverage support and composer' +description: 'Setup PHP in GitHub Actions with required extensions, php.ini configuration, code-coverage support and various tools like composer' branding: color: 'purple' inputs: diff --git a/dist/index.js b/dist/index.js index 06fe5c7b4..bdfc545ea 100644 --- a/dist/index.js +++ b/dist/index.js @@ -2703,6 +2703,7 @@ function addExtensionLinux(extension_csv, version, pipe) { version + pipe; break; + // match 7.0phalcon3...7.3phalcon3 or 7.2phalcon4...7.4phalcon4 case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): script += '\nsh ' + diff --git a/package-lock.json b/package-lock.json index 6ec5a6cb2..fc15eb5a6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "setup-php", - "version": "1.7.3", + "version": "1.7.4", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -691,9 +691,9 @@ "dev": true }, "@types/istanbul-lib-report": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-1.1.1.tgz", - "integrity": "sha512-3BUTyMzbZa2DtDI2BkERNC6jJw2Mr2Y0oGI7mRxYNBPxppbtEK1F66u3bKwU2g+wxwWI7PAoRpJnOY1grJqzHg==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", + "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", "dev": true, "requires": { "@types/istanbul-lib-coverage": "*" @@ -725,9 +725,9 @@ "dev": true }, "@types/node": { - "version": "12.12.24", - "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.24.tgz", - "integrity": "sha512-1Ciqv9pqwVtW6FsIUKSZNB82E5Cu1I2bBTj1xuIHXLe/1zYLl3956Nbhg2MzSYHVfl9/rmanjbQIb7LibfCnug==", + "version": "12.12.25", + "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.25.tgz", + "integrity": "sha512-nf1LMGZvgFX186geVZR1xMZKKblJiRfiASTHw85zED2kI1yDKHDwTKMdkaCbTlXoRKlGKaDfYywt+V0As30q3w==", "dev": true }, "@types/normalize-package-data": { @@ -758,12 +758,12 @@ "dev": true }, "@typescript-eslint/eslint-plugin": { - "version": "2.16.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.16.0.tgz", - "integrity": "sha512-TKWbeFAKRPrvKiR9GNxErQ8sELKqg1ZvXi6uho07mcKShBnCnqNpDQWP01FEvWKf0bxM2g7uQEI5MNjSNqvUpQ==", + "version": "2.17.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.17.0.tgz", + "integrity": "sha512-tg/OMOtPeXlvk0ES8mZzEZ4gd1ruSE03nsKcK+teJhxYv5CPCXK6Mb/OK6NpB4+CqGTHs4MVeoSZXNFqpT1PyQ==", "dev": true, "requires": { - "@typescript-eslint/experimental-utils": "2.16.0", + "@typescript-eslint/experimental-utils": "2.17.0", "eslint-utils": "^1.4.3", "functional-red-black-tree": "^1.0.1", "regexpp": "^3.0.0", @@ -771,32 +771,32 @@ } }, "@typescript-eslint/experimental-utils": { - "version": "2.16.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.16.0.tgz", - "integrity": "sha512-bXTmAztXpqxliDKZgvWkl+5dHeRN+jqXVZ16peKKFzSXVzT6mz8kgBpHiVzEKO2NZ8OCU7dG61K9sRS/SkUUFQ==", + "version": "2.17.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.17.0.tgz", + "integrity": "sha512-2bNf+mZ/3mj5/3CP56v+ldRK3vFy9jOvmCPs/Gr2DeSJh+asPZrhFniv4QmQsHWQFPJFWhFHgkGgJeRmK4m8iQ==", "dev": true, "requires": { "@types/json-schema": "^7.0.3", - "@typescript-eslint/typescript-estree": "2.16.0", + "@typescript-eslint/typescript-estree": "2.17.0", "eslint-scope": "^5.0.0" } }, "@typescript-eslint/parser": { - "version": "2.16.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.16.0.tgz", - "integrity": "sha512-+w8dMaYETM9v6il1yYYkApMSiwgnqXWJbXrA94LAWN603vXHACsZTirJduyeBOJjA9wT6xuXe5zZ1iCUzoxCfw==", + "version": "2.17.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.17.0.tgz", + "integrity": "sha512-k1g3gRQ4fwfJoIfgUpz78AovicSWKFANmvTfkAHP24MgJHjWfZI6ya7tsQZt1sLczvP4G9BE5G5MgADHdmJB/w==", "dev": true, "requires": { "@types/eslint-visitor-keys": "^1.0.0", - "@typescript-eslint/experimental-utils": "2.16.0", - "@typescript-eslint/typescript-estree": "2.16.0", + "@typescript-eslint/experimental-utils": "2.17.0", + "@typescript-eslint/typescript-estree": "2.17.0", "eslint-visitor-keys": "^1.1.0" } }, "@typescript-eslint/typescript-estree": { - "version": "2.16.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.16.0.tgz", - "integrity": "sha512-hyrCYjFHISos68Bk5KjUAXw0pP/455qq9nxqB1KkT67Pxjcfw+r6Yhcmqnp8etFL45UexCHUMrADHH7dI/m2WQ==", + "version": "2.17.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.17.0.tgz", + "integrity": "sha512-g0eVRULGnEEUakxRfJO0s0Hr1LLQqsI6OrkiCLpdHtdJJek+wyd8mb00vedqAoWldeDcOcP8plqw8/jx9Gr3Lw==", "dev": true, "requires": { "debug": "^4.1.1", @@ -857,12 +857,12 @@ "dev": true }, "ajv": { - "version": "6.10.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", - "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.11.0.tgz", + "integrity": "sha512-nCprB/0syFYy9fVYU1ox1l2KN8S9I+tziH8D4zdZuLT3N6RMlGSGt5FSTpAiHB/Whv8Qs1cWHma1aMKZyaHRKA==", "dev": true, "requires": { - "fast-deep-equal": "^2.0.1", + "fast-deep-equal": "^3.1.1", "fast-json-stable-stringify": "^2.0.0", "json-schema-traverse": "^0.4.1", "uri-js": "^4.2.2" @@ -1872,9 +1872,9 @@ } }, "es-abstract": { - "version": "1.17.2", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.2.tgz", - "integrity": "sha512-YoKuru3Lyoy7yVTBSH2j7UxTqe/je3dWAruC0sHvZX1GNd5zX8SSLvQqEgO9b3Ex8IW+goFI9arEEsFIbulhOw==", + "version": "1.17.4", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.4.tgz", + "integrity": "sha512-Ae3um/gb8F0mui/jPL+QiqmglkUsaQf7FwBEHYIFkztkneosu9imhqHpBzQ3h1vit8t5iQ74t6PEVvphBZiuiQ==", "dev": true, "requires": { "es-to-primitive": "^1.2.1", @@ -1908,24 +1908,16 @@ "dev": true }, "escodegen": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.12.1.tgz", - "integrity": "sha512-Q8t2YZ+0e0pc7NRVj3B4tSQ9rim1oi4Fh46k2xhJ2qOiEwhQfdjyEQddWdj7ZFaKmU+5104vn1qrcjEPWq+bgQ==", + "version": "1.13.0", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.13.0.tgz", + "integrity": "sha512-eYk2dCkxR07DsHA/X2hRBj0CFAZeri/LyDMc0C8JT1Hqi6JnVpMhJ7XFITbb0+yZS3lVkaPL2oCkZ3AVmeVbMw==", "dev": true, "requires": { - "esprima": "^3.1.3", + "esprima": "^4.0.1", "estraverse": "^4.2.0", "esutils": "^2.0.2", "optionator": "^0.8.1", "source-map": "~0.6.1" - }, - "dependencies": { - "esprima": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", - "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=", - "dev": true - } } }, "eslint": { @@ -2383,9 +2375,9 @@ "dev": true }, "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", + "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==", "dev": true }, "fast-diff": { diff --git a/package.json b/package.json index a9d2e35ac..5bf0ea653 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "setup-php", - "version": "1.7.3", + "version": "1.7.4", "private": false, "description": "Setup PHP for use with GitHub Actions", "main": "dist/index.js", diff --git a/src/extensions.ts b/src/extensions.ts index 4168cfcdf..28b3bedb7 100644 --- a/src/extensions.ts +++ b/src/extensions.ts @@ -128,6 +128,7 @@ export async function addExtensionLinux( version + pipe; break; + // match 7.0phalcon3...7.3phalcon3 or 7.2phalcon4...7.4phalcon4 case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$/.test(version_extension): script += '\nsh ' + diff --git a/src/scripts/ext/phalcon.ps1 b/src/scripts/ext/phalcon.ps1 index cc34f01b5..1a9f5fb61 100644 --- a/src/scripts/ext/phalcon.ps1 +++ b/src/scripts/ext/phalcon.ps1 @@ -11,6 +11,7 @@ Param ( $version ) +# Function to install phalcon Function Install-Phalcon() { if ($extension_version -eq '4') { Install-Phpextension phalcon -MinimumStability stable -Path $php_dir diff --git a/src/scripts/ext/phalcon.sh b/src/scripts/ext/phalcon.sh index 0783b7c88..5642f6f0f 100644 --- a/src/scripts/ext/phalcon.sh +++ b/src/scripts/ext/phalcon.sh @@ -1,3 +1,4 @@ +# Function to log result of a operation add_log() { mark=$1 subject=$2 @@ -9,6 +10,7 @@ add_log() { fi } +# Function to update php ppa update_ppa() { if [ "$ppa_updated" = "false" ]; then find /etc/apt/sources.list.d -type f -name 'ondrej-ubuntu-php*.list' -exec sudo DEBIAN_FRONTEND=noninteractive apt-get update -o Dir::Etc::sourcelist="{}" ';' >/dev/null 2>&1 @@ -16,6 +18,7 @@ update_ppa() { fi } +# Function to install phalcon install_phalcon() { extension=$1 version=$2 @@ -24,6 +27,7 @@ install_phalcon() { add_log "$cross" "$extension" "Could not install $extension on PHP $semver" } +# Function to remove an extensions remove_extension() { extension=$1 sudo sed -i "/$extension/d" "$ini_file"