Skip to content

Commit

Permalink
refactor: simplify the whole CI (reducing the number of executable wo…
Browse files Browse the repository at this point in the history
…rkflows) and rework engine to avoid multiple weird types

Signed-off-by: kilianpaquier <kilian@kilianpaquier.com>
  • Loading branch information
kilianpaquier committed Dec 11, 2024
1 parent c9c81e4 commit c40c1e3
Show file tree
Hide file tree
Showing 732 changed files with 8,867 additions and 24,473 deletions.
101 changes: 0 additions & 101 deletions .github/actions/version/action.yml

This file was deleted.

2 changes: 1 addition & 1 deletion .github/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@

version: 2
updates:

- package-ecosystem: github-actions
directory: /
schedule:
Expand All @@ -25,6 +24,7 @@ updates:
prefix: ci
reviewers:
- kilianpaquier

- package-ecosystem: gomod
directory: /
schedule:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,7 @@
# Code generated by craft; DO NOT EDIT.

name: Golang
run-name: Golang

<<- $gocli := and (gt (len .Clis) 0) (not .NoGoreleaser) >>
<<- $docker := and .Docker (gt .Binaries 0) >>
name: CICD
run-name: CICD

on:
pull_request:
Expand All @@ -22,37 +19,75 @@ on:
- development
- next
- staging
<<- if not .IsAutoRelease >>
- main
- master
- v[0-9]+.[0-9]+.x
- v[0-9]+.x
<<- end >>
workflow_call:
- v[0-9]+.[0-9]+.x
workflow_dispatch:
inputs:
<<- if $gocli >>
build:
description: Whether to run build job or not
required: false
dry_run:
description: Whether to run all impacting jobs in dry run or preview mode.
type: boolean
<<- end >>
version:
description: Build version to use in build metadata
required: true
type: string
workflow_dispatch:

jobs:
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:
run-workflow:
name: Run Workflow
runs-on: ubuntu-latest
if: ${{ github.event_name != 'pull_request' || (github.event_name == 'pull_request' && github.event.pull_request.draft == false && github.ref_protected != true) }}
outputs:
skip: ${{ steps.skip.outputs.skip }}
steps:
- id: skip
run: echo "Running workflow" && echo "skip=false" >> $GITHUB_OUTPUT
run: echo "Running workflow"

version:
name: Version
runs-on: ubuntu-latest
needs: run-workflow
if: ${{ github.event_name != 'pull_request' }}
outputs:
version: ${{ steps.version.outputs.version }}
permissions:
contents: write
issues: write
pull-requests: write
id-token: none
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
# https://github.com/marketplace/actions/action-for-semantic-release
- id: semrel_version
uses: cycjimmy/semantic-release-action@v4
with:
dry_run: true
semantic_version: 24
extra_plugins: |
@semantic-release/changelog
@semantic-release/commit-analyzer
@semantic-release/exec
@semantic-release/git
@semantic-release/github
@semantic-release/release-notes-generator
conventional-changelog-conventionalcommits
semantic-release-license
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- id: version
run: |
if [ "${SEMREL_INFO_NEXT_VERSION}" != "" ]; then
echo "version=v${SEMREL_INFO_NEXT_VERSION#v}" >> $GITHUB_OUTPUT
else
DESCRIBE=$(git describe --tags || echo "v0.0.0")
echo "version=v${DESCRIBE#v}" >> $GITHUB_OUTPUT
fi
env:
SEMREL_INFO_NEXT_VERSION: ${{ steps.semrel_version.outputs.new_release_version }}
- run: echo ${VERSION}
env:
VERSION: ${{ steps.version.outputs.version }}

go-vulncheck:
name: Go Vulnerability Check
Expand Down Expand Up @@ -83,13 +118,6 @@ jobs:
- uses: golangci/golangci-lint-action@v6
with:
args: --config .golangci.yml --timeout 240s --fast --sort-results --out-format checkstyle:reports/go-ci-lint.checkstyle.xml,colored-line-number
<<- if has "sonar" .CI.Options >>
- uses: actions/upload-artifact@v4
with:
name: lint
path: reports
retention-days: 1
<<- end >>

go-test:
name: Go Test
Expand All @@ -102,8 +130,6 @@ jobs:
- macos-latest
- ubuntu-latest
- windows-latest
env:
OS: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-go@v5
Expand All @@ -113,9 +139,7 @@ jobs:
token: ${{ secrets.GITHUB_TOKEN }}
- run: mkdir -p reports/
- run: go test ./... -coverpkg="./..." -covermode="count" -coverprofile="reports/go-coverage.native.out" -timeout=15s
<<- if has "codecov" .CI.Options >>
- if: ${{ ! startsWith(github.head_ref, 'dependabot') && ! startsWith(github.head_ref, 'renovate') }}
uses: codecov/codecov-action@v4
- uses: codecov/codecov-action@v4
with:
codecov_yml_path: .codecov.yml
disable_search: true
Expand All @@ -125,23 +149,14 @@ jobs:
flags: ${{ matrix.os }}
slug: ${{ github.repository }}
token: ${{ secrets.CODECOV_TOKEN }}
<<- end >>
<<- if has "sonar" .CI.Options >>
- uses: actions/upload-artifact@v4
with:
name: coverage
path: reports
retention-days: 1
<<- end >>

<<- if $gocli >>
env:
OS: ${{ matrix.os }}

go-build:
name: Go Build
runs-on: ubuntu-latest
if: ${{ inputs.build }}
needs:
- run-workflow
- version
- go-test
steps:
- uses: actions/checkout@v4
Expand All @@ -151,11 +166,12 @@ jobs:
go-version-file: go.mod
token: ${{ secrets.GITHUB_TOKEN }}
# https://github.com/marketplace/actions/goreleaser-action
- uses: goreleaser/goreleaser-action@v6
- if: ${{ hashFiles('.goreleaser.yml') != '' }}
uses: goreleaser/goreleaser-action@v6
with:
args: release --clean --config .goreleaser.yml --skip=validate --skip=announce --skip=publish --snapshot
env:
VERSION: ${{ inputs.version }}
VERSION: ${{ needs.version.outputs.version }}
- uses: actions/upload-artifact@v4
with:
name: build
Expand All @@ -166,47 +182,43 @@ jobs:
!dist/*.yaml
!dist/*/
retention-days: 1
<<- end >>

<<- if has "sonar" .CI.Options >>

sonar-analysis:
name: Sonar Analysis
release:
name: Release
runs-on: ubuntu-latest
if: ${{ github.event_name == 'push' && github.ref_protected == 'true' }}
environment:
name: release
url: ${{ github.server_url }}/${{ github.repository_owner }}/${{ github.repository }}/releases/tag/${{ steps.semrel_version.outputs.new_release_version }}
needs:
- run-workflow
- go-lint
- go-test
env:
SONAR_USER_HOME: .sonar
- go-build
permissions:
contents: write
issues: write
pull-requests: write
id-token: none
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: actions/download-artifact@v4
with:
merge-multiple: true
path: reports
- uses: actions/cache@v4
with:
path: ${{ env.SONAR_USER_HOME }}
key: sonar-cache
- uses: sonarsource/sonarcloud-github-action@master
if: ${{ github.event_name == 'pull_request' }}
env:
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
name: build
path: dist
# https://github.com/marketplace/actions/action-for-semantic-release
- id: semrel_version
uses: cycjimmy/semantic-release-action@v4
with:
args: |
-Dproject.settings=sonar.properties
-Dsonar.pullrequest.base=${{ github.base_ref }}
-Dsonar.pullrequest.branch=${{ github.head_ref }}
-Dsonar.pullrequest.key=${{ github.event.issue.number }}
- uses: sonarsource/sonarcloud-github-action@master
if: ${{ github.event_name == 'push' }}
dry_run: ${{ inputs.dry_run == 'true' }}
semantic_version: 24
extra_plugins: |
@semantic-release/changelog
@semantic-release/commit-analyzer
@semantic-release/exec
@semantic-release/git
@semantic-release/github
@semantic-release/release-notes-generator
conventional-changelog-conventionalcommits
semantic-release-license
env:
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
with:
args: |
-Dproject.settings=sonar.properties
-Dsonar.branch.name=${{ github.ref_name }}
<<- end >>
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
2 changes: 1 addition & 1 deletion .github/workflows/codeql.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
# We have attempted to detect the languages in your repository. Please check
# the `language` matrix defined below to confirm you have the correct set of
# supported CodeQL languages.
#

name: CodeQL
run-name: CodeQL

Expand Down
1 change: 0 additions & 1 deletion .github/workflows/dependencies.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ on:
- v[0-9]+.x

jobs:

go-dependency-submission:
name: Go Dependency Submission
runs-on: ubuntu-latest
Expand Down
Loading

0 comments on commit c40c1e3

Please sign in to comment.