From 0e248ed76eaf67977f7a9e41e7bbe32b87facadb Mon Sep 17 00:00:00 2001 From: Edmund Farrow Date: Wed, 6 Mar 2024 09:59:23 +0000 Subject: [PATCH] github-workflow - First pass of CI --- .github/workflows/moodle-ci.yml | 145 ++++++++++++++++++++++++++++++++ 1 file changed, 145 insertions(+) create mode 100644 .github/workflows/moodle-ci.yml diff --git a/.github/workflows/moodle-ci.yml b/.github/workflows/moodle-ci.yml new file mode 100644 index 0000000..b32adaf --- /dev/null +++ b/.github/workflows/moodle-ci.yml @@ -0,0 +1,145 @@ +name: Moodle Plugin CI + +on: [push, pull_request] + +jobs: + test: + runs-on: ubuntu-22.04 + + services: + postgres: + image: postgres:13 + env: + POSTGRES_USER: 'postgres' + POSTGRES_HOST_AUTH_METHOD: 'trust' + ports: + - 5432:5432 + options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 3 + mariadb: + image: mariadb:10.6 + env: + MYSQL_USER: 'root' + MYSQL_ALLOW_EMPTY_PASSWORD: "true" + MYSQL_CHARACTER_SET_SERVER: "utf8mb4" + MYSQL_COLLATION_SERVER: "utf8mb4_unicode_ci" + + ports: + - 3306:3306 + options: --health-cmd="mysqladmin ping" --health-interval 10s --health-timeout 5s --health-retries 3 + + strategy: + fail-fast: false + matrix: # I don't know why, but mariadb is much slower, so mostly use pgsql. + # We use a mix of SBCL and GCL, but mostly prefer SBCL as it is faster. + include: + - php: '8.2' + moodle-branch: 'master' + database: 'pgsql' + maxima: 'SBCL' + - php: '8.1' + moodle-branch: 'MOODLE_402_STABLE' + database: 'pgsql' + maxima: 'GCL' + - php: '8.0' + moodle-branch: 'MOODLE_402_STABLE' + database: 'pgsql' + maxima: 'SBCL' + # Edinburgh is planning to run the setup below for 2023-24. + - php: '7.4' + moodle-branch: 'MOODLE_401_STABLE' + database: 'mariadb' + maxima: 'GCL' + - php: '7.4' + moodle-branch: 'MOODLE_400_STABLE' + database: 'pgsql' + maxima: 'SBCL' + - php: '7.3' + moodle-branch: 'MOODLE_311_STABLE' + database: 'pgsql' + maxima: 'SBCL' + - php: '7.2' + moodle-branch: 'MOODLE_39_STABLE' + database: 'pgsql' + maxima: 'SBCL' + + steps: + - name: Check out repository code + uses: actions/checkout@v3 + with: + path: plugin + + - name: Setup PHP ${{ matrix.php }} + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php }} + extensions: ${{ matrix.extensions }} + ini-values: max_input_vars=5000 + coverage: none + + - name: Initialise moodle-plugin-ci + run: | + composer create-project -n --no-dev --prefer-dist moodlehq/moodle-plugin-ci ci ^3 + echo $(cd ci/bin; pwd) >> $GITHUB_PATH + echo $(cd ci/vendor/bin; pwd) >> $GITHUB_PATH + sudo locale-gen en_AU.UTF-8 + echo "NVM_DIR=$HOME/.nvm" >> $GITHUB_ENV + + - name: Install moodle-plugin-ci + run: | + moodle-plugin-ci add-plugin maths/moodle-qbehaviour_dfexplicitvaildate + moodle-plugin-ci add-plugin maths/moodle-qbehaviour_dfcbmexplicitvaildate + moodle-plugin-ci add-plugin maths/moodle-qbehaviour_adaptivemultipart + moodle-plugin-ci add-plugin maths/moodle-qformat_stack + moodle-plugin-ci add-plugin maths/moodle-qbank_importasversion + + moodle-plugin-ci install --plugin ./plugin --db-host=127.0.0.1 + + #cat ${{ github.workspace }}/moodle/config.php + + env: + DB: ${{ matrix.database }} + MOODLE_BRANCH: ${{ matrix.moodle-branch }} + + - name: PHP Lint + if: ${{ always() }} + run: moodle-plugin-ci phplint + + - name: PHP Copy/Paste Detector + continue-on-error: true # This step will show errors but will not fail. + if: ${{ always() }} + run: moodle-plugin-ci phpcpd + + - name: PHP Mess Detector + continue-on-error: true # This step will show errors but will not fail. + if: ${{ always() }} + run: moodle-plugin-ci phpmd + + - name: Moodle Code Checker + continue-on-error: true # Currently fails. We really ought to get this passing. + if: ${{ always() }} + run: moodle-plugin-ci codechecker --max-warnings 0 + + - name: Moodle PHPDoc Checker + continue-on-error: true # Currently fails. We really ought to get this passing. + if: ${{ always() }} + run: moodle-plugin-ci phpdoc + + - name: Validating + if: ${{ always() }} + run: moodle-plugin-ci validate + + - name: Check upgrade savepoints + if: ${{ always() }} + run: moodle-plugin-ci savepoints + + - name: Mustache Lint + if: ${{ always() }} + run: moodle-plugin-ci mustache + + - name: Grunt + if: ${{ matrix.moodle-branch == 'MOODLE_401_STABLE' }} + run: moodle-plugin-ci grunt + + - name: PHPUnit tests + if: ${{ always() }} + run: moodle-plugin-ci phpunit