Simplify ci-test-extensions

pull/118/head
Michele Locati 2020-02-16 15:47:34 +01:00
parent 069a637113
commit 4e63ee8b36
No known key found for this signature in database
GPG Key ID: 98B7CE2E7234E28B
2 changed files with 153 additions and 178 deletions

View File

@ -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:

View File

@ -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