diff --git a/.circleci/config.yml b/.circleci/config.yml deleted file mode 100644 index d07c27c..0000000 --- a/.circleci/config.yml +++ /dev/null @@ -1,197 +0,0 @@ -version: 2.1 -commands: - setup: - description: "Setup environment" - steps: - - run: | - composer self-update --1 - install_civicrm: - description: "Install CiviCRM" - parameters: - build_name: - type: string - default: master - type: - type: string - default: drupal-clean - version: - type: string - default: master - url: - type: string - default: http://localhost:8080 - steps: - - run: | - civiver=<< parameters.version >> - if [[ "$civiver" == "stable" ]]; then - civiver=$(curl -s 'https://latest.civicrm.org/stable.php') - fi - su - buildkit -c "/buildkit/bin/civibuild create << parameters.build_name >> --civi-ver $civiver --type << parameters.type >> --url << parameters.url >>" - install_extension: - description: "Install Extension" - parameters: - build_name: - type: string - default: master - steps: - - run: | - EXT_DIR=/buildkit/build/<< parameters.build_name >>/web/sites/default/files/civicrm/ext/$CIRCLE_PROJECT_REPONAME - cp /root/project $EXT_DIR -r - chown buildkit:buildkit $EXT_DIR -R - cd $EXT_DIR - su - buildkit -c "cd /buildkit/build/<< parameters.build_name >>/web && cv en $CIRCLE_PROJECT_REPONAME" - run_civilint: - description: "Run civilint" - parameters: - build_name: - type: string - default: master - steps: - - run: su - buildkit -c "cd /buildkit/build/<< parameters.build_name >>/web/sites/default/files/civicrm/ext/$CIRCLE_PROJECT_REPONAME && find . -type f -not -path './vendor/*' | civilint" - run_phpunit: - description: "Run PHPUnit" - parameters: - build_name: - type: string - default: master - steps: - - run: | - mkdir -p /phpunit /coverage - chown buildkit:buildkit /phpunit /coverage - su - buildkit -c "cd /buildkit/build/<< parameters.build_name >>/web/sites/default/files/civicrm/ext/$CIRCLE_PROJECT_REPONAME && /buildkit/bin/phpunit5 --log-junit /phpunit/<< parameters.build_name >>/junit.xml" - run_all: - description: "Run all steps" - parameters: - build_name: - type: string - default: master - type: - type: string - default: drupal-clean - version: - type: string - default: master - url: - type: string - default: http://localhost:8080 - steps: - - install_civicrm: - build_name: << parameters.build_name >> - type: << parameters.type >> - version: << parameters.version >> - url: << parameters.url >> - - install_extension: - build_name: << parameters.build_name >> - - run_civilint: - build_name: << parameters.build_name >> - - run_phpunit: - build_name: << parameters.build_name >> - - store_test_results: - path: /phpunit - - store_artifacts: - path: /phpunit - - store_artifacts: - path: /coverage - -executors: - civicrm: - docker: - - image: michaelmcandrew/civicrm-buildkit - name: civicrm - environment: - TERM: xterm-color - APACHE_RUN_USER: buildkit - - image: mysql:5.7 - name: mysql - environment: - MYSQL_ROOT_PASSWORD: buildkit - - image: maildev/maildev - name: maildev - -jobs: - build_mysql_5_7: - executor: civicrm - steps: - - setup - - checkout - - run_all - - run_all: - build_name: civi-stable - version: "stable" - url: http://localhost:8081 - - run_all: - build_name: civi-5.39 - version: "5.39" - url: http://localhost:8082 - build_mariadb_10_2: - executor: civicrm - docker: - - image: michaelmcandrew/civicrm-buildkit - name: civicrm - environment: - TERM: xterm-color - APACHE_RUN_USER: buildkit - - image: mariadb:10.2 - name: mysql - environment: - MYSQL_ROOT_PASSWORD: buildkit - - image: maildev/maildev - name: maildev - steps: - - setup - - checkout - - run_all - - run_all: - build_name: civi-stable - version: "stable" - url: http://localhost:8081 - - run_all: - build_name: civi-5.39 - version: "5.39" - url: http://localhost:8082 - build_mariadb_10_3: - executor: civicrm - docker: - - image: michaelmcandrew/civicrm-buildkit - name: civicrm - environment: - TERM: xterm-color - APACHE_RUN_USER: buildkit - - image: mariadb:10.3 - name: mysql - environment: - MYSQL_ROOT_PASSWORD: buildkit - - image: maildev/maildev - name: maildev - steps: - - setup - - checkout - - run_all - - run_all: - build_name: civi-stable - version: "stable" - url: http://localhost:8081 - - run_all: - build_name: civi-5.39 - version: "5.39" - url: http://localhost:8082 - -workflows: - version: 2 - build: - jobs: - - build_mysql_5_7 - - build_mariadb_10_2 - - build_mariadb_10_3 - nightly: - triggers: - - schedule: - cron: "0 5 * * *" - filters: - branches: - only: - - master - jobs: - - build_mysql_5_7 - - build_mariadb_10_2 - - build_mariadb_10_3 diff --git a/.github/workflows/unit-tests.yml b/.github/workflows/unit-tests.yml new file mode 100644 index 0000000..73fd5cd --- /dev/null +++ b/.github/workflows/unit-tests.yml @@ -0,0 +1,80 @@ +name: "Run unit tests" + +on: ["push"] + +env: + CIVI_CI_CIVICRM: ${{ vars.CIVI_CI_CIVICRM || '["master"]' }} + CIVI_CI_MYSQL: ${{ vars.CIVI_CI_MYSQL || '["8.0"]' }} + CIVI_CI_OS: ${{ vars.CIVI_CI_OS || '["ubuntu-22.04"]' }} + CIVI_CI_PHP: ${{ vars.CIVI_CI_PHP || '["8.1"]' }} + CIVI_CI_BUILD_TYPE: ${{ vars.CIVI_CI_BUILD_TYPE || '["drupal-clean"]' }} + CIVI_CI_EXCLUDES: ${{ vars.CIVI_CI_EXCLUDES || '' }} + +jobs: + setup-matrix: + runs-on: ubuntu-latest + outputs: + matrix: ${{ steps.setup-matrix.outputs.matrix }} + steps: + - id: setup-matrix + uses: druzsan/setup-matrix@v2 + with: + matrix: | + civicrm: ${{ env.CIVI_CI_CIVICRM }} + mysql: ${{ env.CIVI_CI_MYSQL }} + os: ${{ env.CIVI_CI_OS }} + php: ${{ env.CIVI_CI_PHP }} + build-type: ${{ env.CIVI_CI_BUILD_TYPE }} + exclude: ${{ env.CIVI_CI_EXCLUDES }} + + run-tests: + needs: setup-matrix + strategy: + fail-fast: false + matrix: ${{ fromJson(needs.setup-matrix.outputs.matrix) }} + runs-on: "${{ matrix.os }}" + + services: + mysql: + image: "mysql:${{ matrix.mysql }}" + env: + MYSQL_ALLOW_EMPTY_PASSWORD: "yes" + ports: + - "3306:3306" + options: >- + --health-cmd="mysqladmin ping" + --health-interval="10s" + --health-timeout="5s" + --health-retries="3" + + steps: + - id: clone-repo + name: "Clone the repository" + uses: "actions/checkout@v3" + with: + ref: "${{ github.ref_name }}" + path: "at.greenpeace.advancedlogtables" + - id: build-ci + uses: greenpeace-cee/civi-ci@main + with: + extension: at.greenpeace.advancedlogtables + civicrm: ${{ matrix.civicrm }} + php: ${{ matrix.php }} + build-type: ${{ matrix.build-type }} + - id: install-extension + name: "Install Extension" + env: + EXT_DIR: ${{ steps.build-ci.outputs.ext-dir }} + run: | + PATH="/home/runner/buildkit/bin:$PATH" + cd "$EXT_DIR" + cp -R "$GITHUB_WORKSPACE/at.greenpeace.advancedlogtables" "$EXT_DIR/at.greenpeace.advancedlogtables" + cv en at.greenpeace.advancedlogtables + - id: run-tests + name: "Run Tests" + env: + EXT_DIR: ${{ steps.build-ci.outputs.ext-dir }} + run: | + PATH="/home/runner/buildkit/bin:$PATH" + cd "$EXT_DIR/at.greenpeace.advancedlogtables" + CIVICRM_UF="UnitTests" phpunit9 diff --git a/tests/phpunit/CRM/Advancedlogtables/LogTableTest.php b/tests/phpunit/CRM/Advancedlogtables/LogTableTest.php index 094e708..c3d7e9e 100644 --- a/tests/phpunit/CRM/Advancedlogtables/LogTableTest.php +++ b/tests/phpunit/CRM/Advancedlogtables/LogTableTest.php @@ -16,7 +16,7 @@ * * @group headless */ -class CRM_Advancedlogtables_LogTableTest extends \CivixPhar\PHPUnit\Framework\TestCase implements HeadlessInterface, HookInterface, TransactionalInterface { +class CRM_Advancedlogtables_LogTableTest extends \PHPUnit\Framework\TestCase implements HeadlessInterface, HookInterface, TransactionalInterface { use \Civi\Test\Api3TestTrait; public function setUpHeadless() {