Simplify ci-test-extensions
parent
069a637113
commit
4e63ee8b36
|
@ -61,8 +61,6 @@ jobs:
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v1
|
uses: actions/checkout@v1
|
||||||
with:
|
|
||||||
fetch-depth: 1
|
|
||||||
- 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 "${{ github.event.pull_request.base.sha }}..${{ github.event.pull_request.head.sha }}"
|
||||||
test_restoring_packages:
|
test_restoring_packages:
|
||||||
|
|
|
@ -4,26 +4,76 @@
|
||||||
set -o errexit
|
set -o errexit
|
||||||
set -o nounset
|
set -o nounset
|
||||||
|
|
||||||
echo 'Checking environment'
|
# Extract the extensions to be tested from commit messages
|
||||||
if test -n "${GITHUB_WORKSPACE:-}" && test -n "${GITHUB_SHA:-}"; then
|
#
|
||||||
if test -z "${1:-}"; then
|
# Update: EXTENSIONS_TO_BE_TESTED
|
||||||
echo 'Missing commit range of the push event' >&2
|
# Set: STOP_EXTENSIONS_FOUND
|
||||||
exit 1
|
extractExtensionsFromCommits() {
|
||||||
fi
|
STOP_EXTENSIONS_FOUND=0
|
||||||
CI_BUILD_DIR="$GITHUB_WORKSPACE"
|
IFS='
|
||||||
CI_COMMIT_RANGE="$1"
|
'
|
||||||
else
|
for extractExtensionsFromCommits_hash in $(git -C "$CI_BUILD_DIR" log --pretty='format:%H' "$CI_COMMIT_RANGE"); do
|
||||||
echo 'Not in a CI environment' >&2
|
extractExtensionsFromCommits_firstLine=1
|
||||||
exit 1
|
extractExtensionsFromCommits_message="$(git -C "$CI_BUILD_DIR" log --pretty='format:%B' -n 1 "$extractExtensionsFromCommits_hash")"
|
||||||
fi
|
IFS='
|
||||||
if test -z "${DOCKER_DISTRO:-}"; then
|
'
|
||||||
echo 'DOCKER_DISTRO environment variable not set' >&2
|
for extractExtensionsFromCommits_messageLine in $extractExtensionsFromCommits_message; do
|
||||||
exit 1
|
if test $extractExtensionsFromCommits_firstLine -eq 1; then
|
||||||
fi
|
extractExtensionsFromCommits_firstLine=0
|
||||||
|
else
|
||||||
|
extractExtensionsFromCommits_testList=
|
||||||
|
case "$extractExtensionsFromCommits_messageLine" in
|
||||||
|
Test:*)
|
||||||
|
extractExtensionsFromCommits_testList=${extractExtensionsFromCommits_messageLine#Test:}
|
||||||
|
;;
|
||||||
|
TEST:*)
|
||||||
|
extractExtensionsFromCommits_testList=${extractExtensionsFromCommits_messageLine#TEST:}
|
||||||
|
;;
|
||||||
|
test:*)
|
||||||
|
extractExtensionsFromCommits_testList=${extractExtensionsFromCommits_messageLine#test:}
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
if test -n "$extractExtensionsFromCommits_testList"; then
|
||||||
|
IFS=' ,;'
|
||||||
|
for extractExtensionsFromCommits_extension in $extractExtensionsFromCommits_testList; do
|
||||||
|
if test $extractExtensionsFromCommits_extension = '-STOP-'; then
|
||||||
|
STOP_EXTENSIONS_FOUND=1
|
||||||
|
break 2
|
||||||
|
fi
|
||||||
|
if ! stringInList "$extractExtensionsFromCommits_extension" "$EXTENSIONS_TO_BE_TESTED"; then
|
||||||
|
EXTENSIONS_TO_BE_TESTED="$EXTENSIONS_TO_BE_TESTED $extractExtensionsFromCommits_extension"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
done
|
||||||
|
EXTENSIONS_TO_BE_TESTED="${EXTENSIONS_TO_BE_TESTED# }"
|
||||||
|
}
|
||||||
|
|
||||||
. "$CI_BUILD_DIR/scripts/common"
|
# Extract the extensions to be tested from changes in the data/supported-extensions file
|
||||||
|
#
|
||||||
ALREADY_TESTED_EXTENSIONS=''
|
# Update: EXTENSIONS_TO_BE_TESTED
|
||||||
|
extractExtensionsFromData() {
|
||||||
|
IFS='
|
||||||
|
'
|
||||||
|
extractExtensionsFromData_foundAt=
|
||||||
|
for extractExtensionsFromData_line in $(git -C "$CI_BUILD_DIR" diff --no-indent-heuristic --minimal --no-color --word-diff=none -no-renames --unified=0 "$CI_COMMIT_RANGE" -- data/supported-extensions); do
|
||||||
|
if test -n "$extractExtensionsFromData_line"; then
|
||||||
|
if test -z "$extractExtensionsFromData_foundAt"; then
|
||||||
|
if test -z "${extractExtensionsFromData_line##@@*}"; then
|
||||||
|
extractExtensionsFromData_foundAt=y
|
||||||
|
fi
|
||||||
|
elif test -z "${extractExtensionsFromData_line##+*}"; then
|
||||||
|
extractExtensionsFromData_extension="${extractExtensionsFromData_line%% *}"
|
||||||
|
if ! stringInList "$extractExtensionsFromData_extension" "$EXTENSIONS_TO_BE_TESTED"; then
|
||||||
|
EXTENSIONS_TO_BE_TESTED="$EXTENSIONS_TO_BE_TESTED $extractExtensionsFromData_extension"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
EXTENSIONS_TO_BE_TESTED="${EXTENSIONS_TO_BE_TESTED# }"
|
||||||
|
}
|
||||||
|
|
||||||
# Get the docker image ID for a PHP extension and a PHP version
|
# Get the docker image ID for a PHP extension and a PHP version
|
||||||
#
|
#
|
||||||
|
@ -72,76 +122,6 @@ getDockerImageName() {
|
||||||
printf '%s' "$getDockerImageName_imageName"
|
printf '%s' "$getDockerImageName_imageName"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Test an extension
|
|
||||||
#
|
|
||||||
# Arguments:
|
|
||||||
# $1: space-separated list with the names of the PHP extensions to be tested
|
|
||||||
# $2: the PHP version
|
|
||||||
#
|
|
||||||
# Return:
|
|
||||||
# 0 (true): if test passes
|
|
||||||
# 1 (false): if test fails
|
|
||||||
testExtension() {
|
|
||||||
printf 'PHP version: %s\n' "$2"
|
|
||||||
if test -n "$(printf '%s' "$2" | sed -E 's/^[0-9]+\.[0-9]+$//')"; then
|
|
||||||
printf ' INVALID PHP VERSION: %s\n' "$2" >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
testExtension_Image="$(getDockerImageName "$1" "$2")"
|
|
||||||
if test $? -ne 0; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
if test -z "$testExtension_Image"; then
|
|
||||||
printf ' - Docker image not available\n'
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
printf ' - Docker image: %s\n' "$testExtension_Image"
|
|
||||||
testExtension_out="$(mktemp)"
|
|
||||||
if $(docker run --rm --volume "$CI_BUILD_DIR:/app" --workdir /app "$testExtension_Image" sh -c "./install-php-extensions $1 && php ./scripts/check-installed-extension.php $1" >"$testExtension_out" 2>&1); then
|
|
||||||
rm -rf "$testExtension_out"
|
|
||||||
printf ' - Passed\n'
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
printf ' - FAILED!\n' >&2
|
|
||||||
tail -n500 "$testExtension_out" >&2
|
|
||||||
rm -rf "$testExtension_out"
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Test a new extension line
|
|
||||||
#
|
|
||||||
# Arguments:
|
|
||||||
# $1: the extension name
|
|
||||||
# $@: the list of PHP versions
|
|
||||||
#
|
|
||||||
# Return:
|
|
||||||
# 0 (true): if test passes
|
|
||||||
# 1 (false): if test fails
|
|
||||||
testNewExtensionLine() {
|
|
||||||
testNewExtensionLine_rc=0
|
|
||||||
if test $# -lt 2; then
|
|
||||||
printf 'Missing PHP version list for the new extension %s\n' "${1:-}"
|
|
||||||
testNewExtensionLine_rc=1
|
|
||||||
elif ! stringInList "$1" "$ALREADY_TESTED_EXTENSIONS"; then
|
|
||||||
printf '### TESTING NEW EXTENSION %s ###\n' "$1"
|
|
||||||
if test -n "$(printf '%s' "$1" | sed -E 's/^[a-z][a-z0-9\-\_\.]+$//')"; then
|
|
||||||
printf ' INVALID PHP EXTENSION NAME: %s\n' "$1" >&2
|
|
||||||
testNewExtensionLine_rc=1
|
|
||||||
else
|
|
||||||
ALREADY_TESTED_EXTENSIONS="$ALREADY_TESTED_EXTENSIONS $1"
|
|
||||||
testNewExtensionLine_extension="$1"
|
|
||||||
while test $# -ge 2; do
|
|
||||||
shift
|
|
||||||
testNewExtensionLine_phpVersion="$1"
|
|
||||||
if ! testExtension "$testNewExtensionLine_extension" "$1"; then
|
|
||||||
testNewExtensionLine_rc=1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
return $testNewExtensionLine_rc
|
|
||||||
}
|
|
||||||
|
|
||||||
# Get the list of all supported PHP versions
|
# Get the list of all supported PHP versions
|
||||||
#
|
#
|
||||||
# Arguments:
|
# Arguments:
|
||||||
|
@ -207,66 +187,23 @@ getAllPHPVersionsForExtension() {
|
||||||
printf '%s' "$getAllPHPVersionsForExtension_result"
|
printf '%s' "$getAllPHPVersionsForExtension_result"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Test extensions by reading a commit message
|
# Test extensions
|
||||||
#
|
#
|
||||||
# Arguments:
|
# Arguments:
|
||||||
# $1: the commit hash
|
# $1: space-separated list with the names of the PHP extensions to be tested
|
||||||
#
|
|
||||||
# Set:
|
|
||||||
# STOP_NEXT_COMMITS to 1 if we should skip next commits
|
|
||||||
#
|
#
|
||||||
# Return:
|
# Return:
|
||||||
# 0 (true): if test passes
|
# 0 (true): if test passes
|
||||||
# 1 (false): if test fails
|
# 1 (false): if test fails
|
||||||
testExtensionsFromMessage() {
|
testExtension() {
|
||||||
testExtensionsFromMessage_result=0
|
testExtensionsFromMessage_result=0
|
||||||
TEST_EXTENSIONS=
|
IFS=' '
|
||||||
FIRST_LINE=1
|
for testExtension_extension in $1; do
|
||||||
testExtensionsFromMessage_message="$(git -C "$CI_BUILD_DIR" log --pretty='format:%B' -n 1 "$1")"
|
testExtension_extension="$(printf '%s' "$testExtension_extension" | sed 's/\+/ /g')"
|
||||||
IFS='
|
printf '### TESTING EXTENSION(S) %s ###\n' "$testExtension_extension"
|
||||||
'
|
for testExtension_phpVersion in $(getAllPHPVersionsForExtensions "$testExtension_extension"); do
|
||||||
for COMMIT_LINE in $testExtensionsFromMessage_message; do
|
if ! testExtensionFor "$testExtension_extension" "$testExtension_phpVersion"; then
|
||||||
if test $FIRST_LINE -eq 1; then
|
testExtensionsFromMessage_result=1
|
||||||
FIRST_LINE=0
|
|
||||||
else
|
|
||||||
TESTLIST=
|
|
||||||
case "$COMMIT_LINE" in
|
|
||||||
Test:*)
|
|
||||||
TESTLIST=${COMMIT_LINE#Test:}
|
|
||||||
;;
|
|
||||||
TEST:*)
|
|
||||||
TESTLIST=${COMMIT_LINE#TEST:}
|
|
||||||
;;
|
|
||||||
test:*)
|
|
||||||
TESTLIST=${COMMIT_LINE#test:}
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
if test -n "$TESTLIST"; then
|
|
||||||
IFS=' ,;'
|
|
||||||
for COMMIT_LINE_EXT in $TESTLIST; do
|
|
||||||
if test $COMMIT_LINE_EXT = '-STOP-'; then
|
|
||||||
STOP_NEXT_COMMITS=1
|
|
||||||
elif test -z "$TEST_EXTENSIONS"; then
|
|
||||||
TEST_EXTENSIONS=$COMMIT_LINE_EXT
|
|
||||||
else
|
|
||||||
if ! stringInList "$COMMIT_LINE_EXT" "$TEST_EXTENSIONS"; then
|
|
||||||
TEST_EXTENSIONS="$TEST_EXTENSIONS $COMMIT_LINE_EXT"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
IFS=' '
|
|
||||||
for TEST_EXTENSION in $TEST_EXTENSIONS; do
|
|
||||||
if ! stringInList "$TEST_EXTENSION" "$ALREADY_TESTED_EXTENSIONS"; then
|
|
||||||
ALREADY_TESTED_EXTENSIONS="$ALREADY_TESTED_EXTENSIONS $TEST_EXTENSION"
|
|
||||||
TEST_EXTENSION="$(printf '%s' "$TEST_EXTENSION" | sed 's/\+/ /g')"
|
|
||||||
printf '### TESTING EXTENSION(S) %s ###\n' "$TEST_EXTENSION"
|
|
||||||
for TEST_PHPVERSION in $(getAllPHPVersionsForExtensions "$TEST_EXTENSION"); do
|
|
||||||
if ! testExtension "$TEST_EXTENSION" "$TEST_PHPVERSION"; then
|
|
||||||
testExtensionsFromMessage_result=1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
|
@ -274,43 +211,83 @@ testExtensionsFromMessage() {
|
||||||
return $testExtensionsFromMessage_result
|
return $testExtensionsFromMessage_result
|
||||||
}
|
}
|
||||||
|
|
||||||
STOP_NEXT_COMMITS=0
|
# Test extensions with specific PHP versions
|
||||||
TESTS_RESULTS=0
|
#
|
||||||
ADDED_EXTENSION_LINE=
|
# Arguments:
|
||||||
FOUND_ATAT=
|
# $1: space-separated list with the names of the PHP extensions to be tested
|
||||||
IFS='
|
# $2: the PHP version
|
||||||
'
|
#
|
||||||
for DIFF_LINE in $(git -C "$CI_BUILD_DIR" diff --no-indent-heuristic --minimal --no-color --word-diff=none -no-renames --unified=0 "$CI_COMMIT_RANGE" -- data/supported-extensions); do
|
# Return:
|
||||||
if test -n "$DIFF_LINE"; then
|
# 0 (true): if test passes
|
||||||
if test -z "$FOUND_ATAT"; then
|
# 1 (false): if test fails
|
||||||
if test -z "${DIFF_LINE##@@*}"; then
|
testExtensionFor() {
|
||||||
FOUND_ATAT=y
|
printf 'PHP version: %s\n' "$2"
|
||||||
fi
|
if test -n "$(printf '%s' "$2" | sed -E 's/^[0-9]+\.[0-9]+$//')"; then
|
||||||
elif test -z "${DIFF_LINE##+*}"; then
|
printf ' INVALID PHP VERSION: %s\n' "$2" >&2
|
||||||
resetIFS
|
return 1
|
||||||
ADDED_EXTENSION_LINE="${DIFF_LINE##+}"
|
|
||||||
if ! testNewExtensionLine $ADDED_EXTENSION_LINE; then
|
|
||||||
TESTS_RESULTS=1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
done
|
testExtensionFor_Image="$(getDockerImageName "$1" "$2")"
|
||||||
|
if test $? -ne 0; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if test -z "$testExtensionFor_Image"; then
|
||||||
|
printf ' - Docker image not available\n'
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
printf ' - Docker image: %s\n' "$testExtensionFor_Image"
|
||||||
|
testExtensionFor_out="$(mktemp)"
|
||||||
|
if $(docker run --rm --volume "$CI_BUILD_DIR:/app" --workdir /app "$testExtensionFor_Image" sh -c "./install-php-extensions $1 && php ./scripts/check-installed-extension.php $1" >"$testExtensionFor_out" 2>&1); then
|
||||||
|
rm -rf "$testExtensionFor_out"
|
||||||
|
printf ' - Passed\n'
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
printf ' - FAILED!\n' >&2
|
||||||
|
cat "$testExtensionFor_out" >&2
|
||||||
|
rm -rf "$testExtensionFor_out"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
IFS='
|
echo 'Checking environment'
|
||||||
'
|
if test -n "${GITHUB_WORKSPACE:-}" && test -n "${GITHUB_SHA:-}"; then
|
||||||
for COMMIT_HASH in $(git -C "$CI_BUILD_DIR" log --pretty='format:%H' "$CI_COMMIT_RANGE"); do
|
if test -z "${1:-}"; then
|
||||||
if ! testExtensionsFromMessage "$COMMIT_HASH"; then
|
echo 'Missing commit range of the push event' >&2
|
||||||
TESTS_RESULTS=1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if test $STOP_NEXT_COMMITS -eq 1; then
|
CI_BUILD_DIR="$GITHUB_WORKSPACE"
|
||||||
break
|
CI_COMMIT_RANGE="$1"
|
||||||
fi
|
else
|
||||||
done
|
echo 'Not in a CI environment' >&2
|
||||||
|
exit 1
|
||||||
if test $TESTS_RESULTS -ne 0; then
|
fi
|
||||||
exit $TESTS_RESULTS
|
if test -z "${DOCKER_DISTRO:-}"; then
|
||||||
|
echo 'DOCKER_DISTRO environment variable not set' >&2
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test -z "$ADDED_EXTENSION_LINE"; then
|
. "$CI_BUILD_DIR/scripts/common"
|
||||||
echo 'No new extensions detected.'
|
|
||||||
|
EXTENSIONS_TO_BE_TESTED=''
|
||||||
|
STOP_EXTENSIONS_FOUND=0
|
||||||
|
|
||||||
|
extractExtensionsFromCommits
|
||||||
|
if test $STOP_EXTENSIONS_FOUND -eq 0; then
|
||||||
|
extractExtensionsFromData
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z "$EXTENSIONS_TO_BE_TESTED"; then
|
||||||
|
echo 'No extensions to be tested.'
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf '### EXTENSIONS TO BE TESTED: %s\n' "$EXTENSIONS_TO_BE_TESTED"
|
||||||
|
SOME_TEST_FAILED=0
|
||||||
|
IFS='
|
||||||
|
'
|
||||||
|
|
||||||
|
for EXTENSION_TO_BE_TESTED in "$EXTENSIONS_TO_BE_TESTED"; do
|
||||||
|
testExtension "$EXTENSION_TO_BE_TESTED" || SOME_TEST_FAILED=1
|
||||||
|
done
|
||||||
|
|
||||||
|
if test $SOME_TEST_FAILED -ne 0; then
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Reference in New Issue