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}"