From a606322ebc8d6aa7ecae6c0ff7122228058a6757 Mon Sep 17 00:00:00 2001 From: "Eloy Lafuente (stronk7)" Date: Wed, 5 Jun 2024 17:49:22 +0200 Subject: [PATCH] New postjobs job type to run after integration on new infra This job aims to replace all the separated jobs that are executed @ https://integration.moodle.org after every change to integration.git . They perform a few tests checking that everything in some areas look ok. Created in a modular way, so it's easy to add new scripts in the future. 100% docker, can be run both at CIs or locally by setting a few variables. --- runner/main/jobtypes/postjobs/postjobs.sh | 199 ++++++++++++++++++ .../scripts/check_upgrade_savepoints.sh | 51 +++++ .../postjobs/scripts/compare_databases.sh | 104 +++++++++ .../postjobs/scripts/detect_conflicts.sh | 51 +++++ .../postjobs/scripts/grunt_process.sh | 55 +++++ .../postjobs/scripts/illegal_whitespace.sh | 51 +++++ .../jobtypes/postjobs/scripts/php_lint.sh | 61 ++++++ .../postjobs/scripts/verify_phpunit_xml.sh | 59 ++++++ .../postjobs/scripts/versions_check_set.sh | 54 +++++ .../moodle-core-copy/moodle-core-copy.sh | 8 +- runner/main/run.sh | 5 + 11 files changed, 696 insertions(+), 2 deletions(-) create mode 100644 runner/main/jobtypes/postjobs/postjobs.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/check_upgrade_savepoints.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/compare_databases.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/detect_conflicts.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/grunt_process.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/illegal_whitespace.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/php_lint.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/verify_phpunit_xml.sh create mode 100644 runner/main/jobtypes/postjobs/scripts/versions_check_set.sh diff --git a/runner/main/jobtypes/postjobs/postjobs.sh b/runner/main/jobtypes/postjobs/postjobs.sh new file mode 100644 index 0000000..e6863d3 --- /dev/null +++ b/runner/main/jobtypes/postjobs/postjobs.sh @@ -0,0 +1,199 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Post-jobs job type functions. +# +# This job type is used to run all the post-checks that we use to verify various aspects +# after any new code arrives to the Moodle repository (normally during integration). + +# Post-jobs needed variables to go to the env file. +function postjobs_to_env_file() { + local env=( + DBTYPE + DBTAG + DBHOST + DBNAME + DBUSER + DBPASS + DBCOLLATION + DBREPLICAS + DBHOST_DBREPLICA + + MOODLE_CONFIG + ) + + # We also need to add all the env variables required by the post-jobs scripts. + for script in "${SCRIPTS[@]}"; do + # Add the script env variables to the list. + env+=($("postjobs_${script}_to_env_file")) + done + echo "${env[@]}" +} + +# Post-jobs information to be added to the summary. +function postjobs_to_summary() { + echo "== Moodle branch (version.php): ${MOODLE_BRANCH}" + echo "== PHP version: ${PHP_VERSION}" + echo "== DBTYPE: ${DBTYPE}" + echo "== DBTAG: ${DBTAG}" + echo "== DBCOLLATION: ${DBCOLLATION}" + echo "== DBREPLICAS: ${DBREPLICAS}" + echo "== SCRIPTS: ${SCRIPTS[*]}" + echo "== Git branch (from git): ${GIT_BRANCH}" + echo "== Local CI path: ${LOCAL_CI_PATH}" + echo "== MOODLE_CONFIG: ${MOODLE_CONFIG}" +} + +# This job type defines the following env variables +function postjobs_env() { + env=( + SCRIPTS + GIT_BRANCH + EXITCODE + ) + echo "${env[@]}" +} + +# Post-jobs needed modules. Note that the order is important. +function postjobs_modules() { + local modules=( + env + summary + docker + docker-logs + git + plugins + docker-database + docker-php + moodle-config + moodle-core-copy + docker-healthy + docker-summary + ) + echo "${modules[@]}" +} + +# Post-jobs job type checks. +function postjobs_check() { + # Check all module dependencies. + verify_modules $(postjobs_modules) + + # These env variables must be set for the job to work. + verify_env UUID ENVIROPATH WEBSERVER SHAREDDIR LOCAL_CI_PATH + + # Verify that moodle-local_ci is set, because we require it. + # (note that the moodle-core-copy module perform further checks) + if [[ -z "${LOCAL_CI_PATH}" ]]; then + exit_error "LOCAL_CI_PATH must be defined and point to a valid moodle-local_ci checkout" + fi +} + +# Post-jobs job type init. +function postjobs_config() { + # Apply some defaults. + EXITCODE=0 + + # Various scripts executed by this job do require full access to git, to + # be able to compare branches, switch branches, ... + FULLGIT="yes" + + # Add here all the scripts that will be executed by this job, if not specified in the env. + if [[ -z "${SCRIPTS}" ]]; then + SCRIPTS=( + "illegal_whitespace" + "detect_conflicts" + "check_upgrade_savepoints" + "versions_check_set" + "grunt_process" + "php_lint" + "verify_phpunit_xml" + "compare_databases" + ) + fi + + # Verify that SCRIPTS is an array. + if [[ ! "${SCRIPTS[*]}" ]]; then + exit_error "SCRIPTS must be an array (or keep it empty to use the default scripts)." + fi + + # Get the current git branch (really, it's a reference, can be branch, tag, commit, ...). + # Only if it's not set already. + GIT_BRANCH=${GIT_BRANCH:-$(git -C "${CODEDIR}" rev-parse --abbrev-ref HEAD)} + + # We have to load all the configured scripts and perform various validations. + for script in "${SCRIPTS[@]}"; do + # Check if the script exists. + if [[ ! -f "${BASEDIR}/jobtypes/postjobs/scripts/${script}.sh" ]]; then + echo "${BASEDIR}/jobtypes/postjobs/scripts/${script}.sh" + exit_error "Script ${script} does not exist." + fi + # shellcheck source=jobtypes/postjobs/scripts/illegal_whitespace/illegal_whitespace.sh + source "${BASEDIR}/jobtypes/postjobs/scripts/${script}.sh" + # All scripts must have the following functions: + # - ${script}_to_env_file(): To add information to the env file. + if ! type "postjobs_${script}_to_env_file" > /dev/null 2>&1; then + exit_error "Post job script ${script} does not have a postjobs_${script}_to_env file function." + fi + # - ${script}_to_summary(): To add information to the summary. + if ! type "postjobs_${script}_to_summary" > /dev/null 2>&1; then + exit_error "Post job script ${script} does not have a postjobs_${script}_to_summary function." + fi + # - ${script}_config(): To prepare the environment. + if ! type "postjobs_${script}_config" > /dev/null 2>&1; then + exit_error "Post job script ${script} does not have a postjobs_${script}_config function." + fi + # - ${script}_run(): To effectively execute the script. + if ! type "postjobs_${script}_run" > /dev/null 2>&1; then + exit_error "Post job script ${script} does not have a postjobs_${script}_run function." + fi + + # Arrive here, we can proceed to run the script config function. + echo "Configuring ${script} script..." + "postjobs_${script}_config" + done +} + +# Post-jobs job type setup. +function postjobs_setup() { + # Not much to do here, the scripts don't require any setup, just configuration, + # and that has been already provided by the postjobs_config function. + true +} + +# Post-jobs job type run. +function postjobs_run() { + # We are going to run all the configured scripts. + for script in "${SCRIPTS[@]}"; do + # Run the command + echo ">>> startsection Running script ${script} at $(date) <<<" + echo "============================================================================" + echo "Using configuration:" + "postjobs_${script}_to_summary" + echo "Running ${script} script..." + "postjobs_${script}_run" + local exit_code=$? + if [[ exit_code -ne 0 ]]; then + echo "SCRIPT ERROR: Execution of ${script} script failed with exit code ${exit_code}." + EXITCODE=1 + else + echo "Execution of ${script} script was successful." + fi + echo "============================================================================" + echo ">>> stopsection <<<" + done + +} diff --git a/runner/main/jobtypes/postjobs/scripts/check_upgrade_savepoints.sh b/runner/main/jobtypes/postjobs/scripts/check_upgrade_savepoints.sh new file mode 100644 index 0000000..c51cf43 --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/check_upgrade_savepoints.sh @@ -0,0 +1,51 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Check upgrade savepoints script. +# +# This job will run the moodle-local-ci/check_upgrade_savepoints +# script to verify that all the upgrade save points / steps make sense. + +# Check upgrade savepoints script variables to go to the env file. +function postjobs_check_upgrade_savepoints_to_env_file() { + local env=( + gitdir + gitbranch + ) + echo "${env[@]}" +} + +# Check upgrade savepoints script output to be added to the summary. +function postjobs_check_upgrade_savepoints_to_summary() { + echo "== gitdir: ${gitdir}" + echo "== gitbranch: ${gitbranch}" +} + +# Check upgrade savepoints script config function. +function postjobs_check_upgrade_savepoints_config() { + # Create all the env variables needed for the script. + gitdir="/var/www/html" + gitbranch="${GIT_BRANCH}" +} + +# Check upgrade savepoints script run function. +function postjobs_check_upgrade_savepoints_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/check_upgrade_savepoints/check_upgrade_savepoints.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/compare_databases.sh b/runner/main/jobtypes/postjobs/scripts/compare_databases.sh new file mode 100644 index 0000000..1f3e98d --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/compare_databases.sh @@ -0,0 +1,104 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Compare databases script. +# +# This job will run the moodle-local-ci/comapre_databases +# script that compares the DB schema of installed and +# upgraded databases to verify they are always 100% the same. + +# Compare databases script variables to go to the env file. +function postjobs_compare_databases_to_env_file() { + local env=( + gitdir + gitbranchinstalled + gitbranchupgraded + + GIT_PREVIOUS_COMMIT + GIT_COMMIT + + gitcmd + phpcmd + mysqlcmd + + dblibrary + dbtype + dbhost1 + dbuser1 + dbpass1 + ) + echo "${env[@]}" +} + +# Compare databases script output to be added to the summary. +function postjobs_compare_databases_to_summary() { + echo "== gitdir: ${gitdir}" + echo "== gitbranchinstalled: ${gitbranchinstalled}" + echo "== gitbranchupgraded: ${gitbranchupgraded}" + echo "== GIT_PREVIOUS_COMMIT: ${GIT_PREVIOUS_COMMIT}" + echo "== GIT_COMMIT: ${GIT_COMMIT}" + echo "== gitcmd: ${gitcmd}" + echo "== phpcmd: ${phpcmd}" + echo "== mysqlcmd: ${mysqlcmd}" + echo "== dblibrary: ${dblibrary}" + echo "== dbtype: ${dbtype}" + echo "== dbhost1: ${dbhost1}" + echo "== dbuser1: ${dbuser1}" + echo "== dbpass1: ${dbpass1}" +} + +# Compare databases script config function. +function postjobs_compare_databases_config() { + # Create all the env variables needed for the script. + gitdir="/var/www/html" + gitbranchinstalled="${GIT_BRANCH}" + gitbranchupgraded="${gitbranchupgraded:-}" + GIT_PREVIOUS_COMMIT=${GIT_PREVIOUS_COMMIT:-} + GIT_COMMIT=${GIT_COMMIT:-} + gitcmd="git" + phpcmd="php" + mysqlcmd="mysql" + dblibrary="native" + dbtype="${DBTYPE}" + dbhost1="${DBHOST}" + dbuser1="root" # The script is going to create databases, so it needs root user access. + dbpass1="${DBPASS}" + + # Error if the dbtype is not supported (only mysqli is supported). + if [[ "${dbtype}" != "mysqli" ]]; then + exit_error "Only mysqli is supported for the compare databases script." + fi + +} + +# Compare databases run function. +function postjobs_compare_databases_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + + # First, check if any change (db install/upgrade, versions bump...) has happened. + # in order to decide if the comparison is needed. + if ! docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/compare_databases/run_conditionally.sh; then + return # We can skip the comparison, nothing relevant has changed. + fi + + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/compare_databases/compare_databases.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/detect_conflicts.sh b/runner/main/jobtypes/postjobs/scripts/detect_conflicts.sh new file mode 100644 index 0000000..fe5bcb7 --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/detect_conflicts.sh @@ -0,0 +1,51 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Detect conflicts script. +# +# This job will run the moodle-local-ci/detect_conflicts +# script to check for any conflict left in the code. + +# Detect conflicts script variables to go to the env file. +function postjobs_detect_conflicts_to_env_file() { + local env=( + gitdir + gitbranch + ) + echo "${env[@]}" +} + +# Detect conflicts script output to be added to the summary. +function postjobs_detect_conflicts_to_summary() { + echo "== gitdir: ${gitdir}" + echo "== gitbranch: ${gitbranch}" +} + +# Detect conflicts script config function. +function postjobs_detect_conflicts_config() { + # Create all the env variables needed for the script. + gitdir="/var/www/html" + gitbranch="${GIT_BRANCH}" +} + +# Detect conflicts run function. +function postjobs_detect_conflicts_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/detect_conflicts/detect_conflicts.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/grunt_process.sh b/runner/main/jobtypes/postjobs/scripts/grunt_process.sh new file mode 100644 index 0000000..6bfaff1 --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/grunt_process.sh @@ -0,0 +1,55 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Grunt process script. +# +# This job will run the moodle-local-ci/grunt_process +# script that will install nodejs, all dependencies and +# execute grunt to verify that everything in built properly (CSS, JS, ...). + +# Grunt process script variables to go to the env file. +function postjobs_grunt_process_to_env_file() { + local env=( + gitdir + gitbranch + npminstall + ) + echo "${env[@]}" +} + +# Grunt process script output to be added to the summary. +function postjobs_grunt_process_to_summary() { + echo "== gitdir: ${gitdir}" + echo "== gitbranch: ${gitbranch}" + echo "== npminstall: ${npminstall}" +} + +# Grunt process script config function. +function postjobs_grunt_process_config() { + # Create all the env variables needed for the script. + gitdir="/var/www/html" + gitbranch="${GIT_BRANCH}" + npminstall="true" +} + +# Grunt process script run function. +function postjobs_grunt_process_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/grunt_process/grunt_process.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/illegal_whitespace.sh b/runner/main/jobtypes/postjobs/scripts/illegal_whitespace.sh new file mode 100644 index 0000000..0443f59 --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/illegal_whitespace.sh @@ -0,0 +1,51 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Illegal whitespace script. +# +# This job will run the moodle-local-ci/illegal_whitespace +# script to check for any illegal whitespace in the code. + +# Illegal whitespace script variables to go to the env file. +function postjobs_illegal_whitespace_to_env_file() { + local env=( + gitdir + gitbranch + ) + echo "${env[@]}" +} + +# Illegal whitespace script output to be added to the summary. +function postjobs_illegal_whitespace_to_summary() { + echo "== gitdir: ${gitdir}" + echo "== gitbranch: ${gitbranch}" +} + +# Illegal whitespace script config function. +function postjobs_illegal_whitespace_config() { + # Create all the env variables needed for the script. + gitdir="/var/www/html" + gitbranch="${GIT_BRANCH}" +} + +# Illegal whitespace run function. +function postjobs_illegal_whitespace_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/illegal_whitespace/illegal_whitespace.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/php_lint.sh b/runner/main/jobtypes/postjobs/scripts/php_lint.sh new file mode 100644 index 0000000..07af3f5 --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/php_lint.sh @@ -0,0 +1,61 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# PHP lint codebase (full or only modified). +# +# This job will run the PHP linter against codebase. When information +# about the previous commit is available, it will only lint the files +# modified since then. Else, all the codebase will be linted. + +# PHP lint script variables to go to the env file. +function postjobs_php_lint_to_env_file() { + local env=( + gitcmd + phpcmd + gitdir + GIT_PREVIOUS_COMMIT + GIT_COMMIT + ) + echo "${env[@]}" +} + +# PHP lint script output to be added to the summary. +function postjobs_php_lint_to_summary() { + echo "== gitcmd: ${gitcmd}" + echo "== phpcmd: ${phpcmd}" + echo "== gitdir: ${gitdir}" + echo "== GIT_PREVIOUS_COMMIT: ${GIT_PREVIOUS_COMMIT}" + echo "== GIT_COMMIT: ${GIT_COMMIT}" +} + +# PHP lint script config function. +function postjobs_php_lint_config() { + # Create all the env variables needed for the script. + gitcmd="git" + phpcmd="php" + gitdir="/var/www/html" + GIT_PREVIOUS_COMMIT=${GIT_PREVIOUS_COMMIT:-} + GIT_COMMIT=${GIT_COMMIT:-} +} + +# PHP lint script run function. +function postjobs_php_lint_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/php_lint/php_lint.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/verify_phpunit_xml.sh b/runner/main/jobtypes/postjobs/scripts/verify_phpunit_xml.sh new file mode 100644 index 0000000..58941ed --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/verify_phpunit_xml.sh @@ -0,0 +1,59 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Verify that generated phpunit.xml is correct. +# +# This job will run the moodle-local-ci/verify_phpunit_xml +# script to verify that all the information in the generated +# phpunit.xml file is correct (all tests are covered by it and +# other details). + +# Verify PHPUnit script variables to go to the env file. +function postjobs_verify_phpunit_xml_to_env_file() { + local env=( + phpcmd + gitdir + gitbranch + multipleclassiserror + ) + echo "${env[@]}" +} + +# Verify PHPUnit script output to be added to the summary. +function postjobs_verify_phpunit_xml_to_summary() { + echo "== phpcmd: ${phpcmd}" + echo "== gitdir: ${gitdir}" + echo "== gitbranch: ${gitbranch}" + echo "== multipleclassiserror: ${multipleclassiserror}" +} + +# Verify PHPUnit script config function. +function postjobs_verify_phpunit_xml_config() { + # Create all the env variables needed for the script. + phpcmd=php + gitdir="/var/www/html" + gitbranch="${GIT_BRANCH}" + multipleclassiserror="yes" +} + +# Verify PHPUnit script run function. +function postjobs_verify_phpunit_xml_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/verify_phpunit_xml/verify_phpunit_xml.sh +} diff --git a/runner/main/jobtypes/postjobs/scripts/versions_check_set.sh b/runner/main/jobtypes/postjobs/scripts/versions_check_set.sh new file mode 100644 index 0000000..b48725d --- /dev/null +++ b/runner/main/jobtypes/postjobs/scripts/versions_check_set.sh @@ -0,0 +1,54 @@ +#!/usr/bin/env bash +# +# This file is part of the Moodle Continuous Integration Project. +# +# Moodle is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Moodle is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Moodle. If not, see . + +# Verify that all the versions are set correctly. +# +# This job will run the moodle-local-ci/versions_check_set +# script to verify that all the versions are set correctly. + +# Versions check script variables to go to the env file. +function postjobs_versions_check_set_to_env_file() { + local env=( + phpcmd + gitdir + betweenversions + ) + echo "${env[@]}" +} + +# Versions check script output to be added to the summary. +function postjobs_versions_check_set_to_summary() { + echo "== phpcmd: ${phpcmd}" + echo "== gitdir: ${gitdir}" + echo "== betweenversions: ${betweenversions}" +} + +# Versions check script config function. +function postjobs_versions_check_set_config() { + # Create all the env variables needed for the script. + phpcmd=php + gitdir="/var/www/html" + betweenversions=${betweenversions:-} +} + +# Versions check script run function. +function postjobs_versions_check_set_run() { + # Run the script (within the container, and it's @ /tmp/local_ci + # (The script will use WORKSPACE to store the artifacts). + docker exec -t -u www-data --env WORKSPACE="/shared" "${WEBSERVER}" \ + /tmp/local_ci/versions_check_set/versions_check_set.sh +} diff --git a/runner/main/modules/moodle-core-copy/moodle-core-copy.sh b/runner/main/modules/moodle-core-copy/moodle-core-copy.sh index 6dab10b..439ccd4 100644 --- a/runner/main/modules/moodle-core-copy/moodle-core-copy.sh +++ b/runner/main/modules/moodle-core-copy/moodle-core-copy.sh @@ -31,7 +31,7 @@ function moodle-core-copy_check() { verify_modules docker plugins docker-php # These env variables must be set for the module to work. - verify_env BASEDIR CODEDIR PLUGINSDIR WEBSERVER FULLGIT + verify_env BASEDIR CODEDIR PLUGINSDIR WEBSERVER FULLGIT LOCAL_CI_PATH } # Moodle core copy module config. @@ -109,7 +109,11 @@ function moodle-core-copy_setup() { # Copy local_ci if available to /tmp/local_ci, we'll execute all the scripts from there. # (perform some basic validation, we don't want to copy the wrong stuff) - if [[ -n "${LOCAL_CI_PATH}" ]] && [[ -d "${LOCAL_CI_PATH}" ]] && [[ -d "${LOCAL_CI_PATH}/tracker_automations" ]]; then + if [[ -n "${LOCAL_CI_PATH}" ]] && [[ ! -d "${LOCAL_CI_PATH}/tracker_automations" ]]; then + exit_error "LOCAL_CI_PATH doesn't point to a valid moodle-local_ci checkout" + fi + + if [[ -n "${LOCAL_CI_PATH}" ]]; then echo "== Copying local_ci in place." docker cp "${LOCAL_CI_PATH}" "${WEBSERVER}":/tmp/local_ci docker exec "${WEBSERVER}" chown -R www-data:www-data /tmp/local_ci diff --git a/runner/main/run.sh b/runner/main/run.sh index 05f3f95..b232c2c 100755 --- a/runner/main/run.sh +++ b/runner/main/run.sh @@ -87,6 +87,11 @@ fi # from the jobs (or the caller). FULLGIT="${FULLGIT:-}" +# Some jobs may need to have moodle-local_ci available. This variable +# defines where a valid moodle-local_ci checkout is located, so it can +# be used by the jobs or copied within the PHP container (/tmp/local_ci) +LOCAL_CI_PATH="${LOCAL_CI_PATH:-}" + # Caches directories, used for composer, to accelerate git operations... CACHEDIR="${CACHEDIR:-${HOME}/caches}" COMPOSERCACHE="${COMPOSERCACHE:-${CACHEDIR}/composer}"