From 2ecaa7b3b869ca5e146c45f95ba91bba8a9b30e3 Mon Sep 17 00:00:00 2001 From: Pat Date: Thu, 7 Apr 2022 10:18:58 +0100 Subject: [PATCH] workflows: support 1.8 branch builds plus MacOS (and Windows for staging) (#5248) * workflows: rename to Linux only Signed-off-by: Patrick Stephens * workflows: add reusable job for Windows build Signed-off-by: Patrick Stephens * workflows: call Windows CI in staging build Signed-off-by: Patrick Stephens * workflows: update container build job to handle 1.8 branches Signed-off-by: Patrick Stephens * workflows: add MacOS build Signed-off-by: Patrick Stephens * workflows: linting and other updates Signed-off-by: Patrick Stephens * workflows: linting fix Signed-off-by: Patrick Stephens * workflows: add permissions to new workflows Signed-off-by: Patrick Stephens * workflows: temporary change to invoke reusable workflows on this branch, REVERT BEFORE MERGE Signed-off-by: Patrick Stephens * workflows: fix names Signed-off-by: Patrick Stephens * workflows: add build matrix support for branches Signed-off-by: Patrick Stephens * workflows: update PRs to use Windows job Signed-off-by: Patrick Stephens * workflows: support legacy td-agent-bit in Windows builds Signed-off-by: Patrick Stephens * workflows: fix review comment Signed-off-by: Patrick Stephens * workflows: revert temporary branch change for testing Signed-off-by: Patrick Stephens * workflows: document needs for build matrix action Signed-off-by: Patrick Stephens --- .../generate-package-build-matrix/action.yaml | 51 +++++--- .github/workflows/README.md | 7 ++ .github/workflows/build-master-packages.yaml | 2 +- .github/workflows/call-build-images.yaml | 50 ++++++-- ...es.yaml => call-build-linux-packages.yaml} | 51 ++++++-- .github/workflows/call-build-macos.yaml | 110 ++++++++++++++++++ .github/workflows/call-build-windows.yaml | 97 +++++++++++++++ .github/workflows/cron-unstable-build.yaml | 65 ++++------- .github/workflows/pr-windows-build.yaml | 67 ++--------- .github/workflows/staging-build.yaml | 33 +++++- 10 files changed, 395 insertions(+), 138 deletions(-) rename .github/workflows/{call-build-packages.yaml => call-build-linux-packages.yaml} (84%) create mode 100644 .github/workflows/call-build-macos.yaml create mode 100644 .github/workflows/call-build-windows.yaml diff --git a/.github/actions/generate-package-build-matrix/action.yaml b/.github/actions/generate-package-build-matrix/action.yaml index 4d53dc3e3a0..cf2e4275b62 100644 --- a/.github/actions/generate-package-build-matrix/action.yaml +++ b/.github/actions/generate-package-build-matrix/action.yaml @@ -2,14 +2,17 @@ name: Composite action to generate the matrix of targets to build packages for. description: Remove any duplication of this information so we only have to update in one place. +# Remember to add any new checks and target creation required. +# For example, when 2.0 comes out we should detect it and add any target changes. + inputs: target: description: Override to build a single target for debug/test only. required: false - fluent-bit-version: - description: The version of Fluent Bit to build. - required: false - default: 'master' + default: '' + ref: + description: The commit, tag or branch of Fluent Bit to checkout for building we then use to determine version for. + required: true outputs: build-matrix: description: The build matrix we have created. @@ -17,8 +20,28 @@ outputs: runs: using: "composite" steps: - - name: master/1.9 targets - if: inputs.fluent-bit-version != '1.8' + - name: Checkout code for version check + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + path: version-check + + - name: Determine target type + # TODO: probably switch to a sentinel file with the version in rather than checking for specific changes, or git branch tests. + id: determine-build-type + run: | + ls -l + BUILD_TYPE="1.8" + if [[ -d "packaging" ]]; then + BUILD_TYPE="1.9" + fi + echo "Detected type: $BUILD_TYPE" + echo ::set-output name=BUILD_TYPE::$BUILD_TYPE + shell: bash + working-directory: version-check + + - name: 1.9 targets + if: steps.determine-build-type.outputs.BUILD_TYPE == '1.9' run: | matrix=$(( echo '{ "distro" : [' @@ -29,19 +52,11 @@ runs: echo '"raspbian/buster", "raspbian/bullseye"' echo ']}' ) | jq -c .) - if [ -n "${{ inputs.target || '' }}" ]; then - echo "Overriding matrix to build: ${{ inputs.target }}" - matrix=$(( - echo '{ "distro" : [' - echo '"${{ inputs.target }}"' - echo ']}' - ) | jq -c .) - fi echo "MATRIX=$matrix" >> $GITHUB_ENV shell: bash - name: 1.8 targets - if: inputs.fluent-bit-version == '1.8' + if: steps.determine-build-type.outputs.BUILD_TYPE == '1.8' run: | matrix=$(( echo '{ "distro" : [' @@ -52,6 +67,12 @@ runs: echo '"raspbian/buster"' echo ']}' ) | jq -c .) + echo "MATRIX=$matrix" >> $GITHUB_ENV + shell: bash + + - name: Manual override of target + if: inputs.target != '' + run: | if [ -n "${{ inputs.target || '' }}" ]; then echo "Overriding matrix to build: ${{ inputs.target }}" matrix=$(( diff --git a/.github/workflows/README.md b/.github/workflows/README.md index aa2d9c56120..7647785ff0f 100644 --- a/.github/workflows/README.md +++ b/.github/workflows/README.md @@ -58,6 +58,13 @@ For some reason this is not automatically done via permission inheritance or sim 2. Once this is working locally, you should then be able to set up action permissions for the repository. If you already have a package no need to push a test one. 3. Go to `https://github.com/users/USER/packages/container/fluent-bit/settings` and ensure the repository has access to `Write`. +## Version-specific targets + +Each major version (e.g. 1.8 & 1.9) supports different targets to build for, e.g. 1.9 includes a CentOS 8 target and 1.8 has some other legacy targets. + +This is all handled by the [build matrix generation composite action](../actions/generate-package-build-matrix/action.yaml) so make sure to update appropriately. +The build matrix is then fed into the reusable job that builds packages which will then fire for the appropriate targets. + ## Releases Currently the process is as follows: diff --git a/.github/workflows/build-master-packages.yaml b/.github/workflows/build-master-packages.yaml index a7f539a19d3..06c7f4231c3 100644 --- a/.github/workflows/build-master-packages.yaml +++ b/.github/workflows/build-master-packages.yaml @@ -42,7 +42,7 @@ jobs: master-build-packages: needs: master-build-generate-matrix - uses: fluent/fluent-bit/.github/workflows/call-build-packages.yaml@master + uses: fluent/fluent-bit/.github/workflows/call-build-linux-packages.yaml@master with: version: master ref: master diff --git a/.github/workflows/call-build-images.yaml b/.github/workflows/call-build-images.yaml index 121ad481f23..3d4d8e9c677 100644 --- a/.github/workflows/call-build-images.yaml +++ b/.github/workflows/call-build-images.yaml @@ -44,26 +44,54 @@ on: description: If the Cosign key requires a password then specify here, otherwise not required. required: false jobs: + call-build-legacy-check: + # Determine if this is a 1.8 type of build which is different + name: Extract any supporting metadata + outputs: + build-type: ${{ steps.determine-build-type.outputs.BUILD_TYPE }} + runs-on: ubuntu-latest + environment: ${{ inputs.environment }} + permissions: + contents: read + steps: + - name: Checkout code + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + + - name: Determine build type + id: determine-build-type + run: | + BUILD_TYPE="1.8" + if [[ -f "dockerfiles/Dockerfile" ]]; then + BUILD_TYPE="modern" + fi + echo "Detected type: $BUILD_TYPE" + echo ::set-output name=BUILD_TYPE::$BUILD_TYPE + shell: bash + call-build-images: name: Multiarch container images to GHCR runs-on: ubuntu-latest environment: ${{ inputs.environment }} + needs: + - call-build-legacy-check permissions: contents: read packages: write steps: - - name: Checkout code - if: inputs.ref != '1.8' + - name: Checkout code for modern style builds + if: needs.call-build-legacy-check.outputs.build-type != '1.8' uses: actions/checkout@v3 with: ref: ${{ inputs.ref }} - - name: Checkout the docker build repo - if: inputs.ref == '1.8' + - name: Checkout the docker build repo for legacy builds + if: needs.call-build-legacy-check.outputs.build-type == '1.8' uses: actions/checkout@v3 with: repository: fluent/fluent-bit-docker-image - ref: '1.8' + ref: '1.8' # Fixed to this branch - name: Set up QEMU uses: docker/setup-qemu-action@v1 @@ -88,7 +116,7 @@ jobs: raw,latest - name: Build the production images - if: inputs.ref != '1.8' + if: needs.call-build-legacy-check.outputs.build-type != '1.8' uses: docker/build-push-action@v2 with: file: ./dockerfiles/Dockerfile @@ -111,7 +139,7 @@ jobs: raw,latest-debug - name: Build the debug multi-arch images - if: inputs.ref != '1.8' + if: needs.call-build-legacy-check.outputs.build-type != '1.8' uses: docker/build-push-action@v2 with: file: ./dockerfiles/Dockerfile @@ -126,7 +154,7 @@ jobs: FLB_NIGHTLY_BUILD=${{ inputs.unstable }} - name: Build the legacy image - if: inputs.ref == '1.8' + if: needs.call-build-legacy-check.outputs.build-type == '1.8' uses: docker/build-push-action@v2 with: file: Dockerfile.x86_64 @@ -140,10 +168,12 @@ jobs: FLB_TARBALL=https://github.com/fluent/fluent-bit/tarball/${{ inputs.ref }} call-build-images-generate-schema: - if: inputs.ref != '1.8' + needs: + - call-build-legacy-check + - call-build-images + if: needs.call-build-legacy-check.outputs.build-type != '1.8' runs-on: ubuntu-latest environment: ${{ inputs.environment }} - needs: call-build-images permissions: contents: read packages: read diff --git a/.github/workflows/call-build-packages.yaml b/.github/workflows/call-build-linux-packages.yaml similarity index 84% rename from .github/workflows/call-build-packages.yaml rename to .github/workflows/call-build-linux-packages.yaml index d636ab9f79e..0bf329eec46 100644 --- a/.github/workflows/call-build-packages.yaml +++ b/.github/workflows/call-build-linux-packages.yaml @@ -46,25 +46,54 @@ on: required: false jobs: + call-build-legacy-check: + # Determine if this is a 1.8 type of build which is different + name: Extract any supporting metadata + outputs: + build-type: ${{ steps.determine-build-type.outputs.BUILD_TYPE }} + runs-on: ubuntu-latest + environment: ${{ inputs.environment }} + permissions: + contents: read + steps: + - name: Checkout code + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + + - name: Determine build type + id: determine-build-type + run: | + BUILD_TYPE="1.8" + if [[ -f "dockerfiles/Dockerfile" ]]; then + BUILD_TYPE="modern" + fi + echo "Detected type: $BUILD_TYPE" + echo ::set-output name=BUILD_TYPE::$BUILD_TYPE + shell: bash # We build both master/1.9 and 1.8 style packages in a single job as it is simpler to keep all the custom # code and workflow together. We need to run the dependent job after this as well. - call-build-packages: + call-build-linux-packages: name: ${{ matrix.distro }} package build and stage to S3 environment: ${{ inputs.environment }} runs-on: ubuntu-latest + needs: + - call-build-legacy-check + permissions: + contents: read strategy: fail-fast: false matrix: ${{ fromJSON(inputs.build_matrix) }} steps: - name: Checkout code - if: inputs.ref != '1.8' + if: needs.call-build-legacy-check.outputs.build-type != '1.8' uses: actions/checkout@v3 with: ref: ${{ inputs.ref }} - - name: Checkout packaging code - if: inputs.ref == '1.8' + - name: Checkout legacy packaging code + if: needs.call-build-legacy-check.outputs.build-type == '1.8' uses: actions/checkout@v3 with: repository: fluent/fluent-bit-packaging @@ -85,7 +114,7 @@ jobs: flags: 'g' - name: fluent-bit - ${{ matrix.distro }} artifacts - if: inputs.ref != '1.8' + if: needs.call-build-legacy-check.outputs.build-type != '1.8' run: | ./build.sh env: @@ -98,7 +127,7 @@ jobs: working-directory: packaging - name: td-agent-bit - ${{ matrix.distro }} artifacts - if: inputs.ref != '1.8' + if: needs.call-build-legacy-check.outputs.build-type != '1.8' run: | ./build.sh env: @@ -111,7 +140,7 @@ jobs: working-directory: packaging - name: Legacy td-agent-bit - ${{ matrix.distro }} artifacts - if: inputs.ref == '1.8' + if: needs.call-build-legacy-check.outputs.build-type == '1.8' run: | ./build.sh -v $FLB_VERSION -b $FLB_BRANCH -d $FLB_DISTRO env: @@ -153,7 +182,7 @@ jobs: - name: Push packages to S3 # Only upload for staging - if: ${{ inputs.environment == 'staging' }} + if: inputs.environment == 'staging' # Make sure not to do a --delete on sync as it will remove the other architecture run: | if [ -z "${{ steps.get-target-info.outputs.target }}" ]; then @@ -172,15 +201,15 @@ jobs: AWS_SECRET_ACCESS_KEY: ${{ secrets.secret_access_key }} AWS_S3_BUCKET: ${{ secrets.bucket }} - call-build-packages-repo: + call-build-linux-packages-repo: name: Create repo metadata in S3 # Only upload for staging - if: ${{ inputs.environment == 'staging' }} + if: inputs.environment == 'staging' # Need to use 18.04 as 20.04 has no createrepo available runs-on: ubuntu-18.04 environment: ${{ inputs.environment }} needs: - - call-build-packages + - call-build-linux-packages steps: - name: Install dependencies run: | diff --git a/.github/workflows/call-build-macos.yaml b/.github/workflows/call-build-macos.yaml new file mode 100644 index 00000000000..e9ea3eded81 --- /dev/null +++ b/.github/workflows/call-build-macos.yaml @@ -0,0 +1,110 @@ +--- +name: Reusable workflow to build Windows packages optionally into S3 bucket + +on: + workflow_call: + inputs: + version: + description: The version of Fluent Bit to create. + type: string + required: true + ref: + description: The commit, tag or branch of Fluent Bit to checkout for building that creates the version above. + type: string + required: true + environment: + description: The Github environment to run this workflow on. + type: string + required: false + unstable: + description: Optionally add metadata to build to indicate an unstable build, set to the contents you want to add. + type: string + required: false + default: '' + secrets: + token: + description: The Github token or similar to authenticate with. + required: true + bucket: + description: The name of the S3 (US-East) bucket to push packages into. + required: false + access_key_id: + description: The S3 access key id for the bucket. + required: false + secret_access_key: + description: The S3 secret access key for the bucket. + required: false + +jobs: + call-build-macos-legacy-check: + # Requires https://github.com/fluent/fluent-bit/pull/5247 so will not build for previous branches + name: Extract any supporting metadata + outputs: + build-type: ${{ steps.determine-build-type.outputs.BUILD_TYPE }} + runs-on: ubuntu-latest + environment: ${{ inputs.environment }} + permissions: + contents: read + steps: + - name: Checkout code + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + + - name: Determine build type + id: determine-build-type + run: | + BUILD_TYPE="legacy" + if [[ -f "conf/fluent-bit-macos.conf" ]]; then + BUILD_TYPE="modern" + fi + echo "Detected type: $BUILD_TYPE" + echo ::set-output name=BUILD_TYPE::$BUILD_TYPE + shell: bash + + call-build-macos-package: + if: needs.call-build-macos-legacy-check.outputs.build-type == 'modern' + runs-on: macos-latest + environment: ${{ inputs.environment }} + needs: + - call-build-macos-legacy-check + permissions: + contents: read + steps: + - name: Checkout repository + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + + - name: Build Fluent Bit packages + run: | + cmake -DCPACK_GENERATOR=productbuild -DFLB_NIGHTLY_BUILD=${{ inputs.unstable }} ../ + cmake --build . + cpack -G productbuild + working-directory: build + + - name: Upload build packages + uses: actions/upload-artifact@v2 + with: + name: macos-packages + path: | + build/fluent-bit-*-apple + build/fluent-bit-*-intel + if-no-files-found: error + + - name: Push packages to S3 + # Only upload for staging + if: inputs.environment == 'staging' + # Make sure not to do a --delete on sync as it will remove the other architecture + run: | + if [ -n "${AWS_S3_ENDPOINT}" ]; then + ENDPOINT="--endpoint-url ${AWS_S3_ENDPOINT}" + fi + aws --region "$AWS_REGION" s3 sync "build/fluent-bit-*-apple" "s3://${AWS_S3_BUCKET}/${DEST_DIR}" --follow-symlinks --no-progress ${ENDPOINT} + aws --region "$AWS_REGION" s3 sync "build/fluent-bit-*-intel" "s3://${AWS_S3_BUCKET}/${DEST_DIR}" --follow-symlinks --no-progress ${ENDPOINT} + env: + DEST_DIR: "${{ inputs.version }}/macos/" + AWS_REGION: "us-east-1" + AWS_ACCESS_KEY_ID: ${{ secrets.access_key_id }} + AWS_SECRET_ACCESS_KEY: ${{ secrets.secret_access_key }} + AWS_S3_BUCKET: ${{ secrets.bucket }} diff --git a/.github/workflows/call-build-windows.yaml b/.github/workflows/call-build-windows.yaml new file mode 100644 index 00000000000..8b31b5ad6d2 --- /dev/null +++ b/.github/workflows/call-build-windows.yaml @@ -0,0 +1,97 @@ +--- +name: Reusable workflow to build Windows packages optionally into S3 bucket + +on: + workflow_call: + inputs: + version: + description: The version of Fluent Bit to create. + type: string + required: true + ref: + description: The commit, tag or branch of Fluent Bit to checkout for building that creates the version above. + type: string + required: true + environment: + description: The Github environment to run this workflow on. + type: string + required: false + unstable: + description: Optionally add metadata to build to indicate an unstable build, set to the contents you want to add. + type: string + required: false + default: '' + secrets: + token: + description: The Github token or similar to authenticate with. + required: true + bucket: + description: The name of the S3 (US-East) bucket to push packages into. + required: false + access_key_id: + description: The S3 access key id for the bucket. + required: false + secret_access_key: + description: The S3 secret access key for the bucket. + required: false + +jobs: + call-build-windows-package: + runs-on: windows-latest + environment: ${{ inputs.environment }} + permissions: + contents: read + steps: + - name: Checkout repository + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + + - name: Get dependencies + run: | + Invoke-WebRequest -O winflexbison.zip $env:WINFLEXBISON + Expand-Archive winflexbison.zip -Destination C:\WinFlexBison + Copy-Item -Path C:\WinFlexBison/win_bison.exe C:\WinFlexBison/bison.exe + Copy-Item -Path C:\WinFlexBison/win_flex.exe C:\WinFlexBison/flex.exe + echo "C:\WinFlexBison" | Out-File -FilePath $env:GITHUB_PATH -Append + env: + WINFLEXBISON: https://github.com/lexxmark/winflexbison/releases/download/v2.5.22/win_flex_bison-2.5.22.zip + shell: pwsh + + - name: Set up Visual Studio shell + uses: egor-tensin/vs-shell@v2 + with: + arch: x64 + + - name: Build Fluent Bit packages + run: | + cmake -G "NMake Makefiles" -DFLB_NIGHTLY_BUILD=${{ inputs.unstable }} ../ + cmake --build . + cpack + working-directory: build + + - name: Upload build packages + uses: actions/upload-artifact@v2 + with: + name: windows-packages + path: | + build/*-bit-*.exe + build/*-bit-*.zip + if-no-files-found: error + + - name: Push packages to S3 + # Only upload for staging + if: inputs.environment == 'staging' + # Make sure not to do a --delete on sync as it will remove the other architecture + run: | + if [ -n "${AWS_S3_ENDPOINT}" ]; then + ENDPOINT="--endpoint-url ${AWS_S3_ENDPOINT}" + fi + aws --region "$AWS_REGION" s3 sync "build/*-bit-*.exe" "s3://${AWS_S3_BUCKET}/${DEST_DIR}" --follow-symlinks --no-progress ${ENDPOINT} + aws --region "$AWS_REGION" s3 sync "build/*-bit-*.zip" "s3://${AWS_S3_BUCKET}/${DEST_DIR}" --follow-symlinks --no-progress ${ENDPOINT} + env: + DEST_DIR: "${{ inputs.version }}/windows/" + AWS_REGION: "us-east-1" + AWS_ACCESS_KEY_ID: ${{ secrets.access_key_id }} + AWS_SECRET_ACCESS_KEY: ${{ secrets.secret_access_key }} + AWS_S3_BUCKET: ${{ secrets.bucket }} diff --git a/.github/workflows/cron-unstable-build.yaml b/.github/workflows/cron-unstable-build.yaml index 7ae1e70defb..26ab5fa7eeb 100644 --- a/.github/workflows/cron-unstable-build.yaml +++ b/.github/workflows/cron-unstable-build.yaml @@ -99,19 +99,20 @@ jobs: build-matrix: ${{ steps.set-matrix.outputs.build-matrix }} environment: unstable steps: - - name: Checkout repository + - name: Checkout repository, always latest for action uses: actions/checkout@v3 + # Set up the list of target to build so we can pass the JSON to the reusable job - uses: ./.github/actions/generate-package-build-matrix id: set-matrix with: - fluent-bit-version: ${{ needs.unstable-build-get-meta.outputs.branch }} + ref: ${{ needs.unstable-build-get-meta.outputs.branch }} unstable-build-packages: needs: - unstable-build-get-meta - unstable-build-generate-matrix - uses: fluent/fluent-bit/.github/workflows/call-build-packages.yaml@master + uses: fluent/fluent-bit/.github/workflows/call-build-linux-packages.yaml@master with: version: ${{ needs.unstable-build-get-meta.outputs.branch }} ref: ${{ needs.unstable-build-get-meta.outputs.branch }} @@ -124,45 +125,26 @@ jobs: unstable-build-windows-package: needs: - unstable-build-get-meta - runs-on: windows-latest - environment: unstable - steps: - - name: Checkout repository - uses: actions/checkout@v3 - with: - ref: ${{ needs.unstable-build-get-meta.outputs.branch }} - - - name: Get dependencies - run: | - Invoke-WebRequest -O winflexbison.zip $env:WINFLEXBISON - Expand-Archive winflexbison.zip -Destination C:\WinFlexBison - Copy-Item -Path C:\WinFlexBison/win_bison.exe C:\WinFlexBison/bison.exe - Copy-Item -Path C:\WinFlexBison/win_flex.exe C:\WinFlexBison/flex.exe - echo "C:\WinFlexBison" | Out-File -FilePath $env:GITHUB_PATH -Append - env: - WINFLEXBISON: https://github.com/lexxmark/winflexbison/releases/download/v2.5.22/win_flex_bison-2.5.22.zip - shell: pwsh - - - name: Set up Visual Studio shell - uses: egor-tensin/vs-shell@v2 - with: - arch: x64 - - - name: Build Fluent Bit packages - run: | - cmake -G "NMake Makefiles" ../ - cmake --build . - cpack - working-directory: build + uses: fluent/fluent-bit/.github/workflows/call-build-windows.yaml@master + with: + version: ${{ needs.unstable-build-get-meta.outputs.branch }} + ref: ${{ needs.unstable-build-get-meta.outputs.branch }} + environment: unstable + unstable: ${{ needs.unstable-build-get-meta.outputs.date }} + secrets: + token: ${{ secrets.GITHUB_TOKEN }} - - name: Upload build packages - uses: actions/upload-artifact@v2 - with: - name: windows-packages - path: | - build/fluent-bit-*.exe - build/fluent-bit-*.zip - if-no-files-found: error + unstable-build-macos-package: + needs: + - unstable-build-get-meta + uses: fluent/fluent-bit/.github/workflows/call-build-macos.yaml@master + with: + version: ${{ needs.unstable-build-get-meta.outputs.branch }} + ref: ${{ needs.unstable-build-get-meta.outputs.branch }} + environment: unstable + unstable: ${{ needs.unstable-build-get-meta.outputs.date }} + secrets: + token: ${{ secrets.GITHUB_TOKEN }} # We already detain all artefacts as build output so just capture for an unstable release unstable-release: @@ -172,6 +154,7 @@ jobs: - unstable-build-images - unstable-build-packages - unstable-build-windows-package + - unstable-build-macos-package environment: unstable permissions: contents: write diff --git a/.github/workflows/pr-windows-build.yaml b/.github/workflows/pr-windows-build.yaml index 8bb3b6aec25..3787107697e 100644 --- a/.github/workflows/pr-windows-build.yaml +++ b/.github/workflows/pr-windows-build.yaml @@ -1,4 +1,4 @@ -name: Windows CI +name: PR - Windows checks on: workflow_dispatch: @@ -17,60 +17,11 @@ on: - synchronize jobs: - windows-build-package: - runs-on: windows-latest - steps: - - name: Checkout repository - uses: actions/checkout@v3 - - - name: Get dependencies - run: | - Invoke-WebRequest -O winflexbison.zip $env:WINFLEXBISON - Expand-Archive winflexbison.zip -Destination C:\WinFlexBison - Copy-Item -Path C:\WinFlexBison/win_bison.exe C:\WinFlexBison/bison.exe - Copy-Item -Path C:\WinFlexBison/win_flex.exe C:\WinFlexBison/flex.exe - echo "C:\WinFlexBison" | Out-File -FilePath $env:GITHUB_PATH -Append - env: - WINFLEXBISON: https://github.com/lexxmark/winflexbison/releases/download/v2.5.22/win_flex_bison-2.5.22.zip - shell: pwsh - - - name: Set up Visual Studio shell - uses: egor-tensin/vs-shell@v2 - with: - arch: x64 - - - name: Build Fluent Bit packages - run: | - cmake -G "NMake Makefiles" ../ - cmake --build . - cpack - working-directory: build - - - name: Upload build packages - uses: actions/upload-artifact@v2 - with: - name: windows-packages - path: | - build/fluent-bit-*.exe - build/fluent-bit-*.zip - if-no-files-found: error - - windows-build-container: - # Only build on push as takes a long time and not needed for PRs - if: github.event_name != 'pull_request' - # Need to match the container base image - runs-on: windows-2019 - steps: - - name: Checkout repository - uses: actions/checkout@v3 - - - run: | - docker build -t fluent/fluent-bit:windows-${{ github.sha }} -f ./dockerfiles/Dockerfile.windows . - docker save -o windows-${{ github.sha }}.tar fluent/fluent-bit:windows-${{ github.sha }} - - - name: Upload containers - uses: actions/upload-artifact@v2 - with: - name: windows-containers - path: windows-${{ github.sha }}.tar - if-no-files-found: error + pr-windows-build: + uses: fluent/fluent-bit/.github/workflows/call-build-windows.yaml@master + with: + version: ${{ github.sha }} + ref: ${{ github.sha }} + environment: pr + secrets: + token: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/staging-build.yaml b/.github/workflows/staging-build.yaml index 584c47864fc..db0dede528a 100644 --- a/.github/workflows/staging-build.yaml +++ b/.github/workflows/staging-build.yaml @@ -13,7 +13,7 @@ on: required: true default: master target: - description: Only build a specific target, intended for debug/test/quick builds only. + description: Only build a specific Linux target, intended for debug/test/quick builds only. required: false default: "" @@ -121,11 +121,12 @@ jobs: - uses: ./.github/actions/generate-package-build-matrix id: set-matrix with: + ref: ${{ github.event.inputs.version || github.ref_name }} target: ${{ github.event.inputs.target || '' }} staging-build-packages: needs: [ staging-build-get-meta, staging-build-generate-matrix ] - uses: fluent/fluent-bit/.github/workflows/call-build-packages.yaml@master + uses: fluent/fluent-bit/.github/workflows/call-build-linux-packages.yaml@master with: version: ${{ needs.staging-build-get-meta.outputs.version }} ref: ${{ github.event.inputs.version || github.ref_name }} @@ -138,3 +139,31 @@ jobs: secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }} gpg_private_key_passphrase: ${{ secrets.GPG_PRIVATE_KEY_PASSPHRASE }} + + staging-build-windows-packages: + needs: + - staging-build-get-meta + uses: fluent/fluent-bit/.github/workflows/call-build-windows.yaml@master + with: + version: ${{ needs.staging-build-get-meta.outputs.version }} + ref: ${{ github.event.inputs.version || github.ref_name }} + environment: staging + secrets: + token: ${{ secrets.GITHUB_TOKEN }} + bucket: ${{ secrets.AWS_S3_BUCKET_STAGING }} + access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} + secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + + staging-build-macos-packages: + needs: + - staging-build-get-meta + uses: fluent/fluent-bit/.github/workflows/call-build-macos.yaml@master + with: + version: ${{ needs.staging-build-get-meta.outputs.version }} + ref: ${{ github.event.inputs.version || github.ref_name }} + environment: staging + secrets: + token: ${{ secrets.GITHUB_TOKEN }} + bucket: ${{ secrets.AWS_S3_BUCKET_STAGING }} + access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} + secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}