From 680aa8e480a9d46812735347f44f7c35226a7155 Mon Sep 17 00:00:00 2001 From: David Nestorovic Date: Wed, 20 Nov 2024 09:33:44 +0100 Subject: [PATCH] Use Artifacts to Collect Unsupported Library Versions from Parallel Jobs (#572) * Use artifacts to collect results from failed jobs * Check existing issue url against null --- .../workflows/check-new-library-versions.yml | 43 +++++++++++-------- .../org.graalvm.internal.tck-harness.gradle | 2 +- .../tasks/GroupUnsupportedLibraries.groovy | 17 +++----- 3 files changed, 33 insertions(+), 29 deletions(-) diff --git a/.github/workflows/check-new-library-versions.yml b/.github/workflows/check-new-library-versions.yml index dafdff66..695d011c 100644 --- a/.github/workflows/check-new-library-versions.yml +++ b/.github/workflows/check-new-library-versions.yml @@ -27,7 +27,6 @@ jobs: GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} outputs: matrix: ${{ steps.set-matrix.outputs.matrix }} - issue: ${{ steps.set-issue.outputs.issue }} steps: - name: "☁️ Checkout repository" uses: actions/checkout@v4 @@ -47,14 +46,6 @@ jobs: git config --local user.name "Github Actions" git switch -C check-new-library-versions/$(date '+%Y-%m-%d') git push origin check-new-library-versions/$(date '+%Y-%m-%d') - - name: "🔨 Create issue" - id: set-issue - run: | - git config --local user.email "actions@github.com" - git config --local user.name "Github Actions" - - issue_url=$(gh issue create --title "List unsupported library versions" --body "This issue lists unsupported versions of the existing libraries in the repo") - echo "::set-output name=issue::$issue_url" test-all-metadata: name: "🧪 ${{ matrix.coordinates }} (GraalVM for JDK ${{ matrix.version }} @ ${{ matrix.os }})" @@ -118,9 +109,18 @@ jobs: - name: "❗ New library is not supported" if: failure() run: | - git config --local user.email "actions@github.com" - git config --local user.name "Github Actions" - gh issue comment "${{ needs.get-all-libraries.outputs.issue }}" --body "${{ matrix.coordinates }}" + LIB=$(echo "${{ matrix.coordinates }}" | sed 's/:/_/g') + touch $LIB + echo "UNSUPPORTED_LIB=$LIB" >> $GITHUB_ENV + - name: "Upload artifacts" + if: failure() + id: upload + continue-on-error: true + uses: actions/upload-artifact@v4 + with: + name: ${{ env.UNSUPPORTED_LIB }} + path: ${{ env.UNSUPPORTED_LIB }} + retention-days: 1 process-results: name: "🧪 Process results" @@ -147,13 +147,22 @@ jobs: git fetch origin check-new-library-versions/$(date '+%Y-%m-%d') git checkout check-new-library-versions/$(date '+%Y-%m-%d') gh pr create --title "Update supported library versions" --body "This pull request updates supported versions of the existing libraries in the repo" - - name: "✏️ Edit issue for unsupported versions" + - name: "Download artifacts for unsupported versions" + uses: actions/download-artifact@v4 + with: + path: ./unsupported + - name: "✏️ Issue for unsupported versions" run: | git config --local user.email "actions@github.com" git config --local user.name "Github Actions" - ALL_COMMENTS=$(gh issue view "${{ needs.get-all-libraries.outputs.issue }}" --comments) - FORMATTED_BODY=$(./gradlew -q extractLibrariesGroupsFromGithubComments --comments="$ALL_COMMENTS") - gh issue create --title "List unsupported libraries versions" --body "$FORMATTED_BODY" + LABEL="library-update" + ALL_LIBRARIES=$(ls unsupported) + FORMATTED_BODY=$(./gradlew -q groupLibrariesByName --libraries="$ALL_LIBRARIES") - gh issue close "${{ needs.get-all-libraries.outputs.issue }}" + EXISTING_ISSUE=$(gh issue list --label "$LABEL" --state open --limit 1 --json url | jq -r '.[0].url') + if [ $EXISTING_ISSUE != "null" ]; then + gh issue edit $EXISTING_ISSUE --body "$FORMATTED_BODY" + else + gh issue create --title "List unsupported libraries versions" --body "$FORMATTED_BODY" --label $LABEL + fi diff --git a/tests/tck-build-logic/src/main/groovy/org.graalvm.internal.tck-harness.gradle b/tests/tck-build-logic/src/main/groovy/org.graalvm.internal.tck-harness.gradle index c529e8f2..62b27417 100644 --- a/tests/tck-build-logic/src/main/groovy/org.graalvm.internal.tck-harness.gradle +++ b/tests/tck-build-logic/src/main/groovy/org.graalvm.internal.tck-harness.gradle @@ -171,7 +171,7 @@ tasks.register("fetchExistingLibrariesWithNewerVersions", FetchExistingLibraries task.setAllLibraryCoordinates(matchingCoordinates) } -tasks.register("extractLibrariesGroupsFromGithubComments", GroupUnsupportedLibraries.class) { task -> +tasks.register("groupLibrariesByName", GroupUnsupportedLibraries.class) { task -> task.setGroup(METADATA_GROUP) task.setDescription("Extracts groups of libraries from github comments provided in a form of string.") } diff --git a/tests/tck-build-logic/src/main/groovy/org/graalvm/internal/tck/harness/tasks/GroupUnsupportedLibraries.groovy b/tests/tck-build-logic/src/main/groovy/org/graalvm/internal/tck/harness/tasks/GroupUnsupportedLibraries.groovy index aaa4974f..2ce8217a 100644 --- a/tests/tck-build-logic/src/main/groovy/org/graalvm/internal/tck/harness/tasks/GroupUnsupportedLibraries.groovy +++ b/tests/tck-build-logic/src/main/groovy/org/graalvm/internal/tck/harness/tasks/GroupUnsupportedLibraries.groovy @@ -7,24 +7,19 @@ import org.gradle.api.tasks.TaskAction import org.gradle.api.tasks.options.Option import org.gradle.util.internal.VersionNumber -import java.util.regex.Matcher -import java.util.regex.Pattern - abstract class GroupUnsupportedLibraries extends DefaultTask { @Input - @Option(option = "comments", description = "Provides github comments for library grouping as string.") - abstract Property getGithubComments() + @Option(option = "libraries", description = "Provides list of libraries that should be grouped.") + abstract Property getLibraries() @TaskAction void action() { - def pattern = Pattern.compile("--[\n ](.*?)[\n ]--") - def matcher = pattern.matcher(getGithubComments().get()) + def libraries = getLibraries().get().split("\n") - def libraryGroups = new HashMap>() - while (matcher.find()) { - def coordinates = matcher.group(1) - def coordinatesPart = coordinates.split(":") + Map> libraryGroups = new HashMap>() + for (def library : libraries) { + def coordinatesPart = library.split("_") def artifactKey = coordinatesPart[0] + ":" + coordinatesPart[1] def version = coordinatesPart[2]