Check recently updated PHP extensions
parent
e4cdbdd089
commit
7971155251
|
@ -62,7 +62,7 @@ jobs:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v1
|
uses: actions/checkout@v1
|
||||||
- name: Test extensions
|
- name: Test extensions
|
||||||
run: ./scripts/ci-test-extensions "${{ github.event.pull_request.base.sha }}..${{ github.event.pull_request.head.sha }}"
|
run: ./scripts/ci-test-extensions from-commits "${{ github.event.pull_request.base.sha }}..${{ github.event.pull_request.head.sha }}"
|
||||||
test_restoring_packages:
|
test_restoring_packages:
|
||||||
name: Test restoring packages
|
name: Test restoring packages
|
||||||
needs:
|
needs:
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
name: Test recent
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: "0 */12 * * *"
|
||||||
|
repository_dispatch:
|
||||||
|
types:
|
||||||
|
- test-recent
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
determine_extension_list:
|
||||||
|
name: Determine extension list
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v1
|
||||||
|
- name: Retrieve recently updated extensions
|
||||||
|
run: ./scripts/ci-retrieve-recent-extensions >extensions-updated.txt
|
||||||
|
- name: Filter supported extensions
|
||||||
|
run: |
|
||||||
|
UPDATED_EXTENSIONS="$(cat extensions-updated.txt)"
|
||||||
|
if test -z "$UPDATED_EXTENSIONS"; then
|
||||||
|
EXTENSIONS_TO_TEST=''
|
||||||
|
else
|
||||||
|
EXTENSIONS_TO_TEST="$(./scripts/ci-filter-supported-extensions "$UPDATED_EXTENSIONS")"
|
||||||
|
fi
|
||||||
|
printf "$EXTENSIONS_TO_TEST" > extensions-to-test.txt
|
||||||
|
- name: Persist list of extensions to be tested
|
||||||
|
uses: actions/upload-artifact@v1
|
||||||
|
with:
|
||||||
|
name: artifact
|
||||||
|
path: extensions-to-test.txt
|
||||||
|
test_extensions:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: determine_extension_list
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
distro:
|
||||||
|
- alpine3.7
|
||||||
|
- alpine3.8
|
||||||
|
- alpine3.9
|
||||||
|
- alpine3.10
|
||||||
|
- alpine3.11
|
||||||
|
- jessie
|
||||||
|
- stretch
|
||||||
|
- buster
|
||||||
|
name: Check on ${{ matrix.distro }}
|
||||||
|
env:
|
||||||
|
DOCKER_DISTRO: ${{ matrix.distro }}
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v1
|
||||||
|
- name: Loading list of extensions to be tested
|
||||||
|
uses: actions/download-artifact@v1
|
||||||
|
with:
|
||||||
|
name: artifact
|
||||||
|
- name: Test extensions
|
||||||
|
run: |
|
||||||
|
EXTENSIONS_TO_TEST="$(cat artifact/extensions-to-test.txt)"
|
||||||
|
if test -z "$EXTENSIONS_TO_TEST"; then
|
||||||
|
echo 'No extensions to be tested'
|
||||||
|
else
|
||||||
|
./scripts/ci-test-extensions from-list "$EXTENSIONS_TO_TEST"
|
||||||
|
fi
|
||||||
|
- name: Notify failures
|
||||||
|
if: failure()
|
||||||
|
uses: appleboy/telegram-action@master
|
||||||
|
with:
|
||||||
|
token: ${{ secrets.TELEGRAM_TOKEN }}
|
||||||
|
to: ${{ secrets.TELEGRAM_TO }}
|
||||||
|
message: Testing recent PHP packages failed on https://github.com/mlocati/docker-php-extension-installer
|
|
@ -1,4 +1,5 @@
|
||||||
![Test extensions](https://github.com/mlocati/docker-php-extension-installer/workflows/Test%20extensions/badge.svg)
|
![Test extensions](https://github.com/mlocati/docker-php-extension-installer/workflows/Test%20extensions/badge.svg)
|
||||||
|
![Test recent](https://github.com/mlocati/docker-php-extension-installer/workflows/Test%20recent/badge.svg)
|
||||||
|
|
||||||
# Easy installation of PHP extensions in official PHP Docker images
|
# Easy installation of PHP extensions in official PHP Docker images
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,34 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Let's set a sane environment
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
set -o noglob
|
||||||
|
|
||||||
|
SCRIPTS_DIR="$(CDPATH= cd -- "$(dirname -- "$0")" && pwd)"
|
||||||
|
. "$SCRIPTS_DIR/common"
|
||||||
|
ROOT_DIR="$(dirname -- "$SCRIPTS_DIR")"
|
||||||
|
DATA_DIR="$ROOT_DIR/data"
|
||||||
|
|
||||||
|
EXTENSIONS_LIST="${1:-}"
|
||||||
|
|
||||||
|
if test -z "$EXTENSIONS_LIST"; then
|
||||||
|
echo 'Extensions list not specified' >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
ALL_SUPPORTED_EXTENSIONS="$(cat "$DATA_DIR/supported-extensions")"
|
||||||
|
|
||||||
|
SUPPORTED_EXTENSIONS=''
|
||||||
|
resetIFS
|
||||||
|
for EXTENSION in $EXTENSIONS_LIST; do
|
||||||
|
printf 'Checking extension "%s"... ' "$EXTENSION" >&2
|
||||||
|
if printf '%s' "$ALL_SUPPORTED_EXTENSIONS" | grep -q "^$EXTENSION\s"; then
|
||||||
|
printf 'supported.\n' >&2
|
||||||
|
SUPPORTED_EXTENSIONS="$SUPPORTED_EXTENSIONS $EXTENSION"
|
||||||
|
else
|
||||||
|
printf 'not supported.\n' >&2
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
printf '%s' "${SUPPORTED_EXTENSIONS# }"
|
|
@ -0,0 +1,42 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Let's set a sane environment
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
set -o noglob
|
||||||
|
|
||||||
|
SCRIPTS_DIR="$(CDPATH= cd -- "$(dirname -- "$0")" && pwd)"
|
||||||
|
. "$SCRIPTS_DIR/common"
|
||||||
|
|
||||||
|
printf 'Downloading PECL feed... ' >&2
|
||||||
|
XML="$(curl --fail --silent --show-error --location https://pecl.php.net/feeds/latest.rss)"
|
||||||
|
printf 'done.\n' >&2
|
||||||
|
|
||||||
|
printf 'Formatting XML... ' >&2
|
||||||
|
XML="$(printf '%s' "$XML" | tr -s ' \t\r\n' ' ' | sed -r 's# *<#\n<#g' | sed -r 's#>\n*#>\n#g' | tr -s '\n' '\n' | sed -r 's#^ +##g')"
|
||||||
|
printf 'done.\n' >&2
|
||||||
|
|
||||||
|
NUM_EXTENSIONS=0
|
||||||
|
EXTENSIONS=''
|
||||||
|
printf 'Detecting extension list... ' >&2
|
||||||
|
IFS='
|
||||||
|
'
|
||||||
|
for XML_LINE in $XML; do
|
||||||
|
case "$XML_LINE" in
|
||||||
|
\<item\ *)
|
||||||
|
URL="$(printf '%s' "$XML_LINE" | sed -r 's#^.+ rdf:about\s*=\s*"##' | sed -r 's#".*$##')"
|
||||||
|
EXTENSION="$(printf '%s' "$URL" | sed -r 's#^.*[?%]package=##' | sed -r 's#&.*$##')"
|
||||||
|
if test -n "$EXTENSION" && ! stringInList "$EXTENSION" "$EXTENSIONS"; then
|
||||||
|
EXTENSIONS="$EXTENSIONS $EXTENSION"
|
||||||
|
NUM_EXTENSIONS=$((NUM_EXTENSIONS + 1))
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
if test -z "$EXTENSIONS"; then
|
||||||
|
printf 'no extension found.\n' >&2
|
||||||
|
else
|
||||||
|
EXTENSIONS="${EXTENSIONS# }"
|
||||||
|
printf '%d extension(s) found (%s)\n' $NUM_EXTENSIONS "$EXTENSIONS" >&2
|
||||||
|
fi
|
||||||
|
printf '%s' "$EXTENSIONS"
|
|
@ -252,37 +252,50 @@ testExtensionFor() {
|
||||||
}
|
}
|
||||||
|
|
||||||
echo 'Checking environment'
|
echo 'Checking environment'
|
||||||
if test -n "${GITHUB_WORKSPACE:-}" && test -n "${GITHUB_SHA:-}"; then
|
if test -z "${GITHUB_WORKSPACE:-}"; then
|
||||||
if test -z "${1:-}"; then
|
|
||||||
echo 'Missing commit range of the push event' >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
CI_BUILD_DIR="$GITHUB_WORKSPACE"
|
|
||||||
CI_COMMIT_RANGE="$1"
|
|
||||||
else
|
|
||||||
echo 'Not in a CI environment' >&2
|
echo 'Not in a CI environment' >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
CI_BUILD_DIR="$GITHUB_WORKSPACE"
|
||||||
if test -z "${DOCKER_DISTRO:-}"; then
|
if test -z "${DOCKER_DISTRO:-}"; then
|
||||||
echo 'DOCKER_DISTRO environment variable not set' >&2
|
echo 'DOCKER_DISTRO environment variable not set' >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
. "$CI_BUILD_DIR/scripts/common"
|
case "${1:-}" in
|
||||||
|
from-commits)
|
||||||
EXTENSIONS_TO_BE_TESTED=''
|
if test -z "${2:-}"; then
|
||||||
STOP_EXTENSIONS_FOUND=0
|
echo 'Missing commit range of the push event' >&2
|
||||||
|
exit 1
|
||||||
extractExtensionsFromCommits
|
fi
|
||||||
if test $STOP_EXTENSIONS_FOUND -eq 0; then
|
CI_COMMIT_RANGE="$2"
|
||||||
|
STOP_EXTENSIONS_FOUND=0
|
||||||
|
EXTENSIONS_TO_BE_TESTED=''
|
||||||
|
extractExtensionsFromCommits
|
||||||
|
if test $STOP_EXTENSIONS_FOUND -eq 0; then
|
||||||
extractExtensionsFromData
|
extractExtensionsFromData
|
||||||
fi
|
fi
|
||||||
|
;;
|
||||||
|
from-list)
|
||||||
|
EXTENSIONS_TO_BE_TESTED="${2:-}"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
if test -z "${1:-}"; then
|
||||||
|
printf 'Missing source of extensions to be tested\n' >&2
|
||||||
|
else
|
||||||
|
printf '"%s" is an unknown source of extensions to be tested\n' "$1" >&2
|
||||||
|
fi
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
if test -z "$EXTENSIONS_TO_BE_TESTED"; then
|
if test -z "$EXTENSIONS_TO_BE_TESTED"; then
|
||||||
echo 'No extensions to be tested.'
|
echo 'No extensions to be tested.'
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
. "$CI_BUILD_DIR/scripts/common"
|
||||||
|
|
||||||
printf '### EXTENSIONS TO BE TESTED: %s\n' "$EXTENSIONS_TO_BE_TESTED"
|
printf '### EXTENSIONS TO BE TESTED: %s\n' "$EXTENSIONS_TO_BE_TESTED"
|
||||||
SOME_TEST_FAILED=0
|
SOME_TEST_FAILED=0
|
||||||
IFS='
|
IFS='
|
||||||
|
|
|
@ -13,17 +13,19 @@ case "${1:-}" in
|
||||||
PARAMS="$PARAMS -w"
|
PARAMS="$PARAMS -w"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
fprintf 'Syntax: %s <check|fix>' "$0" >&2
|
printf 'Syntax: %s <check|fix>' "$0" >&2
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
shfmt $PARAMS \
|
shfmt $PARAMS \
|
||||||
install-php-extensions \
|
install-php-extensions \
|
||||||
|
scripts/ci-filter-supported-extensions \
|
||||||
|
scripts/ci-retrieve-recent-extensions \
|
||||||
|
scripts/ci-test-extensions \
|
||||||
|
scripts/ci-update-readme \
|
||||||
scripts/common \
|
scripts/common \
|
||||||
scripts/invoke-shfmt \
|
scripts/invoke-shfmt \
|
||||||
scripts/lint \
|
scripts/lint \
|
||||||
scripts/test-restore-apt \
|
scripts/test-restore-apt \
|
||||||
scripts/ci-test-extensions \
|
|
||||||
scripts/ci-update-readme \
|
|
||||||
scripts/update-readme
|
scripts/update-readme
|
||||||
|
|
Loading…
Reference in New Issue