From 4022e4a54812855bfacc006d333dca5280f7a239 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Nicoll?= Date: Thu, 10 Oct 2024 14:04:59 +0200 Subject: [PATCH] Add CI build on several Spring Framework generations This commit adds a GHA workflow that builds the project against a list of configurable Spring Framework versions. The build action has been updated to accept an additional input that tunes the Spring Framework version the build is using As a result, the default Spring Framework version of the project is now configured in gradle.properties. Closes gh-1810 --- .github/actions/build/action.yml | 5 +++- .github/workflows/ci.yml | 44 ++++++++++++++++++++++++++++++++ build.gradle | 2 +- gradle.properties | 2 ++ 4 files changed, 51 insertions(+), 2 deletions(-) create mode 100644 .github/workflows/ci.yml diff --git a/.github/actions/build/action.yml b/.github/actions/build/action.yml index bc52f1a1a..b0c619cc4 100644 --- a/.github/actions/build/action.yml +++ b/.github/actions/build/action.yml @@ -24,6 +24,9 @@ inputs: description: 'Whether to publish artifacts ready for deployment to Artifactory' required: false default: 'false' + spring-framework-version: + description: 'Spring Framework version to use' + required: false outputs: build-scan-url: description: 'URL, if any, of the build scan produced by the build' @@ -46,7 +49,7 @@ runs: id: build if: ${{ inputs.publish == 'false' }} shell: bash - run: ./gradlew check + run: ./gradlew check ${{ inputs.spring-framework-version != '' && format('-PspringFrameworkVersion={0}', inputs.spring-framework-version) || '' }} - name: Publish id: publish if: ${{ inputs.publish == 'true' }} diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 000000000..0cc67fdbc --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,44 @@ +name: CI +on: + push: + branches: + - main +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} +jobs: + ci: + name: 'Java ${{ matrix.java.version}} | Spring Framework ${{ matrix.spring.generation}}' + if: ${{ github.repository == 'spring-projects/spring-webflow' }} + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + java: + - version: 17 + toolchain: false + spring: + - generation: 6.1.x + version: 6.0.13 + - generation: 6.2.x + version: 6.2.0-SNAPSHOT + steps: + - name: Check Out Code + uses: actions/checkout@v4 + - name: Build + id: build + uses: ./.github/actions/build + with: + develocity-access-key: ${{ secrets.DEVELOCITY_ACCESS_KEY }} + java-early-access: ${{ matrix.java.early-access || 'false' }} + java-distribution: ${{ matrix.java.distribution }} + java-toolchain: ${{ matrix.java.toolchain }} + java-version: ${{ matrix.java.version }} + spring-framework-version: ${{ matrix.spring.version }} + - name: Send Notification + if: always() + uses: ./.github/actions/send-notification + with: + build-scan-url: ${{ steps.build.outputs.build-scan-url }} + run-name: ${{ format('{0} | Java {1} | Spring Framework {2}', github.ref_name, matrix.java.version,matrix.spring.version) }} + status: ${{ job.status }} + webhook-url: ${{ secrets.GOOGLE_CHAT_WEBHOOK_URL }} diff --git a/build.gradle b/build.gradle index 57d06e27e..d95c90e0f 100644 --- a/build.gradle +++ b/build.gradle @@ -21,7 +21,7 @@ allprojects { dependencyManagement { imports { - mavenBom "org.springframework:spring-framework-bom:6.0.7" + mavenBom "org.springframework:spring-framework-bom:${springFrameworkVersion}" mavenBom "org.springframework.security:spring-security-bom:6.0.2" mavenBom "org.junit:junit-bom:5.7.2" } diff --git a/gradle.properties b/gradle.properties index d3b3952ea..a14e5c1b0 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,2 +1,4 @@ version=3.0.1-SNAPSHOT org.gradle.caching=true + +springFrameworkVersion=6.0.7