-
Notifications
You must be signed in to change notification settings - Fork 25
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #699 from nextcloud/techdebt/noid/fix-supported-da…
…tabases Add sqlite and oci compatibility
- Loading branch information
Showing
11 changed files
with
659 additions
and
81 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,146 @@ | ||
# This workflow is provided via the organization template repository | ||
# | ||
# https://github.com/nextcloud/.github | ||
# https://docs.github.com/en/actions/learn-github-actions/sharing-workflows-with-your-organization | ||
|
||
name: PHPUnit | ||
|
||
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 | ||
- master | ||
- stable* | ||
|
||
permissions: | ||
contents: read | ||
|
||
env: | ||
# Location of the phpunit.xml and phpunit.integration.xml files | ||
PHPUNIT_CONFIG: ./tests/phpunit.xml | ||
PHPUNIT_INTEGRATION_CONFIG: ./tests/phpunit.integration.xml | ||
|
||
jobs: | ||
phpunit-mysql: | ||
runs-on: ubuntu-latest | ||
|
||
strategy: | ||
matrix: | ||
php-versions: ['7.4', '8.0', '8.1'] | ||
server-versions: ['master'] | ||
|
||
services: | ||
mysql: | ||
image: mariadb:10.5 | ||
ports: | ||
- 4444:3306/tcp | ||
env: | ||
MYSQL_ROOT_PASSWORD: rootpassword | ||
options: --health-cmd="mysqladmin ping" --health-interval 5s --health-timeout 2s --health-retries 5 | ||
|
||
steps: | ||
- name: Set app env | ||
run: | | ||
# Split and keep last | ||
echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV | ||
- 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: Checkout server | ||
uses: actions/checkout@v3 | ||
with: | ||
submodules: true | ||
repository: nextcloud/server | ||
ref: ${{ matrix.server-versions }} | ||
|
||
- name: Checkout app | ||
uses: actions/checkout@v3 | ||
with: | ||
path: apps/${{ env.APP_NAME }} | ||
|
||
- name: Set up php ${{ matrix.php-versions }} | ||
uses: shivammathur/setup-php@v2 | ||
with: | ||
php-version: ${{ matrix.php-versions }} | ||
tools: phpunit | ||
extensions: mbstring, iconv, fileinfo, intl, mysql, pdo_mysql | ||
coverage: none | ||
|
||
- name: Check composer file existence | ||
id: check_composer | ||
uses: andstor/file-existence-action@v1 | ||
with: | ||
files: apps/${{ env.APP_NAME }}/composer.json | ||
|
||
- name: Set up PHPUnit | ||
# Only run if phpunit config file exists | ||
if: steps.check_composer.outputs.files_exists == 'true' | ||
working-directory: apps/${{ env.APP_NAME }} | ||
run: composer i | ||
|
||
- name: Set up Nextcloud | ||
env: | ||
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 --admin-pass password | ||
./occ app:enable ${{ env.APP_NAME }} | ||
- name: Check PHPUnit config file existence | ||
id: check_phpunit | ||
uses: andstor/file-existence-action@v1 | ||
with: | ||
files: apps/${{ env.APP_NAME }}/${{ env.PHPUNIT_CONFIG }} | ||
|
||
- name: PHPUnit | ||
# Only run if phpunit config file exists | ||
if: steps.check_phpunit.outputs.files_exists == 'true' | ||
working-directory: apps/${{ env.APP_NAME }} | ||
run: composer run test:unit | ||
|
||
- name: Check PHPUnit integration config file existence | ||
id: check_integration | ||
uses: andstor/file-existence-action@v1 | ||
with: | ||
files: apps/${{ env.APP_NAME }}/${{ env.PHPUNIT_INTEGRATION_CONFIG }} | ||
|
||
- name: Run Nextcloud | ||
# Only run if phpunit integration config file exists | ||
if: steps.check_integration.outputs.files_exists == 'true' | ||
run: php -S localhost:8080 & | ||
|
||
- name: PHPUnit integration | ||
# Only run if phpunit integration config file exists | ||
if: steps.check_integration.outputs.files_exists == 'true' | ||
working-directory: apps/${{ env.APP_NAME }} | ||
run: ./vendor/phpunit/phpunit/phpunit -c ${{ env.PHPUNIT_INTEGRATION_CONFIG }} | ||
|
||
summary: | ||
permissions: | ||
contents: none | ||
runs-on: ubuntu-latest | ||
needs: phpunit-mysql | ||
|
||
if: always() | ||
|
||
name: phpunit-mysql-summary | ||
|
||
steps: | ||
- name: Summary status | ||
run: if ${{ needs.phpunit-mysql.result != 'success' }}; then exit 1; fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
# This workflow is provided via the organization template repository | ||
# | ||
# https://github.com/nextcloud/.github | ||
# https://docs.github.com/en/actions/learn-github-actions/sharing-workflows-with-your-organization | ||
|
||
name: PHPUnit | ||
|
||
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 | ||
- master | ||
- stable* | ||
|
||
permissions: | ||
contents: read | ||
|
||
env: | ||
# Location of the phpunit.xml and phpunit.integration.xml files | ||
PHPUNIT_CONFIG: ./tests/phpunit.xml | ||
PHPUNIT_INTEGRATION_CONFIG: ./tests/phpunit.integration.xml | ||
|
||
jobs: | ||
phpunit-pgsql: | ||
runs-on: ubuntu-latest | ||
|
||
strategy: | ||
matrix: | ||
php-versions: ['8.0'] | ||
server-versions: ['master'] | ||
|
||
services: | ||
postgres: | ||
image: postgres | ||
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 | ||
|
||
steps: | ||
- name: Set app env | ||
run: | | ||
# Split and keep last | ||
echo "APP_NAME=${GITHUB_REPOSITORY##*/}" >> $GITHUB_ENV | ||
- name: Checkout server | ||
uses: actions/checkout@v3 | ||
with: | ||
submodules: true | ||
repository: nextcloud/server | ||
ref: ${{ matrix.server-versions }} | ||
|
||
- name: Checkout app | ||
uses: actions/checkout@v3 | ||
with: | ||
path: apps/${{ env.APP_NAME }} | ||
|
||
- name: Set up php ${{ matrix.php-versions }} | ||
uses: shivammathur/setup-php@v2 | ||
with: | ||
php-version: ${{ matrix.php-versions }} | ||
tools: phpunit | ||
extensions: mbstring, iconv, fileinfo, intl, pgsql, pdo_pgsql | ||
coverage: none | ||
|
||
- name: Check composer file existence | ||
id: check_composer | ||
uses: andstor/file-existence-action@v1 | ||
with: | ||
files: apps/${{ env.APP_NAME }}/composer.json | ||
|
||
- name: Set up PHPUnit | ||
# Only run if phpunit config file exists | ||
if: steps.check_composer.outputs.files_exists == 'true' | ||
working-directory: apps/${{ env.APP_NAME }} | ||
run: composer i | ||
|
||
- name: Set up Nextcloud | ||
env: | ||
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 --admin-pass password | ||
./occ app:enable ${{ env.APP_NAME }} | ||
- name: Check PHPUnit config file existence | ||
id: check_phpunit | ||
uses: andstor/file-existence-action@v1 | ||
with: | ||
files: apps/${{ env.APP_NAME }}/${{ env.PHPUNIT_CONFIG }} | ||
|
||
- name: PHPUnit | ||
# Only run if phpunit config file exists | ||
if: steps.check_phpunit.outputs.files_exists == 'true' | ||
working-directory: apps/${{ env.APP_NAME }} | ||
run: composer run test:unit | ||
|
||
- name: Check PHPUnit integration config file existence | ||
id: check_integration | ||
uses: andstor/file-existence-action@v1 | ||
with: | ||
files: apps/${{ env.APP_NAME }}/${{ env.PHPUNIT_INTEGRATION_CONFIG }} | ||
|
||
- name: Run Nextcloud | ||
# Only run if phpunit integration config file exists | ||
if: steps.check_integration.outputs.files_exists == 'true' | ||
run: php -S localhost:8080 & | ||
|
||
- name: PHPUnit integration | ||
# Only run if phpunit integration config file exists | ||
if: steps.check_integration.outputs.files_exists == 'true' | ||
working-directory: apps/${{ env.APP_NAME }} | ||
run: ./vendor/phpunit/phpunit/phpunit -c ${{ env.PHPUNIT_INTEGRATION_CONFIG }} | ||
|
||
summary: | ||
permissions: | ||
contents: none | ||
runs-on: ubuntu-latest | ||
needs: phpunit-pgsql | ||
|
||
if: always() | ||
|
||
name: phpunit-pgsql-summary | ||
|
||
steps: | ||
- name: Summary status | ||
run: if ${{ needs.phpunit-pgsql.result != 'success' }}; then exit 1; fi |
Oops, something went wrong.