name: Full on: workflow_call: inputs: ref: type: string required: true workflow_dispatch: inputs: ref: type: string required: true env: WORKFLOW_RUN_URL: https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }} jobs: search_cache: runs-on: ubuntu-latest outputs: sha: ${{ steps.get-sha.outputs.sha}} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} REPO: ${{ github.repository }} steps: - name: Getting SHA with cache from the default branch id: get-sha run: | DEFAULT_BRANCH=$(gh api /repos/$REPO | jq -r '.default_branch') for sha in $(gh api "/repos/$REPO/commits?per_page=100&sha=$DEFAULT_BRANCH" | jq -r '.[].sha'); do RUN_status=$(gh api /repos/${REPO}/actions/workflows/cache.yml/runs | \ jq -r ".workflow_runs[]? | select((.head_sha == \"${sha}\") and (.conclusion == \"success\")) | .status") if [[ ${RUN_status} == "completed" ]]; then SHA=$sha break fi done echo Default branch is ${DEFAULT_BRANCH} echo Workflow will try to get cache from commit: ${SHA} echo ::set-output name=default_branch::${DEFAULT_BRANCH} echo ::set-output name=sha::${SHA} build: needs: search_cache runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 with: ref: ${{ inputs.ref }} - name: CVAT server. Getting cache from the default branch uses: actions/cache@v3 with: path: /tmp/cvat_cache_server key: ${{ runner.os }}-build-server-${{ needs.search_cache.outputs.sha }} - name: CVAT UI. Getting cache from the default branch uses: actions/cache@v3 with: path: /tmp/cvat_cache_ui key: ${{ runner.os }}-build-ui-${{ needs.search_cache.outputs.sha }} - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 - name: Create image directory run: | mkdir /tmp/cvat_server mkdir /tmp/cvat_ui - name: CVAT server. Build and push uses: docker/build-push-action@v3 with: cache-from: type=local,src=/tmp/cvat_cache_server context: . file: Dockerfile tags: cvat/server outputs: type=docker,dest=/tmp/cvat_server/image.tar - name: CVAT UI. Build and push uses: docker/build-push-action@v3 with: cache-from: type=local,src=/tmp/cvat_cache_ui context: . file: Dockerfile.ui tags: cvat/ui outputs: type=docker,dest=/tmp/cvat_ui/image.tar - name: Upload CVAT server artifact uses: actions/upload-artifact@v3 with: name: cvat_server path: /tmp/cvat_server/image.tar - name: Upload CVAT UI artifact uses: actions/upload-artifact@v3 with: name: cvat_ui path: /tmp/cvat_ui/image.tar rest_api: needs: build runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 with: ref: ${{ inputs.ref }} - uses: actions/setup-python@v2 with: python-version: '3.8' - name: Set up Docker Buildx uses: docker/setup-buildx-action@master - name: Getting CVAT Elasticsearch cache from the default branch uses: actions/cache@v3 with: path: /tmp/cvat_cache_elasticsearch key: ${{ runner.os }}-build-elasticsearch-${{ needs.search_cache.outputs.sha }} - name: Getting CVAT Logstash cache from the default branch uses: actions/cache@v3 with: path: /tmp/cvat_cache_logstash key: ${{ runner.os }}-build-logstash-${{ needs.search_cache.outputs.sha }} - name: Building CVAT Elasticsearch uses: docker/build-push-action@v2 with: context: ./components/analytics/elasticsearch/ file: ./components/analytics/elasticsearch/Dockerfile cache-from: type=local,src=/tmp/cvat_cache_elasticsearch tags: cvat_elasticsearch:latest load: true build-args: ELK_VERSION=6.8.23 - name: Building CVAT Logstash uses: docker/build-push-action@v2 with: context: ./components/analytics/logstash/ file: ./components/analytics/logstash/Dockerfile cache-from: type=local,src=/tmp/cvat_cache_logstash tags: cvat_logstash:latest load: true build-args: ELK_VERSION=6.8.23 - name: Download CVAT server image uses: actions/download-artifact@v3 with: name: cvat_server path: /tmp/cvat_server/ - name: Download CVAT UI images uses: actions/download-artifact@v3 with: name: cvat_ui path: /tmp/cvat_ui/ - name: Load Docker images run: | docker load --input /tmp/cvat_server/image.tar docker load --input /tmp/cvat_ui/image.tar docker image ls -a - name: Running REST API and SDK tests run: | docker run --rm -v ${PWD}/cvat-sdk/schema/:/transfer \ --entrypoint /bin/bash -u root cvat/server \ -c 'python manage.py spectacular --file /transfer/schema.yml' pip3 install --user -r cvat-sdk/gen/requirements.txt cd cvat-sdk/ gen/generate.sh cd .. pip3 install --user cvat-sdk/ pip3 install --user cvat-cli/ pip3 install --user -r tests/python/requirements.txt pytest tests/python -s -v - name: Creating a log file from cvat containers if: failure() env: LOGS_DIR: "${{ github.workspace }}/rest_api" run: | mkdir $LOGS_DIR docker logs test_cvat_server_1 > $LOGS_DIR/cvat.log docker logs test_cvat_opa_1 2> $LOGS_DIR/cvat_opa.log - name: Uploading "cvat" container logs as an artifact if: failure() uses: actions/upload-artifact@v2 env: LOGS_DIR: "${{ github.workspace }}/rest_api" with: name: container_logs path: $LOGS_DIR unit_testing: needs: build runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 with: ref: ${{ inputs.ref }} - name: Set up Docker Buildx uses: docker/setup-buildx-action@master - name: Download CVAT server image uses: actions/download-artifact@v3 with: name: cvat_server path: /tmp/cvat_server/ - name: Load Docker images run: | docker load --input /tmp/cvat_server/image.tar docker image ls -a - name: Running OPA tests run: | curl -L -o opa https://openpolicyagent.org/downloads/v0.34.2/opa_linux_amd64_static chmod +x ./opa ./opa test cvat/apps/iam/rules - name: Running unit tests env: HOST_COVERAGE_DATA_DIR: ${{ github.workspace }} CONTAINER_COVERAGE_DATA_DIR: "/coverage_data" run: | docker-compose -f docker-compose.yml -f docker-compose.dev.yml up -d cvat_opa max_tries=12 while [[ $(curl -s -o /dev/null -w "%{http_code}" localhost:8181/health) != "200" && max_tries -gt 0 ]]; do (( max_tries-- )); sleep 5; done docker-compose -f docker-compose.yml -f docker-compose.dev.yml -f docker-compose.ci.yml run cvat_ci /bin/bash \ -c 'python manage.py test cvat/apps -v 2' docker-compose -f docker-compose.yml -f docker-compose.dev.yml -f docker-compose.ci.yml run cvat_ci /bin/bash \ -c 'yarn --frozen-lockfile --ignore-scripts && yarn workspace cvat-core run test' - name: Creating a log file from cvat containers if: failure() env: LOGS_DIR: "${{ github.workspace }}/unit_testing" run: | mkdir $LOGS_DIR docker logs cvat_server > $LOGS_DIR/cvat.log docker logs cvat_opa 2> $LOGS_DIR/cvat_opa.log - name: Uploading "cvat" container logs as an artifact if: failure() uses: actions/upload-artifact@v2 env: LOGS_DIR: "${{ github.workspace }}/unit_testing" with: name: container_logs path: $LOGS_DIR e2e_testing: needs: build runs-on: ubuntu-latest strategy: fail-fast: false matrix: specs: ['actions_tasks', 'actions_tasks2', 'actions_tasks3', 'actions_objects', 'actions_objects2', 'actions_users', 'actions_projects_models', 'actions_organizations', 'canvas3d_functionality', 'canvas3d_functionality_2', 'issues_prs', 'issues_prs2'] steps: - uses: actions/checkout@v3 with: ref: ${{ inputs.ref }} - uses: actions/setup-node@v2 with: node-version: '16.x' - name: Set up Docker Buildx uses: docker/setup-buildx-action@master - name: Download CVAT server image uses: actions/download-artifact@v3 with: name: cvat_server path: /tmp/cvat_server/ - name: Download CVAT UI image uses: actions/download-artifact@v3 with: name: cvat_ui path: /tmp/cvat_ui/ - name: Load Docker images run: | docker load --input /tmp/cvat_server/image.tar docker load --input /tmp/cvat_ui/image.tar docker image ls -a - name: Run CVAT instance run: | docker-compose \ -f docker-compose.yml \ -f docker-compose.dev.yml \ -f components/serverless/docker-compose.serverless.yml \ -f tests/docker-compose.file_share.yml up -d - name: Waiting for server env: API_ABOUT_PAGE: "localhost:8080/api/server/about" run: | max_tries=60 status_code=$(curl -s -o /tmp/server_response -w "%{http_code}" ${API_ABOUT_PAGE}) while [[ $status_code != "401" && max_tries -gt 0 ]] do echo Number of attempts left: $max_tries echo Status code of response: $status_code sleep 5 status_code=$(curl -s -o /tmp/server_response -w "%{http_code}" ${API_ABOUT_PAGE}) (( max_tries-- )) done - name: Run E2E tests env: DJANGO_SU_NAME: 'admin' DJANGO_SU_EMAIL: 'admin@localhost.company' DJANGO_SU_PASSWORD: '12qwaszx' run: | docker exec -i cvat_server /bin/bash -c "echo \"from django.contrib.auth.models import User; User.objects.create_superuser('${DJANGO_SU_NAME}', '${DJANGO_SU_EMAIL}', '${DJANGO_SU_PASSWORD}')\" | python3 ~/manage.py shell" cd ./tests yarn --frozen-lockfile shopt -s extglob if [[ ${{ matrix.specs }} == canvas3d_* ]]; then npx cypress run \ --headed \ --browser chrome \ --config-file cypress_canvas3d.json \ --spec 'cypress/integration/${{ matrix.specs }}/**/*.js,cypress/integration/remove_users_tasks_projects_organizations.js' else npx cypress run \ --browser chrome \ --spec 'cypress/integration/${{ matrix.specs }}/**/*.js,cypress/integration/remove_users_tasks_projects_organizations.js' fi - name: Creating a log file from "cvat" container logs if: failure() run: | docker logs cvat_server > ${{ github.workspace }}/tests/cvat_${{ matrix.specs }}.log - name: Uploading "cvat" container logs as an artifact if: failure() uses: actions/upload-artifact@v2 with: name: container_logs path: ${{ github.workspace }}/tests/cvat_${{ matrix.specs }}.log - name: Uploading cypress screenshots as an artifact if: failure() uses: actions/upload-artifact@v2 with: name: cypress_screenshots_${{ matrix.specs }} path: ${{ github.workspace }}/tests/cypress/screenshots