diff --git a/.github/workflows/centreon-collect.yml b/.github/workflows/centreon-collect.yml index 592f34c29c..04545f502a 100644 --- a/.github/workflows/centreon-collect.yml +++ b/.github/workflows/centreon-collect.yml @@ -54,9 +54,10 @@ jobs: unit-test: needs: [get-environment] - if: ${{ ! contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' runs-on: [self-hosted, collect] - strategy: fail-fast: false matrix: @@ -84,7 +85,9 @@ jobs: package: needs: [get-environment] - if: ${{ ! contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' uses: ./.github/workflows/package-collect.yml with: major_version: ${{ needs.get-environment.outputs.major_version }} @@ -117,7 +120,12 @@ jobs: token_download_centreon_com: ${{ secrets.TOKEN_DOWNLOAD_CENTREON_COM }} deliver-rpm: - if: ${{ contains(fromJson('["testing", "stable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') needs: [get-environment, package] runs-on: [self-hosted, common] strategy: @@ -147,7 +155,12 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} deliver-deb: - if: ${{ contains(fromJson('["testing", "stable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') needs: [get-environment, package] runs-on: [self-hosted, common] strategy: @@ -175,8 +188,13 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} promote: - needs: [get-environment] - if: ${{ contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch' }} + needs: [get-environment, deliver-rpm, deliver-deb] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + (contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch') && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') runs-on: [self-hosted, common] strategy: matrix: @@ -197,3 +215,12 @@ jobs: github_ref_name: ${{ github.ref_name }} release_type: ${{ needs.get-environment.outputs.release_type }} is_cloud: ${{ needs.get-environment.outputs.is_cloud }} + + set-skip-label: + needs: [get-environment, deliver-rpm, deliver-deb, promote] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') + uses: ./.github/workflows/set-pull-request-skip-label.yml diff --git a/.github/workflows/docker-builder.yml b/.github/workflows/docker-builder.yml index 9fc2bc52d9..2497a780f3 100644 --- a/.github/workflows/docker-builder.yml +++ b/.github/workflows/docker-builder.yml @@ -22,8 +22,11 @@ jobs: with: version_file: CMakeLists.txt - create-and-push-docker: + dockerize: needs: [get-environment] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' strategy: fail-fast: false @@ -92,3 +95,12 @@ jobs: pull: true push: true tags: ${{ vars.DOCKER_INTERNAL_REGISTRY_URL }}/${{ matrix.image }}:${{ matrix.tag }} + + set-skip-label: + needs: [get-environment, dockerize] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') + uses: ./.github/workflows/set-pull-request-skip-label.yml diff --git a/.github/workflows/get-environment.yml b/.github/workflows/get-environment.yml index d88b412833..048aac785c 100644 --- a/.github/workflows/get-environment.yml +++ b/.github/workflows/get-environment.yml @@ -42,6 +42,9 @@ on: gorgone_docker_version: description: "md5 of gorgone dockerfile" value: ${{ jobs.get-environment.outputs.gorgone_docker_version }} + skip_workflow: + description: "if the current workflow should be skipped" + value: ${{ jobs.get-environment.outputs.skip_workflow }} jobs: get-environment: @@ -59,10 +62,37 @@ jobs: img_version: ${{ steps.get_docker_images_version.outputs.img_version }} test_img_version: ${{ steps.get_docker_images_version.outputs.test_img_version }} gorgone_docker_version: ${{ steps.get_docker_images_version.outputs.gorgone_docker_version }} + skip_workflow: ${{ steps.skip_workflow.outputs.result }} steps: + - name: Check if PR has skip label + id: has_skip_label + uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1 + with: + script: | + let hasSkipLabel = false; + if (${{ contains(fromJSON('["pull_request", "pull_request_target"]') , github.event_name) }} === true) { + try { + const labels = await github.rest.issues.listLabelsOnIssue({ + owner: context.repo.owner, + repo: context.repo.repo, + issue_number: context.issue.number + }); + labels.data.forEach(({ name }) => { + if (name === '${{ format('skip-workflow-{0}', github.workflow) }}') { + hasSkipLabel = true; + } + }); + } catch (e) { + core.warning(`failed to list labels: ${e}`); + } + } + return hasSkipLabel; + - name: Checkout sources (current branch) uses: actions/checkout@d632683dd7b4114ad314bca15554477dd762a938 # v4.2.0 + with: + fetch-depth: ${{ steps.has_skip_label.outputs.result == 'true' && 100 || 1 }} # get latest major version to detect cloud / on-prem versions - name: Checkout sources (develop branch) @@ -72,6 +102,97 @@ jobs: path: centreon-develop sparse-checkout: .version + - if: ${{ steps.has_skip_label.outputs.result == 'true' }} + name: Get workflow triggered paths + id: get_workflow_triggered_paths + uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1 + with: + script: | + const fs = require('fs'); + + let paths = []; + + const workflowFilePath = '${{ github.workflow_ref }}'.replace('${{ github.repository }}/', '').split('@').shift(); + + if (fs.existsSync(workflowFilePath)) { + const workflowFileContent = fs.readFileSync(workflowFilePath, 'utf8'); + const workflowFileContentLines = workflowFileContent.split('\n'); + + let hasReadOn = false; + let hasReadPullRequest = false; + let hasReadPaths = false; + for (const line of workflowFileContentLines) { + if (line.match(/^on:\s*$/)) { + hasReadOn = true; + continue; + } + if (line.match(/^\s{2}pull_request(_target)?:\s*$/)) { + hasReadPullRequest = true; + continue; + } + if (line.match(/^\s{4}paths:\s*$/)) { + hasReadPaths = true; + continue; + } + + if (hasReadOn && hasReadPullRequest && hasReadPaths) { + const matches = line.match(/^\s{6}-\s['"](.+)['"]\s*$/); + if (matches) { + paths.push(matches[1].trim()); + } else { + break; + } + } + } + } + + if (paths.length === 0) { + paths = ['**']; + } + + console.log(paths); + + return paths; + + - if: ${{ steps.has_skip_label.outputs.result == 'true' }} + name: Get push changes + id: get_push_changes + uses: tj-actions/changed-files@bab30c2299617f6615ec02a68b9a40d10bd21366 # v45.0.5 + with: + since_last_remote_commit: true + json: true + escape_json: false + files: ${{ join(fromJSON(steps.get_workflow_triggered_paths.outputs.result), ';') }} + files_separator: ';' + + - name: Check if current workflow should be skipped + id: skip_workflow + uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1 + with: + script: | + if (${{ steps.has_skip_label.outputs.result }} === false) { + return false; + } + + const label = '${{ format('skip-workflow-{0}', github.workflow) }}'; + if ('${{ steps.get_push_changes.outputs.any_changed }}' === 'true') { + try { + await github.rest.issues.removeLabel({ + name: label, + owner: context.repo.owner, + repo: context.repo.repo, + issue_number: context.issue.number + }); + core.notice(`label ${label} removed because changes were detected on last push.`); + } catch (e) { + core.warning(`failed to remove label ${label}: ${e}`); + } + + return false; + } + + return true; + - name: Store latest major version id: latest_major_version run: | @@ -257,6 +378,7 @@ jobs: ['img_version', '${{ steps.get_docker_images_version.outputs.img_version }}'], ['test_img_version', '${{ steps.get_docker_images_version.outputs.test_img_version }}'], ['gorgone_docker_version', '${{ steps.get_docker_images_version.outputs.gorgone_docker_version }}'], + ['skip_workflow', '${{ steps.skip_workflow.outputs.result }}'], ]; outputTable.push(['target_stability', '${{ steps.get_stability.outputs.target_stability || 'not defined because current run is not triggered by pull request event' }}']); diff --git a/.github/workflows/gorgone.yml b/.github/workflows/gorgone.yml index 1f3874fcac..719ffa1f64 100644 --- a/.github/workflows/gorgone.yml +++ b/.github/workflows/gorgone.yml @@ -57,7 +57,9 @@ jobs: package: needs: [get-environment] - if: ${{ needs.get-environment.outputs.stability != 'stable' }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' strategy: fail-fast: false @@ -95,7 +97,12 @@ jobs: deliver-sources: runs-on: [self-hosted, common] needs: [get-environment, package] - if: ${{ contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch' }} + if: | + github.event_name != 'workflow_dispatch' && + needs.get-environment.outputs.stability == 'stable' && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') steps: - name: Checkout sources @@ -114,7 +121,12 @@ jobs: deliver-rpm: runs-on: [self-hosted, common] needs: [get-environment, package] - if: ${{ contains(fromJson('["testing", "unstable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["unstable", "testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') strategy: matrix: @@ -139,7 +151,12 @@ jobs: deliver-deb: runs-on: [self-hosted, common] needs: [get-environment, package] - if: ${{ contains(fromJson('["testing", "unstable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["unstable", "testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') strategy: matrix: @@ -162,8 +179,13 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} promote: - needs: [get-environment] - if: ${{ contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch' }} + needs: [get-environment, deliver-rpm, deliver-deb] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + (contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch') && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') runs-on: [self-hosted, common] strategy: matrix: @@ -184,3 +206,12 @@ jobs: github_ref_name: ${{ github.ref_name }} release_type: ${{ needs.get-environment.outputs.release_type }} is_cloud: ${{ needs.get-environment.outputs.is_cloud }} + + set-skip-label: + needs: [get-environment, deliver-rpm, deliver-deb, promote] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') + uses: ./.github/workflows/set-pull-request-skip-label.yml diff --git a/.github/workflows/libzmq.yml b/.github/workflows/libzmq.yml index a72942def0..fd327dd496 100644 --- a/.github/workflows/libzmq.yml +++ b/.github/workflows/libzmq.yml @@ -24,6 +24,9 @@ jobs: package-rpm: needs: [get-environment] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' strategy: fail-fast: false @@ -78,6 +81,9 @@ jobs: package-deb: needs: [get-environment] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' strategy: fail-fast: false @@ -129,8 +135,13 @@ jobs: key: ${{ github.run_id }}-${{ github.sha }}-deb-libzmq-${{ matrix.distrib }}-${{ matrix.arch }} deliver-rpm: - if: ${{ contains(fromJson('["testing", "unstable"]'), needs.get-environment.outputs.stability) }} needs: [get-environment, package-rpm] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["unstable", "testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') runs-on: [self-hosted, common] strategy: matrix: @@ -159,8 +170,13 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} deliver-deb: - if: ${{ contains(fromJson('["testing", "unstable"]'), needs.get-environment.outputs.stability) }} needs: [get-environment, package-deb] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["unstable", "testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') runs-on: [self-hosted, common] strategy: matrix: @@ -187,8 +203,13 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} promote: - needs: [get-environment] - if: ${{ contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch' }} + needs: [get-environment, deliver-rpm, deliver-deb] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + (contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch') && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') runs-on: [self-hosted, common] strategy: matrix: @@ -209,3 +230,12 @@ jobs: github_ref_name: ${{ github.ref_name }} release_type: ${{ needs.get-environment.outputs.release_type }} is_cloud: ${{ needs.get-environment.outputs.is_cloud }} + + set-skip-label: + needs: [get-environment, deliver-rpm, deliver-deb, promote] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') + uses: ./.github/workflows/set-pull-request-skip-label.yml diff --git a/.github/workflows/lua-curl.yml b/.github/workflows/lua-curl.yml index 96f48d668f..edad3b7f8d 100644 --- a/.github/workflows/lua-curl.yml +++ b/.github/workflows/lua-curl.yml @@ -29,7 +29,9 @@ jobs: package: needs: [get-environment] - if: ${{ needs.get-environment.outputs.stability != 'stable' }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + needs.get-environment.outputs.stability != 'stable' strategy: fail-fast: false @@ -152,7 +154,12 @@ jobs: stability: ${{ needs.get-environment.outputs.stability }} deliver-rpm: - if: ${{ contains(fromJson('["testing", "unstable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["unstable", "testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') needs: [get-environment, package] runs-on: ubuntu-24.04 strategy: @@ -181,7 +188,12 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} deliver-deb: - if: ${{ contains(fromJson('["testing", "unstable"]'), needs.get-environment.outputs.stability) }} + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + contains(fromJson('["unstable", "testing"]'), needs.get-environment.outputs.stability) && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') needs: [get-environment, package] runs-on: ubuntu-24.04 strategy: @@ -208,8 +220,13 @@ jobs: is_cloud: ${{ needs.get-environment.outputs.is_cloud }} promote: - needs: [get-environment] - if: ${{ contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch' }} + needs: [get-environment, deliver-rpm, deliver-deb] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + (contains(fromJson('["stable"]'), needs.get-environment.outputs.stability) && github.event_name != 'workflow_dispatch') && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') runs-on: [self-hosted, common] strategy: matrix: @@ -230,3 +247,12 @@ jobs: github_ref_name: ${{ github.ref_name }} release_type: ${{ needs.get-environment.outputs.release_type }} is_cloud: ${{ needs.get-environment.outputs.is_cloud }} + + set-skip-label: + needs: [get-environment, deliver-rpm, deliver-deb, promote] + if: | + needs.get-environment.outputs.skip_workflow == 'false' && + ! cancelled() && + ! contains(needs.*.result, 'failure') && + ! contains(needs.*.result, 'cancelled') + uses: ./.github/workflows/set-pull-request-skip-label.yml diff --git a/.github/workflows/set-pull-request-skip-label.yml b/.github/workflows/set-pull-request-skip-label.yml new file mode 100644 index 0000000000..ffab0b955e --- /dev/null +++ b/.github/workflows/set-pull-request-skip-label.yml @@ -0,0 +1,26 @@ +name: set-pull-request-skip-label + +on: + workflow_call: + +jobs: + set-pull-request-skip-label: + if: ${{ success() && contains(fromJSON('["pull_request", "pull_request_target"]') , github.event_name) }} + runs-on: ubuntu-24.04 + + steps: + - name: Set PR skip label + uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1 + with: + script: | + const label = '${{ format('skip-workflow-{0}', github.workflow) }}'; + try { + await github.rest.issues.addLabels({ + owner: context.repo.owner, + repo: context.repo.repo, + issue_number: context.issue.number, + labels: [label] + }); + } catch (e) { + core.warning(`failed to add label ${label}: ${e}`); + }