feat: or-2935 unify error messages, move validators to magda client #133
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: "[CICD] Main" | |
| on: | |
| push: | |
| branches: [ main ] | |
| workflow_dispatch: | |
| concurrency: CI | |
| jobs: | |
| analyze-code: | |
| name: Analyze Code | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| # needed for Sonar, default is 11 and is decprecated | |
| - name: Set up JDK 17 | |
| uses: actions/setup-java@v4 | |
| with: | |
| java-version: 17 | |
| distribution: oracle | |
| - name: Parse repository name | |
| run: echo REPOSITORY_NAME=$(echo "$GITHUB_REPOSITORY" | awk -F / '{print $2}' | sed -e "s/:refs//") >> $GITHUB_ENV | |
| shell: bash | |
| - name: Setup .NET Core | |
| uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: ${{ vars.VBR_DOTNET_VERSION_9 }} | |
| - name: .NET version | |
| shell: bash | |
| run: dotnet --info | |
| - name: Cache SonarCloud packages | |
| uses: actions/cache@v4 | |
| with: | |
| path: ~/sonar/cache | |
| key: ${{ runner.os }}-sonar | |
| restore-keys: ${{ runner.os }}-sonar | |
| - name: Restore dotnet tools | |
| shell: bash | |
| run: | | |
| dotnet tool restore | |
| - name: Cache SonarCloud scanner | |
| id: cache-sonar-scanner | |
| uses: actions/cache@v4 | |
| with: | |
| path: ./.sonar/scanner | |
| key: ${{ runner.os }}-sonar-scanner | |
| restore-keys: ${{ runner.os }}-sonar-scanner | |
| - name: Install SonarCloud scanner | |
| if: steps.cache-sonar-scanner.outputs.cache-hit != 'true' | |
| shell: bash | |
| run: | | |
| mkdir .sonar | |
| mkdir .sonar/scanner | |
| dotnet tool update dotnet-sonarscanner --tool-path ./.sonar/scanner | |
| - name: Start sonar scanner | |
| env: | |
| GITHUB_TOKEN: ${{ secrets.VBR_ACTIONS_TOKEN }} # Needed to get PR information, if any | |
| SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} | |
| shell: bash | |
| run: | | |
| ./.sonar/scanner/dotnet-sonarscanner begin /k:"Informatievlaanderen_association-registry" /o:"informatievlaanderen" /d:sonar.login="${{ secrets.SONAR_TOKEN }}" /d:sonar.host.url="https://sonarcloud.io" /d:sonar.cs.dotcover.reportsPaths=dotCover.Output.html | |
| - name: Dotnet restore | |
| shell: bash | |
| run: dotnet restore --runtime linux-x64 | |
| - name: Dotnet build | |
| shell: bash | |
| run: dotnet build --no-restore | |
| - name: Analyze with sonar scanner | |
| env: | |
| GITHUB_TOKEN: ${{ secrets.VBR_ACTIONS_TOKEN }} # Needed to get PR information, if any | |
| SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} | |
| shell: bash | |
| run: | | |
| ./.sonar/scanner/dotnet-sonarscanner end /d:sonar.login="${{ secrets.SONAR_TOKEN }}" | |
| set-release-version: | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| name: Decide next version | |
| runs-on: ubuntu-latest | |
| outputs: | |
| version: ${{ steps.set-version.outputs.version }} | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Setup Node.js | |
| uses: actions/setup-node@v4 | |
| - name: Node version | |
| shell: bash | |
| run: node --version | |
| - name: Install NPM dependencies | |
| shell: bash | |
| run: npm install --legacy-peer-deps | |
| - name: Run Semantic Release dry-run | |
| shell: bash | |
| run: npx semantic-release --dry-run | |
| env: | |
| NPM_TOKEN: ${{ secrets.VBR_WEBCOMP_NPM_TOKEN }} | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| GITHUB_TOKEN: ${{ secrets.VBR_ACTIONS_TOKEN }} | |
| GIT_COMMIT: ${{ github.sha }} | |
| GIT_USERNAME: ${{ secrets.VBR_GIT_USER }} | |
| GIT_AUTHOR_NAME: ${{ secrets.VBR_GIT_USER }} | |
| GIT_COMMITTER_NAME: ${{ secrets.VBR_GIT_USER }} | |
| GIT_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
| GIT_AUTHOR_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
| GIT_COMMITTER_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
| - name: Set Release Version | |
| id: set-version | |
| run: | | |
| [ ! -f semver ] && echo none > semver | |
| echo $(cat semver) | |
| echo ::set-output name=version::$(cat semver) | |
| echo RELEASE_VERSION=$(cat semver) >> $GITHUB_ENV | |
| shell: bash | |
| run-unit-tests: | |
| name: Domain | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test | |
| run-docker-acm: false | |
| run-docker-wiremock: true | |
| run-docker-db: true | |
| run-docker-elasticsearch: true | |
| run-docker-localstack: true | |
| run-docker-otelcollector: true | |
| secrets: inherit | |
| run-acm-tests: | |
| name: ACM | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.Acm.Api | |
| run-docker-acm: true | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: false | |
| pre-gen-marten: true | |
| db-name: golden_master_template | |
| secrets: inherit | |
| build-acm-api: | |
| name: ACM | |
| uses: ./.github/workflows/shared.build-image.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-acm-tests ] | |
| with: | |
| image-file: ar-acm-api-image.tar | |
| image-name: verenigingsregister-acmapi | |
| build-project: AssociationRegistry.Acm.Api/ | |
| semver: ${{ needs.set-release-version.outputs.version }} | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: false | |
| pre-gen-marten: true | |
| secrets: inherit | |
| run-public-tests: | |
| name: Public Api | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.Public.Api | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: true | |
| run-docker-localstack: false | |
| run-docker-otelcollector: true | |
| db-name: golden_master_template | |
| secrets: inherit | |
| build-public-api: | |
| name: Public Api | |
| uses: ./.github/workflows/shared.build-image.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-public-tests ] | |
| with: | |
| image-file: ar-public-api-image.tar | |
| image-name: verenigingsregister-publicapi | |
| build-project: AssociationRegistry.Public.Api/ | |
| semver: ${{ needs.set-release-version.outputs.version }} | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: false | |
| pre-gen-marten: true | |
| secrets: inherit | |
| build-public-projections: | |
| name: Public Projections | |
| uses: ./.github/workflows/shared.build-image.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-public-tests ] | |
| with: | |
| image-file: ar-public-projections-image.tar | |
| image-name: verenigingsregister-publicprojections | |
| build-project: AssociationRegistry.Public.ProjectionHost/ | |
| semver: ${{ needs.set-release-version.outputs.version }} | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: true | |
| run-docker-localstack: false | |
| run-docker-otelcollector: false | |
| pre-gen-marten: true | |
| secrets: inherit | |
| run-admin-tests: | |
| name: Admin Api | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.Admin.Api | |
| run-docker-acm: true | |
| run-docker-wiremock: true | |
| run-docker-db: true | |
| run-docker-elasticsearch: true | |
| run-docker-localstack: true | |
| run-docker-otelcollector: true | |
| db-name: golden_master_template | |
| secrets: inherit | |
| build-admin-api: | |
| name: Build Admin Api | |
| runs-on: ubuntu-latest | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-admin-tests ] | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Build | |
| shell: bash | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| run: | | |
| VERSION=${SEMVER:-"0.0.0"} | |
| if [ "$VERSION" == "none" ]; then | |
| VERSION="0.0.0" | |
| fi | |
| docker buildx build . --build-arg ELASTIC_HOST --build-arg CI_BUILD_NUMBER=$VERSION --build-arg GIT_HASH=${{ github.sha }} --network=host -f src/AssociationRegistry.Admin.Api/Dockerfile \ | |
| --tag ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }}/verenigingsregister-adminapi:$VERSION | |
| - name: Show images | |
| shell: bash | |
| run: docker images | |
| - name: Save Api Image | |
| if: needs.set-release-version.outputs.version != 'none' | |
| shell: bash | |
| run: docker image save ${{secrets.BUILD_DOCKER_REGISTRY_IK4}}/verenigingsregister-adminapi:${{ needs.set-release-version.outputs.version }} -o ~/ar-admin-api-image.tar | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Upload Api artifact | |
| if: needs.set-release-version.outputs.version != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminapi | |
| path: ~/ar-admin-api-image.tar | |
| build-admin-projections: | |
| name: Build Admin Projections | |
| runs-on: ubuntu-latest | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-admin-tests ] | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Build | |
| shell: bash | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| run: | | |
| VERSION=${SEMVER:-"0.0.0"} | |
| if [ "$VERSION" == "none" ]; then | |
| VERSION="0.0.0" | |
| fi | |
| docker buildx build . --build-arg ELASTIC_HOST --build-arg CI_BUILD_NUMBER=$VERSION --build-arg github.sha=${{ github.sha }} --network=host -f src/AssociationRegistry.Admin.ProjectionHost/Dockerfile \ | |
| --tag ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }}/verenigingsregister-adminprojections:$VERSION | |
| - name: Show images | |
| shell: bash | |
| run: docker images | |
| - name: Save Api Image | |
| if: needs.set-release-version.outputs.version != 'none' | |
| shell: bash | |
| run: docker image save ${{secrets.BUILD_DOCKER_REGISTRY_IK4}}/verenigingsregister-adminprojections:${{ needs.set-release-version.outputs.version }} -o ~/ar-admin-projections-image.tar | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Upload Api artifact | |
| if: needs.set-release-version.outputs.version != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminprojections | |
| path: ~/ar-admin-projections-image.tar | |
| run-address-sync-tests: | |
| name: Address Sync | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.Admin.AddressSync | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: true | |
| pre-gen-marten: false | |
| secrets: inherit | |
| build-admin-address-sync: | |
| name: Address Sync | |
| uses: ./.github/workflows/shared.build-image.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-address-sync-tests ] | |
| with: | |
| image-file: ar-admin-address-sync-image.tar | |
| image-name: verenigingsregister-adressensync | |
| build-project: AssociationRegistry.Admin.AddressSync/ | |
| semver: ${{ needs.set-release-version.outputs.version }} | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: false | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: false | |
| pre-gen-marten: false | |
| secrets: inherit | |
| build-admin-api-migrations: | |
| name: Build Admin Api Migrations | |
| runs-on: ubuntu-latest | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-admin-tests ] | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Build | |
| shell: bash | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| run: | | |
| VERSION=${SEMVER:-"0.0.0"} | |
| if [ "$VERSION" == "none" ]; then | |
| VERSION="0.0.0" | |
| fi | |
| pushd migrations/production/admin.api/ \ | |
| && docker buildx build . --build-arg CI_BUILD_NUMBER=$VERSION --build-arg GIT_HASH=${{ github.sha }} \ | |
| --tag ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }}/verenigingsregister-adminapi-migrations:$VERSION \ | |
| && popd | |
| - name: Show images | |
| shell: bash | |
| run: docker images | |
| - name: Save Api Image | |
| if: needs.set-release-version.outputs.version != 'none' | |
| shell: bash | |
| run: docker image save ${{secrets.BUILD_DOCKER_REGISTRY_IK4}}/verenigingsregister-adminapi-migrations:${{ needs.set-release-version.outputs.version }} -o ~/ar-admin-api-migration-image.tar | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Upload Api artifact | |
| if: needs.set-release-version.outputs.version != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminapi-migrations | |
| path: ~/ar-admin-api-migration-image.tar | |
| build-admin-projections-migrations: | |
| name: Build Admin Projections Migrations | |
| runs-on: ubuntu-latest | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-admin-tests ] | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Build | |
| shell: bash | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| run: | | |
| VERSION=${SEMVER:-"0.0.0"} | |
| if [ "$VERSION" == "none" ]; then | |
| VERSION="0.0.0" | |
| fi | |
| pushd migrations/production/admin.projections/ \ | |
| && docker buildx build . --build-arg CI_BUILD_NUMBER=$VERSION --build-arg GIT_HASH=${{ github.sha }} \ | |
| --tag ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }}/verenigingsregister-adminprojections-migrations:$VERSION \ | |
| && popd | |
| - name: Show images | |
| shell: bash | |
| run: docker images | |
| - name: Save Api Image | |
| if: needs.set-release-version.outputs.version != 'none' | |
| shell: bash | |
| run: docker image save ${{secrets.BUILD_DOCKER_REGISTRY_IK4}}/verenigingsregister-adminprojections-migrations:${{ needs.set-release-version.outputs.version }} -o ~/ar-admin-proj-migration-image.tar | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Upload Admin Projections artifact | |
| if: needs.set-release-version.outputs.version != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminprojections-migrations | |
| path: ~/ar-admin-proj-migration-image.tar | |
| build-acm-api-migrations: | |
| name: Build Acm Api Migrations | |
| runs-on: ubuntu-latest | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-acm-tests ] | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Build | |
| shell: bash | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| run: | | |
| VERSION=${SEMVER:-"0.0.0"} | |
| if [ "$VERSION" == "none" ]; then | |
| VERSION="0.0.0" | |
| fi | |
| pushd migrations/production/acm.api/ \ | |
| && docker buildx build . --build-arg CI_BUILD_NUMBER=$VERSION --build-arg GIT_HASH=${{ github.sha }} \ | |
| --tag ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }}/verenigingsregister-acmapi-migrations:$VERSION \ | |
| && popd | |
| - name: Show images | |
| shell: bash | |
| run: docker images | |
| - name: Save Api Image | |
| if: needs.set-release-version.outputs.version != 'none' | |
| shell: bash | |
| run: docker image save ${{secrets.BUILD_DOCKER_REGISTRY_IK4}}/verenigingsregister-acmapi-migrations:${{ needs.set-release-version.outputs.version }} -o ~/ar-acm-api-migration-image.tar | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Upload Api artifact | |
| if: needs.set-release-version.outputs.version != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: verenigingsregister-acmapi-migrations | |
| path: ~/ar-acm-api-migration-image.tar | |
| build-public-projections-migrations: | |
| name: Build Public Projections Migrations | |
| runs-on: ubuntu-latest | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-public-tests ] | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Build | |
| shell: bash | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| run: | | |
| VERSION=${SEMVER:-"0.0.0"} | |
| if [ "$VERSION" == "none" ]; then | |
| VERSION="0.0.0" | |
| fi | |
| pushd migrations/production/public.projections/ \ | |
| && docker buildx build . --build-arg CI_BUILD_NUMBER=$VERSION --build-arg GIT_HASH=${{ github.sha }} \ | |
| --tag ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }}/verenigingsregister-publicprojections-migrations:$VERSION \ | |
| && popd | |
| - name: Show images | |
| shell: bash | |
| run: docker images | |
| - name: Save publicprojections migrations Image | |
| if: needs.set-release-version.outputs.version != 'none' | |
| shell: bash | |
| run: docker image save ${{secrets.BUILD_DOCKER_REGISTRY_IK4}}/verenigingsregister-publicprojections-migrations:${{ needs.set-release-version.outputs.version }} -o ~/ar-public-proj-migration-image.tar | |
| env: | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Upload Api artifact | |
| if: needs.set-release-version.outputs.version != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: verenigingsregister-publicprojections-migrations | |
| path: ~/ar-public-proj-migration-image.tar | |
| run-powerbi-tests: | |
| name: PowerBi | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.PowerBi.ExportHost | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: true | |
| pre-gen-marten: false | |
| secrets: inherit | |
| build-powerbi-exporthost: | |
| name: Build PowerBI Export Scheduled Task | |
| uses: ./.github/workflows/shared.build-image.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| needs: [ set-release-version, run-powerbi-tests ] | |
| with: | |
| image-file: ar-powerbiexport-image.tar | |
| image-name: verenigingsregister-powerbiexport | |
| build-project: AssociationRegistry.PowerBi.ExportHost/ | |
| semver: ${{ needs.set-release-version.outputs.version }} | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: false | |
| run-docker-elasticsearch: false | |
| run-docker-localstack: false | |
| run-docker-otelcollector: false | |
| pre-gen-marten: false | |
| secrets: inherit | |
| build-sync-lambda: | |
| name: Build Sync Lambda | |
| needs: [ set-release-version ] | |
| runs-on: ubuntu-latest | |
| if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
| steps: | |
| - name: Check version | |
| shell: bash | |
| run: echo $SEMVER | |
| env: | |
| SEMVER: ${{ needs.set-release-version.outputs.version }} | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Parse repository name | |
| run: echo REPOSITORY_NAME=$(echo "$GITHUB_REPOSITORY" | awk -F / '{print $2}' | sed -e "s/:refs//") >> $GITHUB_ENV | |
| shell: bash | |
| - name: Setup .NET Core | |
| uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: ${{ vars.VBR_DOTNET_VERSION_9 }} | |
| - name: .NET version | |
| shell: bash | |
| run: dotnet --info | |
| - name: Restore dotnet tools | |
| shell: bash | |
| run: | | |
| dotnet tool restore | |
| - name: Dotnet restore | |
| shell: bash | |
| run: dotnet restore --runtime linux-x64 | |
| - name: Package lambda | |
| if: inputs.semver != 'none' | |
| shell: bash | |
| run: cd src/AssociationRegistry.KboMutations.SyncLambda && dotnet lambda package --region ${{ secrets.VBR_AWS_REGION }} | |
| - name: Upload Lambda as Artifact | |
| if: inputs.semver != 'none' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: lambda-sync-${{ needs.set-release-version.outputs.version }} | |
| path: src/AssociationRegistry.KboMutations.SyncLambda/bin/Release/net9.0/AssociationRegistry.KboMutations.SyncLambda.zip | |
| run-e2e-tests: | |
| name: E2E | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.E2E | |
| run-docker-acm: true | |
| run-docker-wiremock: true | |
| run-docker-db: true | |
| run-docker-elasticsearch: true | |
| run-docker-localstack: true | |
| run-docker-otelcollector: true | |
| db-name: golden_master_template | |
| secrets: inherit | |
| run-projections-tests: | |
| name: Projections | |
| uses: ./.github/workflows/shared.run-tests.yml | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| with: | |
| test-project: AssociationRegistry.Test.Projections | |
| run-docker-acm: false | |
| run-docker-wiremock: false | |
| run-docker-db: true | |
| run-docker-elasticsearch: true | |
| run-docker-localstack: false | |
| run-docker-otelcollector: true | |
| db-name: golden_master_template | |
| secrets: inherit | |
| # pack-association-registry: | |
| # name: Pack Association Registry Domain | |
| # uses: Informatievlaanderen/build-pipeline/.github/workflows/pack.yml@main | |
| # needs: [ set-release-version ] | |
| # if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.set-release-version.outputs.version != 'none') }} | |
| # with: | |
| # pack-file: Be.Vlaanderen.Basisregisters.AssociationRegistry | |
| # build-project: AssociationRegistry | |
| # semver: ${{ needs.set-release-version.outputs.version }} | |
| # secrets: inherit | |
| release: | |
| if: github.repository_owner == 'Informatievlaanderen' | |
| name: Semantic Release | |
| runs-on: ubuntu-latest | |
| needs: [ | |
| set-release-version, | |
| build-acm-api, | |
| build-public-api, | |
| build-public-projections, | |
| build-admin-api, | |
| build-admin-projections, | |
| build-admin-api-migrations, | |
| build-admin-address-sync, | |
| build-powerbi-exporthost, | |
| # pack-association-registry, | |
| build-sync-lambda, | |
| run-unit-tests, | |
| run-e2e-tests, | |
| run-projections-tests | |
| ] | |
| outputs: | |
| version: ${{ steps.set-version.outputs.version }} | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Setup .NET Core | |
| uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: ${{ vars.VBR_DOTNET_VERSION_9 }} | |
| - name: Dotnet restore | |
| shell: bash | |
| run: dotnet restore --runtime linux-x64 | |
| - name: Cache NPM | |
| uses: actions/cache@v4 | |
| env: | |
| cache-name: cache-npm | |
| with: | |
| path: ~/.npm | |
| key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }} | |
| restore-keys: | | |
| ${{ runner.os }}-build-${{ env.cache-name }}- | |
| - name: Parse repository name | |
| run: echo REPOSITORY_NAME=$(echo "$GITHUB_REPOSITORY" | awk -F / '{print $2}' | sed -e "s/:refs//") >> $GITHUB_ENV | |
| shell: bash | |
| - name: Setup Node.js | |
| uses: actions/setup-node@v4 | |
| - name: Set up Python | |
| uses: actions/setup-python@v5 | |
| with: | |
| python-version: '3.x' | |
| - name: Node version | |
| shell: bash | |
| run: node --version | |
| - name: .NET version | |
| shell: bash | |
| run: dotnet --info | |
| - name: Python version | |
| shell: bash | |
| run: python --version | |
| - name: Install NPM dependencies | |
| shell: bash | |
| run: npm install --legacy-peer-deps | |
| - name: Install Python dependencies | |
| shell: bash | |
| run: | | |
| python -m pip install --upgrade pip | |
| pip install requests markdown argparse | |
| - name: Generate Token | |
| id: generate_token # Add an ID to this step for reference | |
| run: node .github/build-scripts/generate-token.js | |
| env: | |
| APP_ID: ${{ secrets.MYBOT_APP_ID }} | |
| PRIVATE_KEY: ${{ secrets.MYBOT_PRIVATE_KEY }} | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| with: | |
| token: ${{ steps.generate_token.outputs.installationToken }} | |
| - name: Install NPM dependencies | |
| shell: bash | |
| run: npm install --legacy-peer-deps | |
| - name: Run Semantic Release | |
| shell: bash | |
| run: npx semantic-release | |
| env: | |
| NPM_TOKEN: ${{ secrets.VBR_WEBCOMP_NPM_TOKEN }} | |
| BUILD_DOCKER_REGISTRY: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| GITHUB_TOKEN: ${{ steps.generate_token.outputs.installationToken }} | |
| GIT_COMMIT: ${{ github.sha }} | |
| GIT_USERNAME: ${{ steps.generate_token.outputs.installationToken }} | |
| GIT_AUTHOR_NAME: ${{ secrets.VBR_GIT_USER }} | |
| GIT_COMMITTER_NAME: ${{ secrets.VBR_GIT_USER }} | |
| GIT_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
| GIT_AUTHOR_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
| GIT_COMMITTER_EMAIL: ${{ secrets.VBR_GIT_EMAIL }} | |
| - name: Set Release Version | |
| id: set-version | |
| run: | | |
| [ ! -f semver ] && echo none > semver | |
| echo $(cat semver) | |
| echo ::set-output name=version::$(cat semver) | |
| echo RELEASE_VERSION=$(cat semver) >> $GITHUB_ENV | |
| shell: bash | |
| publish_to_nuget: | |
| needs: [ release ] | |
| if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.release.outputs.version != 'none') }} | |
| name: Publish to NuGet | |
| runs-on: ubuntu-latest | |
| steps: | |
| - run: 'true' | |
| # - name: Checkout Code | |
| # uses: actions/checkout@v4 | |
| # | |
| # - name: Setup .NET Core | |
| # uses: actions/setup-dotnet@v4 | |
| # with: | |
| # dotnet-version: ${{ vars.VBR_DOTNET_VERSION_8 }} | |
| # | |
| # - name: .NET version | |
| # shell: bash | |
| # run: dotnet --info | |
| # | |
| # - name: Download NuGet package 'association-registry' | |
| # uses: actions/download-artifact@v4 | |
| # with: | |
| # name: nuget-Be.Vlaanderen.Basisregisters.AssociationRegistry-${{ needs.release.outputs.version }} | |
| # path: dist/nuget/ | |
| # | |
| # - name: Publish packages to NuGet 'association-registry' | |
| # shell: bash | |
| # run: | | |
| # dotnet nuget push dist/nuget/Be.Vlaanderen.Basisregisters.AssociationRegistry.$SEMVER.nupkg --source nuget.org --api-key $NUGET_API_KEY | |
| # env: | |
| # SEMVER: ${{ needs.release.outputs.version }} | |
| # WORKSPACE: ${{ github.workspace }} | |
| # NUGET_API_KEY: ${{ secrets.NUGET_API_KEY }} | |
| upload-sync-lambda: | |
| name: Upload & Deploy Sync Lambda | |
| needs: [ release ] | |
| environment: test_ik4 | |
| runs-on: ubuntu-latest | |
| if: ${{ (github.repository_owner == 'Informatievlaanderen') && (needs.release.outputs.version != 'none') }} | |
| steps: | |
| - name: Download Lambda | |
| uses: actions/download-artifact@v4 | |
| continue-on-error: false | |
| with: | |
| name: lambda-sync-${{ needs.release.outputs.version }} | |
| path: ~/ | |
| - name: Configure AWS credentials | |
| uses: aws-actions/configure-aws-credentials@v4 | |
| with: | |
| aws-access-key-id: ${{ secrets.VBR_AWS_BUILD_USER_ACCESS_KEY_ID_IK4 }} | |
| aws-secret-access-key: ${{ secrets.VBR_AWS_BUILD_USER_SECRET_ACCESS_KEY_IK4 }} | |
| aws-region: ${{ secrets.VBR_AWS_REGION }} | |
| - name: Show AWS CLI version | |
| shell: bash | |
| run: aws --version | |
| - name: Upload Lambda function | |
| shell: bash | |
| run: | | |
| aws s3 cp ~/AssociationRegistry.KboMutations.SyncLambda.zip s3://$S3_LAMBDA_BUCKETNAME/$S3_LAMBDA/$VERSION/lambda.zip --copy-props none | |
| env: | |
| VERSION: ${{ needs.release.outputs.version }} | |
| S3_LAMBDA_BUCKETNAME: ${{ vars.S3_LAMBDA_BUCKETNAME }} | |
| S3_LAMBDA: 'kbo-sync' | |
| - name: CD | |
| id: awscurl-polling-action | |
| env: | |
| BUILD_URL: ${{ secrets.VBR_AWS_BUILD_API }}/kbosync/test/deploy/v4 | |
| STATUS_URL: ${{ secrets.VBR_AWS_BUILD_STATUS_API }}/kbosync/test/deploy/v4/status | |
| uses: informatievlaanderen/awscurl-polling-action/polling-action@deploy-v4 | |
| with: | |
| environment: test | |
| version: ${{ needs.release.outputs.version }} | |
| status-url: $STATUS_URL | |
| deploy-url: $BUILD_URL | |
| access-key: ${{ secrets.VBR_AWS_BUILD_USER_ACCESS_KEY_ID_IK4 }} | |
| secret-key: ${{ secrets.VBR_AWS_BUILD_USER_SECRET_ACCESS_KEY_IK4 }} | |
| deploy-target: 'lambda' | |
| domain: 'verenigingsregister' | |
| project: 'verenigingsregister' | |
| application: 'lambda' | |
| interval: 2 | |
| - name: output | |
| shell: bash | |
| if: always() | |
| run: | | |
| echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
| echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
| echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
| publish_to_atlassian: | |
| if: needs.release.outputs.version != 'none' | |
| needs: [ release ] | |
| name: Publish to Atlassian | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout Code | |
| uses: actions/checkout@v4 | |
| - name: Parse repository name | |
| run: echo REPOSITORY_NAME=$(echo "$GITHUB_REPOSITORY" | awk -F / '{print $2}' | sed -e "s/:refs//") >> $GITHUB_ENV | |
| shell: bash | |
| - name: Cache Python | |
| uses: actions/cache@v4 | |
| env: | |
| cache-name: cache-pip | |
| with: | |
| path: ~/.cache/pip | |
| key: ${{ runner.os }}-build-${{ env.cache-name }} | |
| - name: Set up Python | |
| uses: actions/setup-python@v5 | |
| with: | |
| python-version: '3.x' | |
| - name: Install Python dependencies | |
| shell: bash | |
| run: | | |
| python -m pip install --upgrade pip | |
| pip install requests markdown argparse | |
| - name: Publish to Confluence | |
| if: needs.release.outputs.version != 'none' | |
| shell: bash | |
| run: ${{ vars.BUILD_PIPELINE_CONTENT_LOCATION }}/ci-confluence.sh | |
| env: | |
| CONFLUENCE_TITLE: ${{ env.REPOSITORY_NAME }} | |
| CONFLUENCE_USERNAME: ${{ secrets.VBR_CONFLUENCE_USER }} | |
| CONFLUENCE_PASSWORD: ${{ secrets.VBR_CONFLUENCE_PASSWORD }} | |
| - name: Create Jira Release | |
| if: needs.release.outputs.version != 'none' | |
| shell: bash | |
| run: ${{ vars.BUILD_PIPELINE_CONTENT_LOCATION }}/ci-jira.sh | |
| env: | |
| CONFLUENCE_TITLE: ${{ env.REPOSITORY_NAME }} | |
| CONFLUENCE_USERNAME: ${{ secrets.VBR_CONFLUENCE_USER }} | |
| CONFLUENCE_PASSWORD: ${{ secrets.VBR_CONFLUENCE_PASSWORD }} | |
| JIRA_PREFIX: Association | |
| JIRA_PROJECT: OR | |
| JIRA_VERSION: ${{ needs.release.outputs.version }} | |
| push_images_to_ik4_devops: | |
| if: needs.release.outputs.version != 'none' | |
| needs: [ release ] | |
| name: Push images IK4 (DevOps) | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Configure AWS credentials (Test) | |
| if: needs.release.outputs.version != 'none' | |
| uses: aws-actions/configure-aws-credentials@v4 | |
| with: | |
| aws-access-key-id: ${{ secrets.VBR_AWS_BUILD_USER_ACCESS_KEY_ID_IK4 }} | |
| aws-secret-access-key: ${{ secrets.VBR_AWS_BUILD_USER_SECRET_ACCESS_KEY_IK4 }} | |
| aws-region: ${{ secrets.VBR_AWS_REGION_PRD }} | |
| - name: Login to Amazon ECR (Test) | |
| if: needs.release.outputs.version != 'none' | |
| uses: aws-actions/[email protected] | |
| - name: Download Acm Api artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-acmapi | |
| path: ~/ | |
| - name: Load Acm Api image | |
| shell: bash | |
| run: docker image load -i ~/ar-acm-api-image.tar | |
| - name: Download Public Api artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-publicapi | |
| path: ~/ | |
| - name: Load Public Api image | |
| shell: bash | |
| run: docker image load -i ~/ar-public-api-image.tar | |
| - name: Download Public Projections artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-publicprojections | |
| path: ~/ | |
| - name: Load Public Projections image | |
| shell: bash | |
| run: docker image load -i ~/ar-public-projections-image.tar | |
| - name: Download Admin Api artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminapi | |
| path: ~/ | |
| - name: Load Admin Api image | |
| shell: bash | |
| run: docker image load -i ~/ar-admin-api-image.tar | |
| - name: Download Admin Projections artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminprojections | |
| path: ~/ | |
| - name: Load Admin Projections image | |
| shell: bash | |
| run: docker image load -i ~/ar-admin-projections-image.tar | |
| - name: Download Admin Address Sync Scheduled Task artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-adressensync | |
| path: ~/ | |
| - name: Load Admin Address Sync Scheduled Task image | |
| shell: bash | |
| run: docker image load -i ~/ar-admin-address-sync-image.tar | |
| - name: Download PowerBI Export Scheduled Task artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-powerbiexport | |
| path: ~/ | |
| - name: Load PowerBI Export Scheduled Task image | |
| shell: bash | |
| run: docker image load -i ~/ar-powerbiexport-image.tar | |
| - name: Download Admin API Migrations artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminapi-migrations | |
| path: ~/ | |
| - name: Load Admin API Migrations image | |
| shell: bash | |
| run: docker image load -i ~/ar-admin-api-migration-image.tar | |
| - name: Download Admin Projections Migrations artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-adminprojections-migrations | |
| path: ~/ | |
| - name: Load Admin Projections Migrations image | |
| shell: bash | |
| run: docker image load -i ~/ar-admin-proj-migration-image.tar | |
| - name: Download ACM API Migrations artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-acmapi-migrations | |
| path: ~/ | |
| - name: Load Acm Api Migrations image | |
| shell: bash | |
| run: docker image load -i ~/ar-acm-api-migration-image.tar | |
| - name: Download Public projections Migrations artifact | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: verenigingsregister-publicprojections-migrations | |
| path: ~/ | |
| - name: Load Public Projections Migrations image | |
| shell: bash | |
| run: docker image load -i ~/ar-public-proj-migration-image.tar | |
| - name: Push docker images to ECR Test | |
| if: needs.release.outputs.version != 'none' | |
| shell: bash | |
| run: | | |
| echo $SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-acmapi:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-adminapi:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-adminprojections:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-publicapi:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-publicprojections:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-adressensync:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-powerbiexport:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-adminapi-migrations:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-adminprojections-migrations:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-publicprojections-migrations:$SEMVER | |
| docker push $BUILD_DOCKER_REGISTRY_IK4/verenigingsregister-acmapi-migrations:$SEMVER | |
| env: | |
| BUILD_DOCKER_REGISTRY_IK4: ${{ secrets.BUILD_DOCKER_REGISTRY_IK4 }} | |
| SEMVER: ${{ needs.release.outputs.version }} | |
| WORKSPACE: ${{ github.workspace }} | |
| deploy_test_ik4: | |
| if: needs.release.outputs.version != 'none' | |
| needs: [ set-release-version, push_images_to_ik4_devops, release ] | |
| name: Deploy to Test (IK4) | |
| environment: test_ik4 | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| services: | |
| [ | |
| 'acmapi', | |
| 'publicapi', | |
| 'publicprojections', | |
| 'adminapi', | |
| 'adminprojections', | |
| ] | |
| steps: | |
| - name: debug_output | |
| shell: bash | |
| run: | | |
| echo ${{ needs.release.outputs.version }} | |
| - name: CD | |
| id: awscurl-polling-action | |
| if: needs.release.outputs.version != 'none' | |
| env: | |
| BUILD_URL: ${{ secrets.VBR_AWS_BUILD_API }}/${{matrix.services}}/test/deploy/v4 | |
| STATUS_URL: ${{ secrets.VBR_AWS_BUILD_STATUS_API }}/${{matrix.services}}/test/deploy/v4/status | |
| uses: informatievlaanderen/awscurl-polling-action/polling-action@deploy-v4 | |
| with: | |
| environment: test | |
| version: ${{ needs.release.outputs.version }} | |
| status-url: $STATUS_URL | |
| deploy-url: $BUILD_URL | |
| access-key: ${{ secrets.VBR_AWS_BUILD_USER_ACCESS_KEY_ID_IK4 }} | |
| secret-key: ${{ secrets.VBR_AWS_BUILD_USER_SECRET_ACCESS_KEY_IK4 }} | |
| region: eu-west-1 | |
| deploy-target: 'ecs' | |
| domain: 'verenigingsregister' | |
| project: 'verenigingsregister' | |
| application: ${{matrix.services}} | |
| interval: 2 | |
| - name: output | |
| shell: bash | |
| if: always() | |
| run: | | |
| echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
| echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
| echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
| deploy_test_scheduledtasks_ik4: | |
| if: needs.release.outputs.version != 'none' | |
| needs: [ set-release-version, push_images_to_ik4_devops, release ] | |
| name: Deploy scheduled tasks to Test (IK4) | |
| environment: test_ik4 | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| services: | |
| [ | |
| 'adressensync', | |
| 'powerbiexport' | |
| ] | |
| steps: | |
| - name: debug_output | |
| shell: bash | |
| run: | | |
| echo ${{ needs.release.outputs.version }} | |
| - name: CD | |
| id: awscurl-polling-action | |
| if: needs.release.outputs.version != 'none' | |
| env: | |
| BUILD_URL: ${{ secrets.VBR_AWS_BUILD_API }}/${{matrix.services}}/test/deploy/v4 | |
| STATUS_URL: ${{ secrets.VBR_AWS_BUILD_STATUS_API }}/${{matrix.services}}/test/deploy/v4/status | |
| uses: informatievlaanderen/awscurl-polling-action/polling-action@deploy-v4 | |
| with: | |
| environment: test | |
| version: ${{ needs.release.outputs.version }} | |
| status-url: $STATUS_URL | |
| deploy-url: $BUILD_URL | |
| access-key: ${{ secrets.VBR_AWS_BUILD_USER_ACCESS_KEY_ID_IK4 }} | |
| secret-key: ${{ secrets.VBR_AWS_BUILD_USER_SECRET_ACCESS_KEY_IK4 }} | |
| region: eu-west-1 | |
| deploy-target: 'ecs' | |
| domain: 'verenigingsregister' | |
| project: 'verenigingsregister' | |
| application: ${{matrix.services}} | |
| interval: 2 | |
| - name: output | |
| shell: bash | |
| if: always() | |
| run: | | |
| echo build-uuid: ${{ steps.awscurl-polling-action.outputs.build-uuid }} | |
| echo Status: ${{ steps.awscurl-polling-action.outputs.status }} | |
| echo ${{ steps.awscurl-polling-action.outputs.final-message }} | |
| notify: | |
| if: failure() | |
| name: Notify slack | |
| runs-on: ubuntu-latest | |
| needs: [ deploy_test_ik4, deploy_test_scheduledtasks_ik4 ] | |
| steps: | |
| - name: Construct Slack message | |
| id: construct_message | |
| run: | | |
| USER_IDS="${{ secrets.SLACK_USER_IDS }}" | |
| IFS=',' read -r -a array <<< "$USER_IDS" | |
| MENTIONS="" | |
| for user_id in "${array[@]}" | |
| do | |
| MENTIONS+="<@$user_id> " | |
| done | |
| echo "::set-output name=mentions::$MENTIONS" | |
| - name: Post to a Slack channel | |
| id: slack | |
| uses: slackapi/[email protected] | |
| with: | |
| channel-id: ${{ secrets.SLACK_CHANNEL_ID }} | |
| slack-message: | | |
| GitHub build result: ${{ job.status }} | |
| ${{ github.event.pull_request.html_url || github.event.head_commit.url }} | |
| ${{ steps.construct_message.outputs.mentions }} Please check the build failure. | |
| env: | |
| SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }} | |
| call-postman-tests: | |
| needs: | |
| - deploy_test_ik4 | |
| - deploy_test_scheduledtasks_ik4 | |
| - upload-sync-lambda | |
| uses: ./.github/workflows/postman.minimal.yml | |
| secrets: | |
| POSTMAN_API_KEY: ${{ secrets.POSTMAN_API_KEY }} | |
| SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} |