From 600be5351b495a8cda2273427d2081bea862959a Mon Sep 17 00:00:00 2001 From: Vitor Mattos Date: Thu, 28 Mar 2024 12:45:27 -0300 Subject: [PATCH] feat: split behat tests Signed-off-by: Vitor Mattos --- .github/workflows/behat-mariadb.yml | 175 ++++++++++++++++++++++++ .github/workflows/behat-mysql.yml | 183 ++++++++++++++++++++++++++ .github/workflows/behat-pgsql.yml | 179 +++++++++++++++++++++++++ .github/workflows/behat-sqlite.yml | 170 ++++++++++++++++++++++++ .github/workflows/behat.yml | 127 ------------------ .github/workflows/phpunit-mariadb.yml | 25 ++-- .github/workflows/phpunit-mysql.yml | 25 ++-- .github/workflows/phpunit-pgsql.yml | 29 ++-- .github/workflows/phpunit-sqlite.yml | 23 ++-- tests/Api/ApiRequester.php | 2 +- 10 files changed, 761 insertions(+), 177 deletions(-) create mode 100644 .github/workflows/behat-mariadb.yml create mode 100644 .github/workflows/behat-mysql.yml create mode 100644 .github/workflows/behat-pgsql.yml create mode 100644 .github/workflows/behat-sqlite.yml delete mode 100644 .github/workflows/behat.yml diff --git a/.github/workflows/behat-mariadb.yml b/.github/workflows/behat-mariadb.yml new file mode 100644 index 000000000..22067142d --- /dev/null +++ b/.github/workflows/behat-mariadb.yml @@ -0,0 +1,175 @@ +name: Behat MariaDB + +on: pull_request + +permissions: + contents: read + +concurrency: + group: behat-mariadb-${{ github.head_ref || github.run_id }} + cancel-in-progress: true + +jobs: + matrix: + runs-on: ubuntu-latest + outputs: + php-version: ${{ steps.versions.outputs.php-available-list }} + server-max: ${{ steps.versions.outputs.branches-max-list }} + steps: + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Get version matrix + id: versions + uses: icewind1991/nextcloud-version-matrix@58becf3b4bb6dc6cef677b15e2fd8e7d48c0908f # v1.3.1 + + changes: + runs-on: ubuntu-latest + + outputs: + src: ${{ steps.changes.outputs.src}} + + steps: + - uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2 + id: changes + continue-on-error: true + with: + filters: | + src: + - '.github/workflows/**' + - 'appinfo/**' + - 'lib/**' + - 'templates/**' + - 'tests/**' + - 'vendor/**' + - 'vendor-bin/**' + - '.php-cs-fixer.dist.php' + - 'composer.json' + - 'composer.lock' + + behat-mariadb: + runs-on: ubuntu-latest + + needs: [changes, matrix] + if: needs.changes.outputs.src != 'false' + + strategy: + matrix: + php-versions: ${{ fromJson(needs.matrix.outputs.php-version) }} + server-versions: ${{ fromJson(needs.matrix.outputs.server-max) }} + mariadb-versions: ['10.6', '10.11'] + + name: MariaDB ${{ matrix.mariadb-versions }} PHP ${{ matrix.php-versions }} Nextcloud ${{ matrix.server-versions }} + + services: + mariadb: + image: ghcr.io/nextcloud/continuous-integration-mariadb-${{ matrix.mariadb-versions }}:latest + ports: + - 4444:3306/tcp + env: + MYSQL_ROOT_PASSWORD: rootpassword + options: --health-cmd="mysqladmin ping" --health-interval 5s --health-timeout 2s --health-retries 5 + mailhog: + image: mailhog/mailhog + ports: + - 8025:8025/tcp + - 1025:1025/tcp + + steps: + - name: Set app env + run: | + # Split and keep last + echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV + + - name: Checkout server + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + submodules: true + repository: nextcloud/server + ref: ${{ matrix.server-versions }} + + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + path: apps/${{ env.APP_NAME }} + + - name: Set up php ${{ matrix.php-versions }} + uses: shivammathur/setup-php@a4e22b60bbb9c1021113f2860347b0759f66fe5d # v2 + with: + php-version: ${{ matrix.php-versions }} + tools: phpunit + # https://docs.nextcloud.com/server/stable/admin_manual/installation/source_installation.html#prerequisites-for-manual-installation + extensions: bz2, ctype, curl, dom, fileinfo, gd, iconv, intl, json, libxml, mbstring, openssl, pcntl, posix, session, simplexml, xmlreader, xmlwriter, zip, zlib, mysql, pdo_mysql + coverage: none + ini-file: development + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Enable ONLY_FULL_GROUP_BY MariaDB option + run: | + echo "SET GLOBAL sql_mode=(SELECT CONCAT(@@sql_mode,',ONLY_FULL_GROUP_BY'));" | mysql -h 127.0.0.1 -P 4444 -u root -prootpassword + echo "SELECT @@sql_mode;" | mysql -h 127.0.0.1 -P 4444 -u root -prootpassword + + - name: Set up dependencies + working-directory: apps/${{ env.APP_NAME }} + run: | + composer install --no-dev + composer --working-dir=tests/integration install + + - name: Prevent Nextcloud OCP outdated + working-directory: apps/${{ env.APP_NAME }} + run: make updateocp + + - name: Set up Nextcloud + env: + DB_PORT: 4444 + run: | + sudo echo "127.0.0.1 mailhog" | sudo tee -a /etc/hosts + mkdir data + ./occ maintenance:install \ + --verbose \ + --database=mysql \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ + --admin-pass admin + ./occ --version + ./occ app:enable --force ${{ env.APP_NAME }} + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/notifications apps/notifications + ./occ app:enable --force notifications + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/activity apps/activity + ./occ app:enable --force activity + ./occ config:system:set mail_smtpport --value 1025 --type integer + ./occ config:system:set mail_smtphost --value mailhog + ./occ config:system:set allow_local_remote_servers --value true --type boolean + + - name: Run behat + working-directory: apps/${{ env.APP_NAME }}/tests/integration + env: + BEHAT_ROOT_DIR: ../../../../ + run: | + export BEHAT_RUN_AS=runner + export BEHAT_VERBOSE="$RUNNER_DEBUG" + vendor/bin/behat -f junit -f pretty --colors + + - name: Print logs + if: always() + run: | + cat data/nextcloud.log + + summary: + permissions: + contents: none + runs-on: ubuntu-latest + needs: [changes, behat-mariadb] + + if: always() + + name: behat-mariadb-summary + + steps: + - name: Summary status + run: if ${{ needs.changes.outputs.src != 'false' && needs.behat-mariadb.result != 'success' }}; then exit 1; fi diff --git a/.github/workflows/behat-mysql.yml b/.github/workflows/behat-mysql.yml new file mode 100644 index 000000000..167058160 --- /dev/null +++ b/.github/workflows/behat-mysql.yml @@ -0,0 +1,183 @@ +name: Behat MySQL + +on: pull_request + +permissions: + contents: read + +concurrency: + group: behat-mysql-${{ github.head_ref || github.run_id }} + cancel-in-progress: true + +jobs: + matrix: + runs-on: ubuntu-latest + outputs: + matrix: ${{ steps.versions.outputs.sparse-matrix }} + steps: + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Get version matrix + id: versions + uses: icewind1991/nextcloud-version-matrix@58becf3b4bb6dc6cef677b15e2fd8e7d48c0908f # v1.3.1 + with: + matrix: '{"mysql-versions": ["8.1"]}' + + changes: + runs-on: ubuntu-latest + + outputs: + src: ${{ steps.changes.outputs.src}} + + steps: + - uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2 + id: changes + continue-on-error: true + with: + filters: | + src: + - '.github/workflows/**' + - 'appinfo/**' + - 'lib/**' + - 'templates/**' + - 'tests/**' + - 'vendor/**' + - 'vendor-bin/**' + - '.php-cs-fixer.dist.php' + - 'composer.json' + - 'composer.lock' + + behat-mysql: + runs-on: ubuntu-latest + + needs: [changes, matrix] + if: needs.changes.outputs.src != 'false' + + strategy: + matrix: + php-versions: ${{ fromJson(needs.matrix.outputs.php-version) }} + server-versions: ${{ fromJson(needs.matrix.outputs.server-max) }} + + name: MySQL ${{ matrix.mysql-versions }} PHP ${{ matrix.php-versions }} Nextcloud ${{ matrix.server-versions }} + + services: + mysql: + image: ghcr.io/nextcloud/continuous-integration-mysql-${{ matrix.mysql-versions }}:latest + ports: + - 4444:3306/tcp + env: + MYSQL_ROOT_PASSWORD: rootpassword + options: --health-cmd="mysqladmin ping" --health-interval 5s --health-timeout 2s --health-retries 10 + mailhog: + image: mailhog/mailhog + ports: + - 8025:8025/tcp + - 1025:1025/tcp + + steps: + - name: Set app env + run: | + # Split and keep last + echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV + + - name: Checkout server + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + submodules: true + repository: nextcloud/server + ref: ${{ matrix.server-versions }} + + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + path: apps/${{ env.APP_NAME }} + + - name: Set up php ${{ matrix.php-versions }} + uses: shivammathur/setup-php@a4e22b60bbb9c1021113f2860347b0759f66fe5d # v2 + with: + php-version: ${{ matrix.php-versions }} + tools: phpunit + # https://docs.nextcloud.com/server/stable/admin_manual/installation/source_installation.html#prerequisites-for-manual-installation + extensions: bz2, ctype, curl, dom, fileinfo, gd, iconv, intl, json, libxml, mbstring, openssl, pcntl, posix, session, simplexml, xmlreader, xmlwriter, zip, zlib, sqlite, pdo_sqlite + coverage: none + ini-file: development + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Enable ONLY_FULL_GROUP_BY MySQL option + run: | + echo "SET GLOBAL sql_mode=(SELECT CONCAT(@@sql_mode,',ONLY_FULL_GROUP_BY'));" | mysql -h 127.0.0.1 -P 4444 -u root -prootpassword + echo "SELECT @@sql_mode;" | mysql -h 127.0.0.1 -P 4444 -u root -prootpassword + + - name: Check composer file existence + id: check_composer + uses: andstor/file-existence-action@076e0072799f4942c8bc574a82233e1e4d13e9d6 # v3.0.0 + with: + files: apps/${{ env.APP_NAME }}/composer.json + + - name: Set up dependencies + # Only run if phpunit config file exists + if: steps.check_composer.outputs.files_exists == 'true' + working-directory: apps/${{ env.APP_NAME }} + run: | + composer install --no-dev + composer --working-dir=tests/integration install + + - name: Prevent Nextcloud OCP outdated + working-directory: apps/${{ env.APP_NAME }} + run: make updateocp + + - name: Set up Nextcloud + env: + DB_PORT: 4444 + run: | + sudo echo "127.0.0.1 mailhog" | sudo tee -a /etc/hosts + mkdir data + ./occ maintenance:install \ + --verbose \ + --database=mysql \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ + --admin-pass admin + ./occ --version + ./occ app:enable --force ${{ env.APP_NAME }} + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/notifications apps/notifications + ./occ app:enable --force notifications + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/activity apps/activity + ./occ app:enable --force activity + ./occ config:system:set mail_smtpport --value 1025 --type integer + ./occ config:system:set mail_smtphost --value mailhog + ./occ config:system:set allow_local_remote_servers --value true --type boolean + + - name: Run behat + working-directory: apps/${{ env.APP_NAME }}/tests/integration + env: + BEHAT_ROOT_DIR: ../../../../ + run: | + export BEHAT_RUN_AS=runner + export BEHAT_VERBOSE="$RUNNER_DEBUG" + vendor/bin/behat -f junit -f pretty --colors + + - name: Print logs + if: always() + run: | + cat data/nextcloud.log + + summary: + permissions: + contents: none + runs-on: ubuntu-latest + needs: [changes, behat-mysql] + + if: always() + + name: behat-mysql-summary + + steps: + - name: Summary status + run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-mysql.result != 'success' }}; then exit 1; fi diff --git a/.github/workflows/behat-pgsql.yml b/.github/workflows/behat-pgsql.yml new file mode 100644 index 000000000..0df082673 --- /dev/null +++ b/.github/workflows/behat-pgsql.yml @@ -0,0 +1,179 @@ +name: Behat PostgreSQL + +on: pull_request + +permissions: + contents: read + +concurrency: + group: behat-pgsql-${{ github.head_ref || github.run_id }} + cancel-in-progress: true + +jobs: + matrix: + runs-on: ubuntu-latest + outputs: + php-version: ${{ steps.versions.outputs.php-available-list }} + server-max: ${{ steps.versions.outputs.branches-max-list }} + steps: + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Get version matrix + id: versions + uses: icewind1991/nextcloud-version-matrix@58becf3b4bb6dc6cef677b15e2fd8e7d48c0908f # v1.3.1 + + changes: + runs-on: ubuntu-latest + + outputs: + src: ${{ steps.changes.outputs.src}} + + steps: + - uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2 + id: changes + continue-on-error: true + with: + filters: | + src: + - '.github/workflows/**' + - 'appinfo/**' + - 'lib/**' + - 'templates/**' + - 'tests/**' + - 'vendor/**' + - 'vendor-bin/**' + - '.php-cs-fixer.dist.php' + - 'composer.json' + - 'composer.lock' + + behat-pgsql: + runs-on: ubuntu-latest + + needs: [changes, matrix] + if: needs.changes.outputs.src != 'false' + + strategy: + matrix: + php-versions: ${{ fromJson(needs.matrix.outputs.php-version) }} + server-versions: ${{ fromJson(needs.matrix.outputs.server-max) }} + + name: PostgreSQL PHP ${{ matrix.mysql-versions }} PHP ${{ matrix.php-versions }} Nextcloud ${{ matrix.server-versions }} + + services: + postgres: + image: ghcr.io/nextcloud/continuous-integration-postgres-14:latest + ports: + - 4444:5432/tcp + env: + POSTGRES_USER: root + POSTGRES_PASSWORD: rootpassword + POSTGRES_DB: nextcloud + options: --health-cmd pg_isready --health-interval 5s --health-timeout 2s --health-retries 5 + mailhog: + image: mailhog/mailhog + ports: + - 8025:8025/tcp + - 1025:1025/tcp + + steps: + - name: Set app env + run: | + # Split and keep last + echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV + + - name: Checkout server + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + submodules: true + repository: nextcloud/server + ref: ${{ matrix.server-versions }} + + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + path: apps/${{ env.APP_NAME }} + + - name: Set up php ${{ matrix.php-versions }} + uses: shivammathur/setup-php@a4e22b60bbb9c1021113f2860347b0759f66fe5d # v2 + with: + php-version: ${{ matrix.php-versions }} + tools: phpunit + # https://docs.nextcloud.com/server/stable/admin_manual/installation/source_installation.html#prerequisites-for-manual-installation + extensions: bz2, ctype, curl, dom, fileinfo, gd, iconv, intl, json, libxml, mbstring, openssl, pcntl, posix, session, simplexml, xmlreader, xmlwriter, zip, zlib, pgsql, pdo_pgsql + coverage: none + ini-file: development + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Check composer file existence + id: check_composer + uses: andstor/file-existence-action@076e0072799f4942c8bc574a82233e1e4d13e9d6 # v3.0.0 + with: + files: apps/${{ env.APP_NAME }}/composer.json + + - name: Set up dependencies + # Only run if phpunit config file exists + if: steps.check_composer.outputs.files_exists == 'true' + working-directory: apps/${{ env.APP_NAME }} + run: | + composer install --no-dev + composer --working-dir=tests/integration install + + - name: Prevent Nextcloud OCP outdated + working-directory: apps/${{ env.APP_NAME }} + run: make updateocp + + - name: Set up Nextcloud + env: + DB_PORT: 4444 + run: | + sudo echo "127.0.0.1 mailhog" | sudo tee -a /etc/hosts + mkdir data + ./occ maintenance:install \ + --verbose \ + --database=pgsql \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ + --admin-pass admin + ./occ --version + ./occ app:enable --force ${{ env.APP_NAME }} + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/notifications apps/notifications + ./occ app:enable --force notifications + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/activity apps/activity + ./occ app:enable --force activity + ./occ config:system:set mail_smtpport --value 1025 --type integer + ./occ config:system:set mail_smtphost --value mailhog + ./occ config:system:set allow_local_remote_servers --value true --type boolean + + - name: Run behat + working-directory: apps/${{ env.APP_NAME }}/tests/integration + env: + BEHAT_ROOT_DIR: ../../../../ + run: | + export BEHAT_RUN_AS=runner + export BEHAT_VERBOSE="$RUNNER_DEBUG" + vendor/bin/behat -f junit -f pretty --colors + + - name: Print logs + if: always() + run: | + cat data/nextcloud.log + + summary: + permissions: + contents: none + runs-on: ubuntu-latest + needs: [changes, behat-pgsql] + + if: always() + + name: behat-pgsql-summary + + steps: + - name: Summary status + run: if ${{ needs.changes.outputs.src != 'false' && needs.behat-pgsql.result != 'success' }}; then exit 1; fi diff --git a/.github/workflows/behat-sqlite.yml b/.github/workflows/behat-sqlite.yml new file mode 100644 index 000000000..900ff9fc8 --- /dev/null +++ b/.github/workflows/behat-sqlite.yml @@ -0,0 +1,170 @@ +name: Behat SQLite + +on: pull_request + +permissions: + contents: read + +concurrency: + group: behat-sqlite-${{ github.head_ref || github.run_id }} + cancel-in-progress: true + +jobs: + matrix: + runs-on: ubuntu-latest + outputs: + php-version: ${{ steps.versions.outputs.php-available-list }} + server-max: ${{ steps.versions.outputs.branches-max-list }} + steps: + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Get version matrix + id: versions + uses: icewind1991/nextcloud-version-matrix@58becf3b4bb6dc6cef677b15e2fd8e7d48c0908f # v1.3.1 + + changes: + runs-on: ubuntu-latest + + outputs: + src: ${{ steps.changes.outputs.src}} + + steps: + - uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2 + id: changes + continue-on-error: true + with: + filters: | + src: + - '.github/workflows/**' + - 'appinfo/**' + - 'lib/**' + - 'templates/**' + - 'tests/**' + - 'vendor/**' + - 'vendor-bin/**' + - '.php-cs-fixer.dist.php' + - 'composer.json' + - 'composer.lock' + + behat-sqlite: + runs-on: ubuntu-latest + + needs: [changes, matrix] + if: needs.changes.outputs.src != 'false' + + strategy: + matrix: + php-versions: ${{ fromJson(needs.matrix.outputs.php-version) }} + server-versions: ${{ fromJson(needs.matrix.outputs.server-max) }} + + name: SQLite PHP ${{ matrix.mysql-versions }} PHP ${{ matrix.php-versions }} Nextcloud ${{ matrix.server-versions }} + + services: + mailhog: + image: mailhog/mailhog + ports: + - 8025:8025/tcp + - 1025:1025/tcp + + steps: + - name: Set app env + run: | + # Split and keep last + echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV + + - name: Checkout server + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + submodules: true + repository: nextcloud/server + ref: ${{ matrix.server-versions }} + + - name: Checkout app + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + with: + path: apps/${{ env.APP_NAME }} + + - name: Set up php ${{ matrix.php-versions }} + uses: shivammathur/setup-php@a4e22b60bbb9c1021113f2860347b0759f66fe5d # v2 + with: + php-version: ${{ matrix.php-versions }} + tools: phpunit + # https://docs.nextcloud.com/server/stable/admin_manual/installation/source_installation.html#prerequisites-for-manual-installation + extensions: bz2, ctype, curl, dom, fileinfo, gd, iconv, intl, json, libxml, mbstring, openssl, pcntl, posix, session, simplexml, xmlreader, xmlwriter, zip, zlib, sqlite, pdo_sqlite + coverage: none + ini-file: development + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Check composer file existence + id: check_composer + uses: andstor/file-existence-action@076e0072799f4942c8bc574a82233e1e4d13e9d6 # v3.0.0 + with: + files: apps/${{ env.APP_NAME }}/composer.json + + - name: Set up dependencies + # Only run if phpunit config file exists + if: steps.check_composer.outputs.files_exists == 'true' + working-directory: apps/${{ env.APP_NAME }} + run: | + composer install --no-dev + composer --working-dir=tests/integration install + + - name: Prevent Nextcloud OCP outdated + working-directory: apps/${{ env.APP_NAME }} + run: make updateocp + + - name: Set up Nextcloud + env: + DB_PORT: 4444 + run: | + sudo echo "127.0.0.1 mailhog" | sudo tee -a /etc/hosts + mkdir data + ./occ maintenance:install \ + --verbose \ + --database=sqlite \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ + --admin-pass admin + ./occ --version + ./occ app:enable --force ${{ env.APP_NAME }} + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/notifications apps/notifications + ./occ app:enable --force notifications + git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/activity apps/activity + ./occ app:enable --force activity + ./occ config:system:set mail_smtpport --value 1025 --type integer + ./occ config:system:set mail_smtphost --value mailhog + ./occ config:system:set allow_local_remote_servers --value true --type boolean + + - name: Run behat + working-directory: apps/${{ env.APP_NAME }}/tests/integration + env: + BEHAT_ROOT_DIR: ../../../../ + run: | + export BEHAT_RUN_AS=runner + export BEHAT_VERBOSE="$RUNNER_DEBUG" + vendor/bin/behat -f junit -f pretty --colors + + - name: Print logs + if: always() + run: | + cat data/nextcloud.log + + summary: + permissions: + contents: none + runs-on: ubuntu-latest + needs: [changes, behat-sqlite] + + if: always() + + name: behat-sqlite-summary + + steps: + - name: Summary status + run: if ${{ needs.changes.outputs.src != 'false' && needs.behat-sqlite.result != 'success' }}; then exit 1; fi diff --git a/.github/workflows/behat.yml b/.github/workflows/behat.yml deleted file mode 100644 index 16e7eaafc..000000000 --- a/.github/workflows/behat.yml +++ /dev/null @@ -1,127 +0,0 @@ -name: Behat - -on: - pull_request: - paths: - - '.github/workflows/**' - - 'appinfo/**' - - 'lib/**' - - 'templates/**' - - 'tests/**' - - 'vendor/**' - - 'vendor-bin/**' - - '.php-cs-fixer.dist.php' - - 'composer.json' - - 'composer.lock' - push: - branches: - - main - - stable* - -env: - APP_NAME: libresign - -jobs: - behat: - runs-on: ubuntu-latest - strategy: - fail-fast: false - matrix: - php-versions: ['8.0', '8.1', '8.2'] - databases: ['sqlite', 'mysql', 'pgsql'] - server-versions: ['master'] - - name: php${{ matrix.php-versions }}-${{ matrix.databases }}-${{ matrix.server-versions }} - - services: - postgres: - image: postgres:15 - ports: - - 4445:5432/tcp - env: - POSTGRES_USER: root - POSTGRES_PASSWORD: rootpassword - POSTGRES_DB: nextcloud - options: --health-cmd pg_isready --health-interval 5s --health-timeout 2s --health-retries 5 - mysql: - image: ghcr.io/nextcloud/continuous-integration-mariadb-10.6:latest - ports: - - 4444:3306/tcp - env: - MYSQL_ROOT_PASSWORD: rootpassword - options: --health-cmd="mysqladmin ping" --health-interval 5s --health-timeout 2s --health-retries 5 - mailhog: - image: mailhog/mailhog - ports: - - 8025:8025/tcp - - 1025:1025/tcp - - steps: - - name: Checkout server - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - with: - repository: nextcloud/server - ref: ${{ matrix.server-versions }} - - - name: Checkout submodules - shell: bash - run: | - auth_header="$(git config --local --get http.https://github.com/.extraheader)" - git submodule sync --recursive - git -c "http.extraheader=$auth_header" -c protocol.version=2 submodule update --init --force --recursive --depth=1 - - - name: Checkout app - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - with: - path: apps/${{ env.APP_NAME }} - - - name: Set up php ${{ matrix.php-versions }} - uses: shivammathur/setup-php@a4e22b60bbb9c1021113f2860347b0759f66fe5d # 2.30.0 - with: - php-version: ${{ matrix.php-versions }} - tools: phpunit - extensions: mbstring, iconv, fileinfo, intl, sqlite, pdo_sqlite, mysql, pdo_mysql, pgsql, pdo_pgsql, - coverage: none - - - name: Set up dependencies - working-directory: apps/${{ env.APP_NAME }} - run: | - composer install --no-dev - composer --working-dir=tests/integration install - - - name: Set up Nextcloud - run: | - if [ "${{ matrix.databases }}" = "mysql" ]; then - export DB_PORT=4444 - elif [ "${{ matrix.databases }}" = "pgsql" ]; then - export DB_PORT=4445 - fi - sudo echo "127.0.0.1 mailhog" | sudo tee -a /etc/hosts - mkdir data - ./occ maintenance:install \ - --verbose \ - --database=${{ matrix.databases }} \ - --database-name=nextcloud \ - --database-host=127.0.0.1 \ - --database-port=$DB_PORT \ - --database-user=root \ - --database-pass=rootpassword \ - --admin-user=admin \ - --admin-pass=admin - ./occ app:enable ${{ env.APP_NAME }} - git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/notifications apps/notifications - ./occ app:enable --force notifications - git clone --depth 1 -b ${{ matrix.server-versions }} https://github.com/nextcloud/activity apps/activity - ./occ app:enable --force activity - ./occ config:system:set mail_smtpport --value 1025 --type integer - ./occ config:system:set mail_smtphost --value mailhog - ./occ config:system:set allow_local_remote_servers --value true --type boolean - - - name: Run behat - working-directory: apps/${{ env.APP_NAME }}/tests/integration - env: - BEHAT_ROOT_DIR: ../../../../ - run: | - export BEHAT_RUN_AS=runner - export BEHAT_VERBOSE="$RUNNER_DEBUG" - vendor/bin/behat -f junit -f pretty --colors diff --git a/.github/workflows/phpunit-mariadb.yml b/.github/workflows/phpunit-mariadb.yml index 38eefad34..c81da7de4 100644 --- a/.github/workflows/phpunit-mariadb.yml +++ b/.github/workflows/phpunit-mariadb.yml @@ -139,16 +139,17 @@ jobs: DB_PORT: 4444 run: | mkdir data - ./occ maintenance:install - --verbose - --database=mysql - --database-name=nextcloud - --database-host=127.0.0.1 - --database-port=$DB_PORT - --database-user=root - --database-pass=rootpassword - --admin-user admin + ./occ maintenance:install \ + --verbose \ + --database=mysql \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ --admin-pass admin + ./occ --version ./occ app:enable --force ${{ env.APP_NAME }} - name: Set up dependencies apps @@ -173,7 +174,7 @@ jobs: summary: permissions: contents: none - runs-on: ubuntu-latest-low + runs-on: ubuntu-latest needs: [changes, phpunit-mariadb] if: always() @@ -182,10 +183,10 @@ jobs: steps: - name: Summary status - run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-sqlite.result != 'success' }}; then exit 1; fi + run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-mariadb.result != 'success' }}; then exit 1; fi upload-coverage: - needs: phpunit + needs: [changes, phpunit-mariadb] runs-on: ubuntu-latest steps: - name: Upload coverage results to Coveralls diff --git a/.github/workflows/phpunit-mysql.yml b/.github/workflows/phpunit-mysql.yml index 1025234c7..0361ede80 100644 --- a/.github/workflows/phpunit-mysql.yml +++ b/.github/workflows/phpunit-mysql.yml @@ -139,16 +139,17 @@ jobs: DB_PORT: 4444 run: | mkdir data - ./occ maintenance:install - --verbose - --database=mysql - --database-name=nextcloud - --database-host=127.0.0.1 - --database-port=$DB_PORT - --database-user=root - --database-pass=rootpassword - --admin-user admin + ./occ maintenance:install \ + --verbose \ + --database=mysql \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ --admin-pass admin + ./occ --version ./occ app:enable --force ${{ env.APP_NAME }} - name: Set up dependencies apps @@ -173,7 +174,7 @@ jobs: summary: permissions: contents: none - runs-on: ubuntu-latest-low + runs-on: ubuntu-latest needs: [changes, phpunit-mysql] if: always() @@ -182,10 +183,10 @@ jobs: steps: - name: Summary status - run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-sqlite.result != 'success' }}; then exit 1; fi + run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-mysql.result != 'success' }}; then exit 1; fi upload-coverage: - needs: phpunit + needs: [changes, phpunit-mysql] runs-on: ubuntu-latest steps: - name: Upload coverage results to Coveralls diff --git a/.github/workflows/phpunit-pgsql.yml b/.github/workflows/phpunit-pgsql.yml index b3d69a8ed..abfeedf8e 100644 --- a/.github/workflows/phpunit-pgsql.yml +++ b/.github/workflows/phpunit-pgsql.yml @@ -135,16 +135,17 @@ jobs: DB_PORT: 4444 run: | mkdir data - ./occ maintenance:install - --verbose - --database=pgsql - --database-name=nextcloud - --database-host=127.0.0.1 - --database-port=$DB_PORT - --database-user=root - --database-pass=rootpassword - --admin-user admin + ./occ maintenance:install \ + --verbose \ + --database=pgsql \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ --admin-pass admin + ./occ --version ./occ app:enable --force ${{ env.APP_NAME }} - name: Set up dependencies apps @@ -169,19 +170,19 @@ jobs: summary: permissions: contents: none - runs-on: ubuntu-latest-low - needs: [changes, phpunit-mariadb] + runs-on: ubuntu-latest + needs: [changes, phpunit-pgsql] if: always() - name: phpunit-mariadb-summary + name: phpunit-pgsql-summary steps: - name: Summary status - run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-sqlite.result != 'success' }}; then exit 1; fi + run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-pgsql.result != 'success' }}; then exit 1; fi upload-coverage: - needs: phpunit + needs: [changes, phpunit-pgsql] runs-on: ubuntu-latest steps: - name: Upload coverage results to Coveralls diff --git a/.github/workflows/phpunit-sqlite.yml b/.github/workflows/phpunit-sqlite.yml index d2cb2629f..77cb53a5c 100644 --- a/.github/workflows/phpunit-sqlite.yml +++ b/.github/workflows/phpunit-sqlite.yml @@ -130,16 +130,17 @@ jobs: DB_PORT: 4444 run: | mkdir data - ./occ maintenance:install - --verbose - --database=sqlite - --database-name=nextcloud - --database-host=127.0.0.1 - --database-port=$DB_PORT - --database-user=root - --database-pass=rootpassword - --admin-user admin + ./occ maintenance:install \ + --verbose \ + --database=sqlite \ + --database-name=nextcloud \ + --database-host=127.0.0.1 \ + --database-port=$DB_PORT \ + --database-user=root \ + --database-pass=rootpassword \ + --admin-user admin \ --admin-pass admin + ./occ --version ./occ app:enable --force ${{ env.APP_NAME }} - name: Set up dependencies apps @@ -164,7 +165,7 @@ jobs: summary: permissions: contents: none - runs-on: ubuntu-latest-low + runs-on: ubuntu-latest needs: [changes, phpunit-sqlite] if: always() @@ -176,7 +177,7 @@ jobs: run: if ${{ needs.changes.outputs.src != 'false' && needs.phpunit-sqlite.result != 'success' }}; then exit 1; fi upload-coverage: - needs: phpunit + needs: [changes, phpunit-sqlite] runs-on: ubuntu-latest steps: - name: Upload coverage results to Coveralls diff --git a/tests/Api/ApiRequester.php b/tests/Api/ApiRequester.php index 818c498f3..b79c5dc0e 100644 --- a/tests/Api/ApiRequester.php +++ b/tests/Api/ApiRequester.php @@ -28,7 +28,7 @@ protected function handleRequest(RequestInterface $request) { $response = Response::getInstance(http_response_code()); $response = $response->withBody(new Stream($body)); - $headers = xdebug_get_headers(); + $headers = \xdebug_get_headers(); foreach ($headers as $header) { $header = explode(': ', $header, 2); $response = $response->withHeader($header[0], $header[1]);