name: Backend Integration Tests on: push: paths: - 'backend/src/**' - 'backend/package.json' - 'backend/pnpm-lock.yaml' - 'backend/tests/**' - '.github/workflows/backend-integration-test.yaml' pull_request: paths: - 'backend/src/**' workflow_dispatch: inputs: use-aws: description: 'Run recording tests in AWS EC2 runner' default: 'true' aws-instance-type: description: 'AWS EC2 instance type' default: 'c5.2xlarge' jobs: build-components: name: Build OpenVidu Components Angular runs-on: ov-actions-runner steps: - name: Build Components id: build uses: OpenVidu/actions/build-openvidu-components-angular@main outputs: artifact_name: ${{ steps.build.outputs.artifact_name }} test-api: name: ${{ matrix.test-name }} needs: build-components runs-on: ov-actions-runner strategy: fail-fast: false matrix: include: - test-name: 'Rooms API Tests' test-script: 'test:integration-backend-rooms' - test-name: 'Webhook Tests' test-script: 'test:integration-backend-webhooks' - test-name: 'Security API Tests' test-script: 'test:integration-backend-security' azure-container: 'openvidu-appdata-security' - test-name: 'Global Config API Tests' test-script: 'test:integration-backend-global-config' - test-name: 'Participants API Tests' test-script: 'test:integration-backend-participants' - test-name: 'Meetings API Tests' test-script: 'test:integration-backend-meetings' - test-name: 'Users API Tests' test-script: 'test:integration-backend-users' steps: - name: Install LK CLI run: curl -sSL https://get.livekit.io/cli | bash - name: Setup Node.js uses: actions/setup-node@v5 with: node-version: '22.13' - name: Setup pnpm uses: pnpm/action-setup@v2 with: version: 10 - name: Setup OpenVidu Local Deployment uses: OpenVidu/actions/start-openvidu-local-deployment@main with: ref-openvidu-local-deployment: development pre_startup_commands: | cat <<'BASH' > pre_startup_commands.sh #!/bin/bash echo "Commenting out openvidu-meet container in docker-compose.yaml" if [ -f docker-compose.yaml ]; then yq e 'del(.services.openvidu-meet)' -i docker-compose.yaml fi BASH chmod +x pre_startup_commands.sh && ./pre_startup_commands.sh - name: Setup OpenVidu Meet uses: OpenVidu/actions/start-openvidu-meet@main with: build_components_angular: 'true' components_artifact_name: ${{ needs.build-components.outputs.artifact_name }} env: MEET_AZURE_CONTAINER_NAME: ${{ matrix.azure-container || '' }} - name: Run tests run: pnpm run ${{ matrix.test-script }} env: JEST_JUNIT_OUTPUT_DIR: './backend/reports/' - name: Upload OpenVidu Meet logs if: failure() uses: actions/upload-artifact@v4 with: name: ${{ matrix.test-name }}-openvidu-meet-logs path: meet_backend.log retention-days: 2 - name: Publish Test Report uses: mikepenz/action-junit-report@v4 if: always() with: report_paths: '**/reports/junit.xml' fail_on_failure: true require_tests: true - name: Clean up if: always() uses: OpenVidu/actions/cleanup@main start-aws-runner-s3: name: Prepare AWS runner (S3) runs-on: ov-actions-runner if: ${{ inputs.use-aws != 'false' }} outputs: label: ${{ steps.start-ec2-runner.outputs.label }} ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} steps: - name: Start AWS EC2 Runner id: start-ec2-runner uses: OpenVidu/actions/start-aws-runner@main with: aws-instance-type: ${{ inputs.aws-instance-type || 'c5.2xlarge' }} aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} aws-region: ${{ vars.AWS_REGION }} github-token: ${{ secrets.OPENVIDU_GITHUB_TOKEN }} ec2-image-id: ${{ vars.AWS_GITHUB_ACTIONS_AMI }} subnet-id: ${{ vars.AWS_SUBNET_ID }} security-group-id: ${{ vars.AWS_SECURITY_GROUP_ID }} workflow-name: ${{ github.workflow }}-s3 repository-name: ${{ github.repository }} start-aws-runner-abs: name: Prepare AWS runner (ABS) runs-on: ov-actions-runner if: ${{ inputs.use-aws != 'false' }} outputs: label: ${{ steps.start-ec2-runner.outputs.label }} ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} steps: - name: Start AWS EC2 Runner id: start-ec2-runner uses: OpenVidu/actions/start-aws-runner@main with: aws-instance-type: ${{ inputs.aws-instance-type || 'c5.2xlarge' }} aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} aws-region: ${{ vars.AWS_REGION }} github-token: ${{ secrets.OPENVIDU_GITHUB_TOKEN }} ec2-image-id: ${{ vars.AWS_GITHUB_ACTIONS_AMI }} subnet-id: ${{ vars.AWS_SUBNET_ID }} security-group-id: ${{ vars.AWS_SECURITY_GROUP_ID }} workflow-name: ${{ github.workflow }}-abs repository-name: ${{ github.repository }} start-aws-runner-gcs: name: Prepare AWS runner (GCS) runs-on: ov-actions-runner if: ${{ inputs.use-aws != 'false' }} outputs: label: ${{ steps.start-ec2-runner.outputs.label }} ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} steps: - name: Start AWS EC2 Runner id: start-ec2-runner uses: OpenVidu/actions/start-aws-runner@main with: aws-instance-type: ${{ inputs.aws-instance-type || 'c5.2xlarge' }} aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} aws-region: ${{ vars.AWS_REGION }} github-token: ${{ secrets.OPENVIDU_GITHUB_TOKEN }} ec2-image-id: ${{ vars.AWS_GITHUB_ACTIONS_AMI }} subnet-id: ${{ vars.AWS_SUBNET_ID }} security-group-id: ${{ vars.AWS_SECURITY_GROUP_ID }} workflow-name: ${{ github.workflow }}-gcs repository-name: ${{ github.repository }} test-recordings: name: Recordings API Tests (${{ matrix.storage-provider }}) needs: - start-aws-runner-s3 - start-aws-runner-abs - start-aws-runner-gcs - build-components if: ${{ always() && (needs.start-aws-runner-s3.result == 'success' || needs.start-aws-runner-s3.result == 'skipped') && (needs.start-aws-runner-abs.result == 'success' || needs.start-aws-runner-abs.result == 'skipped') && (needs.start-aws-runner-gcs.result == 'success' || needs.start-aws-runner-gcs.result == 'skipped') }} runs-on: ${{ (matrix.storage-provider == 's3' && needs.start-aws-runner-s3.outputs.label) || (matrix.storage-provider == 'abs' && needs.start-aws-runner-abs.outputs.label) || (matrix.storage-provider == 'gcs' && needs.start-aws-runner-gcs.outputs.label) || 'ov-actions-runner' }} strategy: fail-fast: false matrix: storage-provider: [s3, abs, gcs] timeout-minutes: 30 steps: - name: Setup Node.js uses: actions/setup-node@v5 with: node-version: '22.13' - name: Setup pnpm uses: pnpm/action-setup@v2 with: version: 10 - name: Install LK CLI run: curl -sSL https://get.livekit.io/cli | bash - name: Save GCP credentials if: matrix.storage-provider == 'gcs' run: | echo '${{ secrets.GCP_CREDENTIALS_JSON }}' > /tmp/credentials.json chmod 600 /tmp/credentials.json - name: Setup OpenVidu Local Deployment uses: OpenVidu/actions/start-openvidu-local-deployment@main with: ref-openvidu-local-deployment: development pre_startup_commands: | cat <<'BASH' > pre_startup_commands.sh #!/bin/bash if [[ "${{ matrix.storage-provider }}" == "abs" ]]; then echo "Using Azure Blob Storage provider" yq e -i ' del(.storage.s3) | .storage.azure = { "account_name": "${{ vars.MEET_AZURE_ACCOUNT_NAME }}", "account_key": "${{ secrets.MEET_AZURE_ACCOUNT_KEY }}", "container_name": "openvidu-appdata-recordings" } ' egress.yaml elif [[ "${{ matrix.storage-provider }}" == "gcs" ]]; then echo "Using Google Cloud Storage provider" yq eval --inplace '.storage.gcp.credentials_json = (load("/tmp/credentials.json") | tostring) | .storage.gcp.credentials_json style="single"' egress.yaml yq e -i ' del(.storage.s3) | .storage.gcp.bucket = "openvidu-appdata" ' egress.yaml fi echo "Commenting out openvidu-meet container in docker-compose.yaml" if [ -f docker-compose.yaml ]; then yq e 'del(.services.openvidu-meet)' -i docker-compose.yaml fi BASH chmod +x pre_startup_commands.sh && ./pre_startup_commands.sh - name: Setup OpenVidu Meet uses: OpenVidu/actions/start-openvidu-meet@main with: build_components_angular: 'true' components_artifact_name: ${{ needs.build-components.outputs.artifact_name }} env: MEET_BLOB_STORAGE_MODE: ${{ matrix.storage-provider }} # ABS variables MEET_AZURE_ACCOUNT_NAME: ${{ matrix.storage-provider == 'abs' && vars.MEET_AZURE_ACCOUNT_NAME || '' }} MEET_AZURE_ACCOUNT_KEY: ${{ matrix.storage-provider == 'abs' && secrets.MEET_AZURE_ACCOUNT_KEY || '' }} MEET_AZURE_CONTAINER_NAME: ${{ matrix.storage-provider == 'abs' && 'openvidu-appdata-recordings' || '' }} # GCS variables GOOGLE_APPLICATION_CREDENTIALS: ${{ matrix.storage-provider == 'gcs' && '/tmp/credentials.json' || '' }} MEET_S3_BUCKET: ${{ matrix.storage-provider == 'gcs' && 'openvidu-appdata' || 'openvidu-appdata' }} - name: Run tests run: pnpm run test:integration-backend-recordings env: JEST_JUNIT_OUTPUT_DIR: './backend/reports/' MEET_BLOB_STORAGE_MODE: ${{ matrix.storage-provider }} # ABS variables MEET_AZURE_ACCOUNT_NAME: ${{ matrix.storage-provider == 'abs' && vars.MEET_AZURE_ACCOUNT_NAME || '' }} MEET_AZURE_ACCOUNT_KEY: ${{ matrix.storage-provider == 'abs' && secrets.MEET_AZURE_ACCOUNT_KEY || '' }} MEET_AZURE_CONTAINER_NAME: ${{ matrix.storage-provider == 'abs' && 'openvidu-appdata-recordings' || '' }} # GCS variables GOOGLE_APPLICATION_CREDENTIALS: ${{ matrix.storage-provider == 'gcs' && '/tmp/credentials.json' || '' }} MEET_S3_BUCKET: ${{ matrix.storage-provider == 'gcs' && 'openvidu-appdata' || 'openvidu-appdata' }} - name: Publish Test Report uses: mikepenz/action-junit-report@v4 if: always() with: report_paths: '**/reports/junit.xml' fail_on_failure: true require_tests: true - name: Upload OpenVidu Meet logs if: failure() uses: actions/upload-artifact@v4 with: name: recordings-test-${{ matrix.storage-provider }}-openvidu-meet-logs path: backend/meet_backend.log retention-days: 2 - name: Clean up credentials if: always() && matrix.storage-provider == 'gcs' run: | rm -f /tmp/credentials.json echo "GCP credentials file removed" - name: Clean up if: always() uses: OpenVidu/actions/cleanup@main stop-runner: name: Stop EC2 runner (${{ matrix.storage-provider }}) needs: - start-aws-runner-s3 - start-aws-runner-abs - start-aws-runner-gcs - test-recordings runs-on: ov-actions-runner if: ${{ always() }} strategy: fail-fast: false matrix: storage-provider: [s3, abs, gcs] steps: - name: Stop AWS EC2 Runner if: ${{ (matrix.storage-provider == 's3' && needs.start-aws-runner-s3.result != 'skipped') || (matrix.storage-provider == 'abs' && needs.start-aws-runner-abs.result != 'skipped') || (matrix.storage-provider == 'gcs' && needs.start-aws-runner-gcs.result != 'skipped') }} uses: OpenVidu/actions/stop-aws-runner@main with: aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} aws-region: ${{ vars.AWS_REGION }} github-token: ${{ secrets.OPENVIDU_GITHUB_TOKEN }} label: ${{ (matrix.storage-provider == 's3' && needs.start-aws-runner-s3.outputs.label) || (matrix.storage-provider == 'abs' && needs.start-aws-runner-abs.outputs.label) || (matrix.storage-provider == 'gcs' && needs.start-aws-runner-gcs.outputs.label) }} ec2-instance-id: ${{ (matrix.storage-provider == 's3' && needs.start-aws-runner-s3.outputs.ec2-instance-id) || (matrix.storage-provider == 'abs' && needs.start-aws-runner-abs.outputs.ec2-instance-id) || (matrix.storage-provider == 'gcs' && needs.start-aws-runner-gcs.outputs.ec2-instance-id) }} remove-components-artifact: name: Remove OpenVidu Components Angular Artifact needs: - build-components - test-api - test-recordings runs-on: ov-actions-runner if: ${{ always() }} steps: - name: Remove Artifact uses: geekyeggo/delete-artifact@v5 with: name: ${{ needs.build-components.outputs.artifact_name }}