name: WOPI Integration tests on: pull_request: push: branches: - master - stable* env: APP_NAME: richdocuments jobs: php: runs-on: ubuntu-latest strategy: # do not stop on another job's failure fail-fast: false matrix: php-versions: ['7.3', '7.4'] databases: ['sqlite'] server-versions: ['master'] name: php${{ matrix.php-versions }}-${{ matrix.databases }}-${{ matrix.server-versions }} services: collabora: image: collabora/code env: extra_params: '--o:ssl.enable=false' domain: nextcloud ports: - "9980:9980" steps: - name: Checkout server uses: actions/checkout@v2 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@v2 with: path: apps/${{ env.APP_NAME }} - name: Set up php ${{ matrix.php-versions }} uses: shivammathur/setup-php@v1 with: php-version: ${{ matrix.php-versions }} tools: phpunit:8.5.14 extensions: mbstring, iconv, fileinfo, intl, sqlite, pdo_sqlite coverage: none - name: Set up PHPUnit 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=${{ 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 password ./occ app:enable --force ${{ env.APP_NAME }} export OC_PASS=123456 ./occ user:add --password-from-env user1 ./occ user:add --password-from-env user2 - name: Run WOPI integration tests working-directory: apps/${{ env.APP_NAME }} run: cd tests && bash run-integration.sh features/wopi mysql: runs-on: ubuntu-latest strategy: # do not stop on another job's failure fail-fast: false matrix: php-versions: ['7.3', '7.4'] databases: ['mysql'] server-versions: ['master'] name: php${{ matrix.php-versions }}-${{ matrix.databases }}-${{ matrix.server-versions }} services: mysql: image: mariadb ports: - 4444:3306/tcp env: MYSQL_ROOT_PASSWORD: rootpassword options: --health-cmd="mysqladmin ping" --health-interval 5s --health-timeout 2s --health-retries 5 collabora: image: collabora/code env: extra_params: '--o:ssl.enable=false' domain: nextcloud ports: - "9980:9980" steps: - name: Checkout server uses: actions/checkout@v2 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@v2 with: path: apps/${{ env.APP_NAME }} - name: Set up php ${{ matrix.php-versions }} uses: shivammathur/setup-php@v1 with: php-version: ${{ matrix.php-versions }} tools: phpunit:8.5.14 extensions: mbstring, iconv, fileinfo, intl, mysql, pdo_mysql coverage: none - name: Set up PHPUnit 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=${{ 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 password ./occ app:enable --force ${{ env.APP_NAME }} export OC_PASS=123456 ./occ user:add --password-from-env user1 ./occ user:add --password-from-env user2 - name: Run WOPI integration tests working-directory: apps/${{ env.APP_NAME }} run: cd tests && bash run-integration.sh features/wopi pgsql: runs-on: ubuntu-latest strategy: # do not stop on another job's failure fail-fast: false matrix: php-versions: ['7.4'] databases: ['pgsql'] server-versions: ['master'] name: php${{ matrix.php-versions }}-${{ matrix.databases }}-${{ matrix.server-versions }} 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 collabora: image: collabora/code env: extra_params: '--o:ssl.enable=false' domain: nextcloud ports: - "9980:9980" steps: - name: Checkout server uses: actions/checkout@v2 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@v2 with: path: apps/${{ env.APP_NAME }} - name: Set up php ${{ matrix.php-versions }} uses: shivammathur/setup-php@v1 with: php-version: ${{ matrix.php-versions }} tools: phpunit:8.5.14 extensions: mbstring, iconv, fileinfo, intl, pgsql, pdo_pgsql coverage: none - name: Set up PHPUnit 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=${{ 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 password ./occ app:enable --force ${{ env.APP_NAME }} export OC_PASS=123456 ./occ user:add --password-from-env user1 ./occ user:add --password-from-env user2 - name: Run WOPI integration tests working-directory: apps/${{ env.APP_NAME }} run: cd tests && bash run-integration.sh features/wopi oci: runs-on: ubuntu-latest strategy: # do not stop on another job's failure fail-fast: false matrix: php-versions: ['7.4'] databases: ['oci'] server-versions: ['master'] name: php${{ matrix.php-versions }}-${{ matrix.databases }}-${{ matrix.server-versions }} services: oracle: image: deepdiver/docker-oracle-xe-11g ports: - "1521:1521" collabora: image: collabora/code env: extra_params: '--o:ssl.enable=false' domain: nextcloud ports: - "9980:9980" steps: - name: Checkout server uses: actions/checkout@v2 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@v2 with: path: apps/${{ env.APP_NAME }} - name: Set up php ${{ matrix.php-versions }} uses: "shivammathur/setup-php@v2" with: php-version: "${{ matrix.php-versions }}" extensions: mbstring, iconv, fileinfo, intl, oci8 tools: phpunit:8.5.15 coverage: none - name: Set up PHPUnit working-directory: apps/${{ env.APP_NAME }} run: composer i - name: Set up Nextcloud run: | mkdir data ./occ maintenance:install --verbose --database=oci --database-name=XE --database-host=127.0.0.1 --database-port=1521 --database-user=autotest --database-pass=owncloud --admin-user admin --admin-pass admin php -f index.php ./occ app:enable --force ${{ env.APP_NAME }} export OC_PASS=123456 ./occ user:add --password-from-env user1 ./occ user:add --password-from-env user2 - name: Run WOPI integration tests working-directory: apps/${{ env.APP_NAME }} run: cd tests && bash run-integration.sh features/wopi