Add support for php.ini customization and fix bugs

This commit is contained in:
Shivam Mathur 2019-09-18 07:40:09 +05:30
parent a398f54da4
commit e4a37d0f16
9 changed files with 112 additions and 34 deletions

View File

@ -21,10 +21,21 @@ jobs:
- name: Installing NPM - name: Installing NPM
run: npm install run: npm install
- name: Installing PHP - name: Installing PHP with extensions and custom config
run: node lib/install.js run: node lib/install.js
env: env:
php-version: ${{ matrix.php-versions }} php-version: ${{ matrix.php-versions }}
extension-csv: "mbstring, curl, mysqli, json, xml, xdebug, pcov, phpdbg" extension-csv: "mbstring, xdebug, pcov" #optional
- name: Testing ini-values-csv: "post_max_size=256M, short_open_tag=On, date.timezone=Asia/Kolkata" #optional
run: php -v && composer -V && php -m
- name: Testing PHP version
run: php -v
- name: Testing Composer version
run: composer -V
- name: Testing Extensions
run: php -m
- name: Testing ini values
run: |
php -r "echo \"post_max_size: \" . ini_get('post_max_size') . \"\n\";"
php -r "echo \"short_open_tag: \" . ini_get('short_open_tag') . \"\n\";"
php -r "echo \"date.timezone: \" . ini_get('date.timezone') . \"\n\";"

View File

@ -5,7 +5,7 @@
<a href="https://github.com/shivammathur/setup-php/blob/master/LICENSE"><img alt="LICENSE" src="https://img.shields.io/badge/license-MIT-428f7e.svg"></a> <a href="https://github.com/shivammathur/setup-php/blob/master/LICENSE"><img alt="LICENSE" src="https://img.shields.io/badge/license-MIT-428f7e.svg"></a>
</p> </p>
[GitHub Action](https://github.com/features/actions) to install PHP with required extensions and composer. This action can be added as a step in your action workflow and it will setup the PHP environment you need to test your application. Refer to [Usage](#usage) section to see how to use this. [GitHub Action](https://github.com/features/actions) to install PHP with required extensions, php.ini configuration and composer. This action can be added as a step in your action workflow and it will setup the PHP environment you need to test your application. Refer to [Usage](#usage) section to see how to use this.
## PHP Versions Support ## PHP Versions Support
- 5.6 - 5.6
@ -36,9 +36,15 @@
## Usage ## Usage
See [action.yml](action.yml) for inputs this action supports. Inputs supported by this GitHub Action.
### Basic - php-version
- extension-csv (optional)
- ini-values-csv (optional)
See [action.yml](action.yml) for more info
### Basic Usage
```yaml ```yaml
steps: steps:
@ -48,7 +54,8 @@ steps:
uses: shivammathur/setup-php@master uses: shivammathur/setup-php@master
with: with:
php-version: 7.3 php-version: 7.3
extension-csv: mbstring, xdebug extension-csv: mbstring, xdebug #optional
ini-values-csv: "post_max_size=256M, short_open_tag=On" #optional
- name: Check PHP Version - name: Check PHP Version
run: php -v run: php -v
- name: Check Composer Version - name: Check Composer Version
@ -76,7 +83,8 @@ jobs:
uses: shivammathur/setup-php@master uses: shivammathur/setup-php@master
with: with:
php-version: ${{ matrix.php-versions }} php-version: ${{ matrix.php-versions }}
extension-csv: mbstring, xdebug extension-csv: mbstring, xdebug #optional
ini-values-csv: "post_max_size=256M, short_open_tag=On" #optional
- name: Check PHP Version - name: Check PHP Version
run: php -v run: php -v
- name: Check Composer Version - name: Check Composer Version

View File

@ -11,6 +11,9 @@ inputs:
extension-csv: extension-csv:
description: '(Optional) Comma seperated list of PHP extensions to be installed.' description: '(Optional) Comma seperated list of PHP extensions to be installed.'
required: false required: false
ini-values-csv:
description: '(Optional) Custom values you want to set in php.ini'
required: false
runs: runs:
using: 'node12' using: 'node12'
main: 'lib/install.js' main: 'lib/install.js'

View File

@ -86,7 +86,7 @@ function addExtension(extension_csv, version) {
// else add script to attempt to install the extension // else add script to attempt to install the extension
if (os_version == 'linux') { if (os_version == 'linux') {
linux += linux +=
'sudo apt install -y php' + 'sudo DEBIAN_FRONTEND=noninteractive apt install -y php' +
version + version +
'-' + '-' +
extension + extension +
@ -129,7 +129,28 @@ function addExtension(extension_csv, version) {
} }
}); });
}); });
linux += 'sudo apt autoremove -y'; linux += 'sudo DEBIAN_FRONTEND=noninteractive apt autoremove -y';
});
}
/*
Add script to set custom ini values
*/
function addINIValues(ini_values_csv) {
return __awaiter(this, void 0, void 0, function* () {
let ini_values = ini_values_csv
.split(',')
.map(function (ini_value) {
return ini_value.trim();
});
yield asyncForEach(ini_values, function (ini_value) {
return __awaiter(this, void 0, void 0, function* () {
// add script to set ini value
linux += '\necho "' + ini_value + '" >> $ini_file';
darwin += '\necho "' + ini_value + '" >> $ini_file';
windows +=
'\nAdd-Content C:\\tools\\php$version\\php.ini "' + ini_value + '"';
});
});
}); });
} }
/* /*
@ -166,7 +187,7 @@ function run() {
if (!version) { if (!version) {
version = core.getInput('php-version', { required: true }); version = core.getInput('php-version', { required: true });
} }
console.log('Input: ' + version); console.log('Version: ' + version);
if (version == '7.4') { if (version == '7.4') {
darwin = fs.readFileSync(path.join(__dirname, '../src/7.4.sh'), 'utf8'); darwin = fs.readFileSync(path.join(__dirname, '../src/7.4.sh'), 'utf8');
} }
@ -175,9 +196,17 @@ function run() {
extension_csv = core.getInput('extension-csv'); extension_csv = core.getInput('extension-csv');
} }
if (extension_csv) { if (extension_csv) {
console.log('Input: ' + extension_csv); console.log('Extensions: ' + extension_csv);
yield addExtension(extension_csv, version); yield addExtension(extension_csv, version);
} }
let ini_values_csv = process.env['ini-values-csv'];
if (!ini_values_csv) {
ini_values_csv = core.getInput('ini-values-csv');
}
if (ini_values_csv) {
console.log('INI Values: ' + ini_values_csv);
yield addINIValues(ini_values_csv);
}
// check the os version and run the respective script // check the os version and run the respective script
if (os_version == 'darwin') { if (os_version == 'darwin') {
yield createScript('darwin.sh', version); yield createScript('darwin.sh', version);

2
package-lock.json generated
View File

@ -1,6 +1,6 @@
{ {
"name": "setup-php", "name": "setup-php",
"version": "1.2.1", "version": "1.3.0",
"lockfileVersion": 1, "lockfileVersion": 1,
"requires": true, "requires": true,
"dependencies": { "dependencies": {

View File

@ -1,6 +1,6 @@
{ {
"name": "setup-php", "name": "setup-php",
"version": "1.2.1", "version": "1.3.0",
"private": false, "private": false,
"description": "Setup php action", "description": "Setup php action",
"main": "lib/setup-php.js", "main": "lib/setup-php.js",

View File

@ -4,8 +4,11 @@ if [ "$version" != "$1" ]; then
brew unlink php; brew unlink php;
brew install php@$1; brew install php@$1;
brew link --force --overwrite php@$1; brew link --force --overwrite php@$1;
else
sudo cp /etc/php.ini.default /etc/php.ini
fi fi
ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g")
sudo chmod 777 $ini_file
curl -sS https://getcomposer.org/installer | php curl -sS https://getcomposer.org/installer | php
chmod +x composer.phar chmod +x composer.phar
mv composer.phar /usr/local/bin/composer mv composer.phar /usr/local/bin/composer

View File

@ -71,7 +71,7 @@ async function addExtension(extension_csv: string, version: string) {
// else add script to attempt to install the extension // else add script to attempt to install the extension
if (os_version == 'linux') { if (os_version == 'linux') {
linux += linux +=
'sudo apt install -y php' + 'sudo DEBIAN_FRONTEND=noninteractive apt install -y php' +
version + version +
'-' + '-' +
extension + extension +
@ -113,7 +113,25 @@ async function addExtension(extension_csv: string, version: string) {
} }
} }
}); });
linux += 'sudo apt autoremove -y'; linux += 'sudo DEBIAN_FRONTEND=noninteractive apt autoremove -y';
}
/*
Add script to set custom ini values
*/
async function addINIValues(ini_values_csv: string) {
let ini_values: any = ini_values_csv
.split(',')
.map(function(ini_value: string) {
return ini_value.trim();
});
await asyncForEach(ini_values, async function(ini_value: string) {
// add script to set ini value
linux += '\necho "' + ini_value + '" >> $ini_file';
darwin += '\necho "' + ini_value + '" >> $ini_file';
windows +=
'\nAdd-Content C:\\tools\\php$version\\php.ini "' + ini_value + '"';
});
} }
/* /*
@ -146,7 +164,7 @@ async function run() {
if (!version) { if (!version) {
version = core.getInput('php-version', {required: true}); version = core.getInput('php-version', {required: true});
} }
console.log('Input: ' + version); console.log('Version: ' + version);
if (version == '7.4') { if (version == '7.4') {
darwin = fs.readFileSync(path.join(__dirname, '../src/7.4.sh'), 'utf8'); darwin = fs.readFileSync(path.join(__dirname, '../src/7.4.sh'), 'utf8');
@ -157,10 +175,19 @@ async function run() {
extension_csv = core.getInput('extension-csv'); extension_csv = core.getInput('extension-csv');
} }
if (extension_csv) { if (extension_csv) {
console.log('Input: ' + extension_csv); console.log('Extensions: ' + extension_csv);
await addExtension(extension_csv, version); await addExtension(extension_csv, version);
} }
let ini_values_csv = process.env['ini-values-csv'];
if (!ini_values_csv) {
ini_values_csv = core.getInput('ini-values-csv');
}
if (ini_values_csv) {
console.log('INI Values: ' + ini_values_csv);
await addINIValues(ini_values_csv);
}
// check the os version and run the respective script // check the os version and run the respective script
if (os_version == 'darwin') { if (os_version == 'darwin') {
await createScript('darwin.sh', version); await createScript('darwin.sh', version);

View File

@ -1,26 +1,23 @@
ua()
{
for tool in php phar phar.phar php-cgi php-config phpize; do
if [ -e "/usr/bin/$tool$version" ]; then
sudo update-alternatives --set $tool /usr/bin/$tool$1;
fi
done
}
version=$(php-config --version | cut -c 1-3) version=$(php-config --version | cut -c 1-3)
if [ "$version" != "$1" ]; then if [ "$version" != "$1" ]; then
if [ ! -e "/usr/bin/php$1" ]; then if [ ! -e "/usr/bin/php$1" ]; then
sudo add-apt-repository ppa:ondrej/php -y sudo DEBIAN_FRONTEND=noninteractive add-apt-repository ppa:ondrej/php -y
sudo apt update -y sudo DEBIAN_FRONTEND=noninteractive apt update -y
sudo apt install -y php$1 curl; sudo DEBIAN_FRONTEND=noninteractive apt install -y php$1 curl;
sudo apt autoremove -y; sudo DEBIAN_FRONTEND=noninteractive apt autoremove -y;
fi fi
ua $1; for tool in php phar phar.phar php-cgi php-config phpize; do
if [ -e "/usr/bin/$tool$1" ]; then
sudo update-alternatives --set $tool /usr/bin/$tool$1;
fi
done
fi fi
if [ ! -e "/usr/bin/composer" ]; then if [ ! -e "/usr/bin/composer" ]; then
sudo curl -s https://getcomposer.org/installer | php; sudo curl -s https://getcomposer.org/installer | php;
sudo mv composer.phar /usr/local/bin/composer; sudo mv composer.phar /usr/local/bin/composer;
fi fi
ini_file=$(php --ini | grep "Loaded Configuration" | sed -e "s|.*:s*||" | sed "s/ //g")
sudo chmod 777 $ini_file
php -v php -v
composer -V composer -V