name: "pull-request" on: workflow_call: inputs: dry-run-release: description: 'enable dry-run on artifact push' required: false type: boolean default: true devel: description: 'devel' required: false type: string default: false pull_request: types: [opened, synchronize, reopened] branches: - develop - master - develop-patch* - master-patch* concurrency: group: ${{ github.workflow }}-${{ github.ref }} cancel-in-progress: true env: BASE_REF: ${{ github.base_ref }} HEAD_REF: ${{ github.head_ref }} AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} GITHUB_BRANCH: ${{ github.ref_name }} GH_BUILD_DIR: ${{ github.workspace }} GH_COMMIT: ${{ github.sha }} BUILD_ID: ${{ github.run_id }} GH_RUN_NUMBER: ${{ github.run_attempt }} GH_BUILD_NUMBER: ${{ github.run_id }} JOB_ID: ${{ github.run_id }} PROXY_HOST_BPM: ${{ secrets.E2E_HOST }} E2E_HOST_APA: ${{ secrets.E2E_HOST_APA }} E2E_HOST: ${{ secrets.E2E_HOST }} E2E_USERNAME: ${{ secrets.E2E_ADMIN_EMAIL_IDENTITY }} E2E_PASSWORD: ${{ secrets.E2E_PASSWORD }} E2E_ADMIN_EMAIL_IDENTITY: ${{ secrets.E2E_ADMIN_EMAIL_IDENTITY }} E2E_ADMIN_PASSWORD_IDENTITY: ${{ secrets.E2E_ADMIN_PASSWORD_IDENTITY }} USERNAME_ADF: ${{ secrets.E2E_ADMIN_EMAIL_IDENTITY }} PASSWORD_ADF: ${{ secrets.E2E_PASSWORD }} URL_HOST_ADF: "http://localhost:4200" IDENTITY_ADMIN_EMAIL: ${{ secrets.E2E_ADMIN_EMAIL_IDENTITY }} IDENTITY_ADMIN_PASSWORD: ${{ secrets.E2E_ADMIN_PASSWORD_IDENTITY }} AWS_S3_BUCKET_ACTIVITI_LICENSE: ${{ secrets.AWS_S3_BUCKET_ACTIVITI_LICENSE }} HOST_SSO: ${{ secrets.HOST_SSO }} LOG_LEVEL: "ERROR" E2E_LOG_LEVEL: "ERROR" E2E_MODELER_USERNAME: ${{ secrets.E2E_MODELER_USERNAME }} E2E_MODELER_PASSWORD: ${{ secrets.E2E_MODELER_PASSWORD }} EXTERNAL_ACS_HOST: ${{ secrets.EXTERNAL_ACS_HOST }} E2E_DEVOPS_USERNAME: ${{ secrets.E2E_DEVOPS_USERNAME }} E2E_DEVOPS_PASSWORD: ${{ secrets.E2E_DEVOPS_PASSWORD }} USERNAME_SUPER_ADMIN_ADF: ${{ secrets.USERNAME_SUPER_ADMIN_ADF }} PASSWORD_SUPER_ADMIN_ADF: ${{ secrets.PASSWORD_SUPER_ADMIN_ADF }} HR_USER: ${{ secrets.HR_USER }} HR_USER_PASSWORD: ${{ secrets.HR_USER_PASSWORD }} SMART_RUNNER_PATH: ".protractor-smartrunner" S3_DBP_PATH: ${{ secrets.S3_DBP_PATH }} S3_BUILD_BUCKET_SHORT_NAME: ${{ secrets.S3_BUILD_BUCKET_SHORT_NAME }} NODE_OPTIONS: "--max-old-space-size=5120" DOCKER_REPOSITORY_DOMAIN: ${{ secrets.DOCKER_REPOSITORY_DOMAIN }} DOCKER_REPOSITORY_USER: ${{ secrets.DOCKER_REPOSITORY_USER }} DOCKER_REPOSITORY_PASSWORD: ${{ secrets.DOCKER_REPOSITORY_PASSWORD }} DOCKER_REPOSITORY_STORYBOOK: "${{ secrets.DOCKER_REPOSITORY_DOMAIN }}/alfresco/storybook" DOCKER_REPOSITORY: "${{ secrets.DOCKER_REPOSITORY_DOMAIN }}/alfresco/demo-shell" REPO_OWNER: "Alfresco" REPO_NAME: "alfresco-ng2-components" DEMO_SHELL_DIR: "./dist/demo-shell" STORYBOOK_DIR: "./dist/storybook/stories" BUILT_LIBS_DIR: "./dist/libs" NODE_MODULES_DIR: "./node_modules" SMART_RUNNER_DIRECTORY: ".protractor-smartrunner" SAVE_SCREENSHOT: true REDIRECT_URI: / BROWSER_RUN: false MAXINSTANCES: 2 PLAYWRIGHT_WORKERS: 2 PLAYWRIGHT_STORYBOOK_E2E_HOST: http://localhost PLAYWRIGHT_STORYBOOK_E2E_PORT: 4400 PROXY_HOST_ECM: ${{ secrets.E2E_HOST }} jobs: check-package-lock: runs-on: ubuntu-22.04 steps: - name: Checkout repository uses: actions/checkout@v3 - name: Check package-lock.json version run: | if [[ $(jq '.lockfileVersion == 2' package-lock.json) == "true" ]] ; then echo -e "\033[31mpackage-lock must be version 1\033[0m" exit 1 else echo -e "\033[32mpackage-lock.json has a correct version\033[0m" fi check-if-pr-is-approved: runs-on: ubuntu-22.04 steps: - name: Checkout repository uses: actions/checkout@v3 - name: Check if PR is approved id: action if: ${{ github.event_name != 'schedule' }} uses: kamatama41/get-pr-number-action@5c77b38a1b4974ebf8a9521a689f38a5898eadd6 with: github_token: ${{ secrets.GITHUB_TOKEN }} - name: check if pr is approved env: DEVEL_FLAG: ${{ inputs.devel }} GH_TOKEN: ${{ github.token }} skip_check: "false" run: | if [ "${{ github.actor }}" == "dependabot[bot]" ] || [ "${{ github.actor }}" == "alfresco-build" ]; then echo -e "\033[32mCommit by ${{ github.actor }}. No need for approval.\033[0m" skip_check="true" fi if [ "${{ github.event_name }}" == "schedule" ]; then echo -e "\033[32mSchedule event\033[0m" skip_check="true" fi if [[ "$DEVEL_FLAG" == "true" ]]; then echo -e "\033[32mDevel flag\033[0m" skip_check="true" fi if [ "$skip_check" == "false" ]; then echo "Checking PR approval" prNumber=${{ steps.action.outputs.number }} checkApproval=$(gh api /repos/Alfresco/alfresco-ng2-components/pulls/$prNumber/reviews | jq '.[] | select(.state == "APPROVED") | .user.login') if [[ $checkApproval ]]; then echo -e "\033[32mPR approved\033[0m" else echo -e "\033[31mPR NOT approved\033[0m" exit 1 fi fi setup: # long timeout required when cache has to be recreated timeout-minutes: 30 name: "Setup" runs-on: ubuntu-22.04 needs: [check-if-pr-is-approved, check-package-lock] steps: - name: Checkout repository uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch all history for all tags and branches - uses: ./.github/actions/setup - name: install run: | npm ci nx run cli:bundle nx run testing:bundle - run: nx print-affected $NX_CALCULATION_FLAGS - uses: ./.github/actions/upload-node-modules-and-artifacts unit-tests: timeout-minutes: 30 name: "Unit tests: ${{ matrix.unit-tests.name }}" runs-on: ubuntu-22.04 needs: [setup] strategy: fail-fast: false # max-parallel: 4 matrix: unit-tests: - name: content-services exclude: "insights,core,extensions,process-services,process-services-cloud" - name: core exclude: "insights,content-services,process-services,process-services-cloud" - name: insights and process-services exclude: "core,extensions,content-services,process-services-cloud" - name: process-cloud exclude: "insights,core,extensions,content-services,process-services" steps: - name: Checkout repository uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch all history for all tags and branches - uses: ./.github/actions/setup - uses: ./.github/actions/download-node-modules-and-artifacts - name: Run unit tests run: | /usr/bin/xvfb-run --auto-servernum nx affected:test $NX_CALCULATION_FLAGS --exclude=${{ matrix.unit-tests.exclude }} lint: # long timeout required when cache has to be recreated timeout-minutes: 30 name: "Lint" runs-on: ubuntu-22.04 needs: [setup] steps: - name: Checkout repository uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch all history for all tags and branches - uses: ./.github/actions/setup - uses: ./.github/actions/download-node-modules-and-artifacts - run: nx affected --target=lint $NX_CALCULATION_FLAGS build-libs: # long timeout required when cache has to be recreated timeout-minutes: 30 name: "Build libs" runs-on: ubuntu-22.04 needs: [setup] steps: - name: Checkout repository uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch all history for all tags and branches - uses: ./.github/actions/setup - uses: ./.github/actions/download-node-modules-and-artifacts - run: nx affected:build $NX_CALCULATION_FLAGS --prod - run: nx build demoshell --configuration production - run: nx affected --target=build-storybook $NX_CALCULATION_FLAGS --configuration ci - uses: ./.github/actions/upload-node-modules-and-artifacts e2e-storybook: timeout-minutes: 20 name: "e2e: storybook" needs: [build-libs, lint, unit-tests] runs-on: ubuntu-22.04 steps: - name: Checkout repository uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch all history for all - uses: ./.github/actions/setup - uses: ./.github/actions/download-node-modules-and-artifacts - name: Process Cloud Storybook Playwright run: | npx playwright install chromium sudo sysctl -w fs.inotify.max_user_watches=524288 npx nx affected --target=e2e-playwright $NX_CALCULATION_FLAGS || exit 1 - uses: ./.github/actions/upload-node-modules-and-artifacts e2e: timeout-minutes: 90 name: "e2e: ${{ matrix.e2e-test.description }}" needs: [build-libs, lint, unit-tests] runs-on: ubuntu-22.04 strategy: fail-fast: false # max-parallel: 4 matrix: e2e-test: - description: "Core" test-id: "core" folder: "core" provider: "ALL" auth: "OAUTH" check-cs-env: "true" check-ps-env: "true" - description: "Content: Components" test-id: "content-services" folder: "content-services/components" provider: "ECM" auth: "BASIC" check-cs-env: "true" - description: "Content: Directives" test-id: "content-services" folder: "content-services/directives" provider: "ECM" auth: "BASIC" check-cs-env: "true" - description: "Content: Document List" test-id: "content-services" folder: "content-services/document-list" provider: "ECM" auth: "BASIC" check-cs-env: "true" - description: "Content: Metadata" test-id: "content-services" folder: "content-services/metadata" provider: "ECM" auth: "BASIC" check-cs-env: "true" - description: "Content: Upload and Versioning" test-id: "content-services" folder: "content-services/upload" provider: "ECM" auth: "BASIC" check-cs-env: "true" - description: "Search" test-id: "content-services" folder: "search" provider: "ECM" auth: "BASIC" check-cs-env: "true" - description: "Process: Form" test-id: "process-services" folder: "process-services/form" provider: "BPM" auth: "OAUTH" check-ps-env: "true" check-external-cs-env: "true" - description: "Process: Process" test-id: "process-services" folder: "process-services/process" provider: "BPM" auth: "OAUTH" check-ps-env: "true" check-external-cs-env: "true" - description: "Process: Tasks" test-id: "process-services" folder: "process-services/tasks" provider: "BPM" auth: "OAUTH" check-ps-env: "true" check-external-cs-env: "true" - description: "Process: Widget" test-id: "process-services" folder: "process-services/widgets" provider: "BPM" auth: "OAUTH" check-ps-env: "true" check-external-cs-env: "true" - description: "Process Cloud: Form" test-id: "process-services-cloud" folder: "process-services-cloud/form-field" provider: "ALL" auth: "OAUTH" apa-proxy: true check-cs-env: "true" check-ps-cloud-env: "true" - description: "Process Cloud: People" test-id: "process-services-cloud" folder: "process-services-cloud/people" provider: "ALL" auth: "OAUTH" apa-proxy: true check-cs-env: "true" check-ps-cloud-env: "true" - description: "Process Cloud: Process" test-id: "process-services-cloud" folder: "process-services-cloud/process" provider: "ALL" auth: "OAUTH" apa-proxy: true check-cs-env: "true" check-ps-cloud-env: "true" - description: "Process Cloud: Start Task" test-id: "process-services-cloud" folder: "process-services-cloud/start-task" provider: "ALL" auth: "OAUTH" apa-proxy: true check-cs-env: "true" check-ps-cloud-env: "true" - description: "Process Cloud: Tasks List" test-id: "process-services-cloud" folder: "process-services-cloud/task-list" provider: "ALL" auth: "OAUTH" apa-proxy: true check-cs-env: "true" check-ps-cloud-env: "true" steps: - name: Checkout repository uses: actions/checkout@v3 with: fetch-depth: 0 # Fetch all history for all - uses: ./.github/actions/setup with: enable-cache: "true" enable-node-modules-cache: "true" - uses: ./.github/actions/download-node-modules-and-artifacts - name: setup chrome uses: ./.github/actions/setup-chrome - name: e2e uses: ./.github/actions/e2e with: e2e-test-id: ${{ matrix.e2e-test.test-id }} e2e-test-folder: ${{ matrix.e2e-test.folder }} e2e-test-provider: ${{ matrix.e2e-test.provider }} e2e-test-auth: ${{ matrix.e2e-test.auth }} check-cs-env: ${{ matrix.e2e-test.check-cs-env }} check-ps-env: ${{ matrix.e2e-test.check-ps-env }} check-ps-cloud-env: ${{ matrix.e2e-test.check-ps-cloud-env }} check-external-cs-env: ${{ matrix.e2e-test.check-external-cs-env }} apa-proxy: ${{ matrix.e2e-test.apa-proxy }} finalize: if: ${{ always() }} runs-on: ubuntu-latest name: Final Results needs: [check-if-pr-is-approved, check-package-lock, unit-tests, build-libs, e2e, e2e-storybook] steps: - name: workflow failure run: exit 1 if: ${{ contains(needs.*.result, 'failure') }} - name: workflow canceled run: exit 1 if: ${{ contains(needs.*.result, 'cancelled') }} - name: workflow success run: exit 0 if: ${{ contains(needs.*.result, 'success') }}