| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- name: PR Entrypoint
- concurrency:
- group: pr-entrypoint-${{ github.event_name }}-${{ github.ref }}
- cancel-in-progress: true
- on:
- pull_request:
- workflow_dispatch:
- inputs:
- ref:
- required: false
- permissions:
- contents: read
- defaults:
- run:
- shell: bash
- env:
- IS_CI: "yes"
- jobs:
- init:
- runs-on: ubuntu-22.04
- outputs:
- BUILDER_VSN: ${{ steps.env.outputs.BUILDER_VSN }}
- OTP_VSN: ${{ steps.env.outputs.OTP_VSN }}
- ELIXIR_VSN: ${{ steps.env.outputs.ELIXIR_VSN }}
- BUILDER: ${{ steps.env.outputs.BUILDER }}
- steps:
- - uses: actions/checkout@d632683dd7b4114ad314bca15554477dd762a938 # v4.2.0
- with:
- ref: ${{ github.event.inputs.ref }}
- - name: Set up environment
- id: env
- run: |
- source ./env.sh
- echo "BUILDER_VSN=$EMQX_BUILDER_VSN" | tee -a "$GITHUB_OUTPUT"
- echo "OTP_VSN=$OTP_VSN" | tee -a "$GITHUB_OUTPUT"
- echo "ELIXIR_VSN=$ELIXIR_VSN" | tee -a "$GITHUB_OUTPUT"
- echo "BUILDER=$EMQX_BUILDER" | tee -a "$GITHUB_OUTPUT"
- sanity-checks:
- runs-on: ubuntu-22.04
- needs: init
- container: ${{ needs.init.outputs.BUILDER }}
- outputs:
- ct-matrix: ${{ steps.matrix.outputs.ct-matrix }}
- ct-host: ${{ steps.matrix.outputs.ct-host }}
- ct-docker: ${{ steps.matrix.outputs.ct-docker }}
- steps:
- - uses: actions/checkout@d632683dd7b4114ad314bca15554477dd762a938 # v4.2.0
- with:
- ref: ${{ github.event.inputs.ref }}
- fetch-depth: 0
- - name: Work around https://github.com/actions/checkout/issues/766
- run: |
- git config --global --add safe.directory "$GITHUB_WORKSPACE"
- - name: Run gitlint
- env:
- BEFORE_REF: ${{ github.event_name == 'pull_request' && github.event.pull_request.base.sha || github.event.before }}
- AFTER_REF: ${{ github.sha }}
- run: |
- pip install --require-hashes -r .ci/gitlint.requirements.txt
- gitlint --commits $BEFORE_REF..$AFTER_REF --config .github/workflows/.gitlint
- - name: Run shellcheck
- run: |
- DEBIAN_FRONTEND=noninteractive apt-get update -qy && apt-get install -qy shellcheck
- ./scripts/shellcheck.sh
- - name: Run shell tests
- run: |
- DEBIAN_FRONTEND=noninteractive apt-get update -qy && apt-get install -qy shelltestrunner
- scripts/shelltest/run_tests.sh
- - name: Check workflow files
- env:
- ACTIONLINT_VSN: 1.6.25
- run: |
- wget -q https://github.com/rhysd/actionlint/releases/download/v${ACTIONLINT_VSN}/actionlint_${ACTIONLINT_VSN}_linux_$(dpkg --print-architecture).tar.gz -O actionlint.tar.gz
- tar zxf actionlint.tar.gz actionlint
- # TODO: enable shellcheck when all the current issues are fixed
- ./actionlint -color \
- -shellcheck= \
- -ignore 'label ".+" is unknown' \
- -ignore 'value "emqx-enterprise" in "exclude"' \
- -ignore 'value "emqx-enterprise-elixir" in "exclude"'
- - name: Check line-break at EOF
- run: |
- ./scripts/check-nl-at-eof.sh
- - name: Check apps version
- run: |
- ./scripts/apps-version-check.sh
- - name: Setup mix
- env:
- MIX_ENV: emqx-enterprise
- PROFILE: emqx-enterprise
- run: |
- # mix local.hex --force --if-missing && mix local.rebar --force --if-missing
- mix local.hex 2.0.6 --force --if-missing && mix local.rebar --force --if-missing
- - name: Check formatting
- env:
- MIX_ENV: emqx-enterprise
- PROFILE: emqx-enterprise
- run: |
- ./scripts/check-format.sh
- - name: Run elvis check
- run: |
- ./scripts/elvis-check.sh $GITHUB_BASE_REF
- - name: Generate CT Matrix
- id: matrix
- run: |
- MATRIX="$(./scripts/find-apps.sh --ci)"
- echo "${MATRIX}" | jq
- CT_MATRIX="$(echo "${MATRIX}" | jq -c 'map({profile}) | unique')"
- CT_HOST="$(echo "${MATRIX}" | jq -c 'map(select(.runner == "host"))')"
- CT_DOCKER="$(echo "${MATRIX}" | jq -c 'map(select(.runner == "docker"))')"
- echo "ct-matrix=${CT_MATRIX}" | tee -a $GITHUB_OUTPUT
- echo "ct-host=${CT_HOST}" | tee -a $GITHUB_OUTPUT
- echo "ct-docker=${CT_DOCKER}" | tee -a $GITHUB_OUTPUT
- compile:
- runs-on: ${{ endsWith(github.repository, '/emqx') && 'ubuntu-22.04' || fromJSON('["self-hosted","ephemeral-xl","linux","x64"]') }}
- container: ${{ needs.init.outputs.BUILDER }}
- needs:
- - init
- - sanity-checks
- strategy:
- matrix:
- profile:
- - emqx
- - emqx-enterprise
- steps:
- - uses: actions/checkout@d632683dd7b4114ad314bca15554477dd762a938 # v4.2.0
- with:
- fetch-depth: 0
- - name: Work around https://github.com/actions/checkout/issues/766
- run: |
- git config --global --add safe.directory "$GITHUB_WORKSPACE"
- - id: compile
- env:
- PROFILE: ${{ matrix.profile }}
- ENABLE_COVER_COMPILE: 1
- run: |
- make ensure-rebar3
- make ${PROFILE}-compile test-compile
- echo "export PROFILE=${PROFILE}" | tee -a env.sh
- echo "export PKG_VSN=$(./pkg-vsn.sh ${PROFILE})" | tee -a env.sh
- zip -ryq -x@.github/workflows/.zipignore $PROFILE.zip .
- make ${PROFILE}-rel
- - uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4.4.0
- with:
- name: ${{ matrix.profile }}
- path: ${{ matrix.profile }}.zip
- retention-days: 7
- - uses: actions/upload-artifact@50769540e7f4bd5e21e526ee35c689e35e0d6874 # v4.4.0
- with:
- name: "${{ matrix.profile }}-schema-dump"
- path: |
- env.sh
- scripts/spellcheck
- _build/docgen/${{ matrix.profile }}/*.json
- _build/docgen/${{ matrix.profile }}/*.hocon
- retention-days: 7
- run_emqx_app_tests:
- needs:
- - init
- - sanity-checks
- - compile
- uses: ./.github/workflows/run_emqx_app_tests.yaml
- with:
- builder: ${{ needs.init.outputs.BUILDER }}
- before_ref: ${{ github.event_name == 'pull_request' && github.event.pull_request.base.sha || github.event.before }}
- after_ref: ${{ github.sha }}
- run_test_cases:
- needs:
- - init
- - sanity-checks
- - compile
- permissions:
- contents: read
- pull-requests: write
- uses: ./.github/workflows/run_test_cases.yaml
- with:
- builder: ${{ needs.init.outputs.BUILDER }}
- ct-matrix: ${{ needs.sanity-checks.outputs.ct-matrix }}
- ct-host: ${{ needs.sanity-checks.outputs.ct-host }}
- ct-docker: ${{ needs.sanity-checks.outputs.ct-docker }}
- static_checks:
- needs:
- - init
- - sanity-checks
- - compile
- uses: ./.github/workflows/static_checks.yaml
- with:
- builder: ${{ needs.init.outputs.BUILDER }}
- ct-matrix: ${{ needs.sanity-checks.outputs.ct-matrix }}
- build_slim_packages:
- needs:
- - sanity-checks
- uses: ./.github/workflows/build_slim_packages.yaml
- build_docker_emqx:
- needs:
- - init
- - sanity-checks
- uses: ./.github/workflows/build_and_push_docker_images.yaml
- with:
- profile: emqx
- publish: false
- secrets: inherit
- build_docker_emqx_enterprise:
- needs:
- - init
- - sanity-checks
- uses: ./.github/workflows/build_and_push_docker_images.yaml
- with:
- profile: emqx-enterprise
- publish: false
- secrets: inherit
- spellcheck:
- needs:
- - sanity-checks
- - compile
- uses: ./.github/workflows/spellcheck.yaml
- run_conf_tests:
- needs:
- - init
- - sanity-checks
- - compile
- uses: ./.github/workflows/run_conf_tests.yaml
- with:
- builder: ${{ needs.init.outputs.BUILDER }}
- check_deps_integrity:
- needs:
- - init
- - sanity-checks
- uses: ./.github/workflows/check_deps_integrity.yaml
- with:
- builder: ${{ needs.init.outputs.BUILDER }}
- run_jmeter_tests:
- needs:
- - sanity-checks
- - build_docker_emqx
- uses: ./.github/workflows/run_jmeter_tests.yaml
- run_docker_tests:
- needs:
- - sanity-checks
- - build_docker_emqx
- - build_docker_emqx_enterprise
- uses: ./.github/workflows/run_docker_tests.yaml
- run_helm_tests:
- needs:
- - sanity-checks
- - build_docker_emqx
- - build_docker_emqx_enterprise
- uses: ./.github/workflows/run_helm_tests.yaml
|