Skip to content

Commit

Permalink
fix: faster integration testing CI matrix creation (#910)
Browse files Browse the repository at this point in the history
Uses `grep` rather than `go test -list`, which has to download Go deps
and compile the source.

Also adds a post step to Build Cache that downloads all Maven and Go
dependencies.

I think this will address the CI issue in #911
  • Loading branch information
alecthomas authored Feb 9, 2024
1 parent c57a6fe commit e02ead5
Show file tree
Hide file tree
Showing 10 changed files with 51 additions and 22 deletions.
3 changes: 3 additions & 0 deletions .github/actions/build-cache/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,7 @@ runs:
with:
path: ~/.m2/repository
key: ${{ runner.os }}-{{ hashFiles('**/pom.xml') }}-maven
- name: Populate Cache
id: populate-cache
uses: ./.github/actions/populate-cache

6 changes: 6 additions & 0 deletions .github/actions/populate-cache/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
name: Populate Cache
description: "Populates the cache with the necessary dependencies"
runs:
using: node20
main: "main.js"
post: "post.js"
Empty file.
12 changes: 12 additions & 0 deletions .github/actions/populate-cache/post.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
const { execSync } = require("child_process");

try {
console.log("Resolving Maven dependencies");
execSync("mvn dependency:resolve --batch-mode", { stdio: "inherit" });
console.log("Resolving Go dependencies");
execSync("go mod download -x", { stdio: "inherit" });
console.log("Dependency resolution successful");
} catch (error) {
console.error("Dependency resolution failed:", error.message);
process.exit(1);
}
4 changes: 2 additions & 2 deletions .github/workflows/autofmt.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,12 @@ jobs:
with:
ref: ${{ github.head_ref }}
- name: Init Hermit
run: ./bin/hermit env -r >> $GITHUB_ENV
run: ./bin/hermit env -r >> "$GITHUB_ENV"
- name: Auto format
run: autofmt
- name: Check for modified files
id: git-check
run: echo "modified=$(if git diff-index --quiet HEAD --; then echo "false"; else echo "true"; fi)" >> $GITHUB_OUTPUT
run: echo "modified=$(if git diff-index --quiet HEAD --; then echo "false"; else echo "true"; fi)" >> "$GITHUB_OUTPUT"
- name: Switch to main
if: github.ref == 'refs/heads/main'
run: |
Expand Down
12 changes: 11 additions & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,12 @@ jobs:
uses: actions/checkout@v4
- name: Init Hermit
uses: cashapp/activate-hermit@v1
- name: Build Cache
uses: ./.github/actions/build-cache
- name: Test
run: mvn test
run: |
find ~/.m2 -ls
mvn test --batch-mode
test:
name: Test Go
runs-on: ubuntu-latest
Expand All @@ -40,6 +44,8 @@ jobs:
uses: actions/checkout@v4
- name: Init Hermit
uses: cashapp/activate-hermit@v1
- name: Build Cache
uses: ./.github/actions/build-cache
- name: Docker Compose
run: docker compose up -d --wait
- name: Initialise database
Expand All @@ -60,6 +66,8 @@ jobs:
run: golangci-lint run
- name: go-check-sumtype
run: go-check-sumtype ./...
- name: actionlint
run: actionlint --oneline
# Too annoying to disable individual warnings
# - name: staticcheck
# run: staticcheck ./...
Expand Down Expand Up @@ -94,6 +102,8 @@ jobs:
uses: actions/checkout@v4
- name: Init Hermit
uses: cashapp/activate-hermit@v1
- name: Build Cache
uses: ./.github/actions/build-cache
- name: Console NPM Install
working-directory: frontend
run: npm install
Expand Down
16 changes: 6 additions & 10 deletions .github/workflows/integration.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ jobs:
prepare:
runs-on: ubuntu-latest
outputs:
matrix: ${{ steps.set-tests.outputs.matrix }}
matrix: ${{ steps.extract-tests.outputs.matrix }}
steps:
- name: Checkout code
uses: actions/checkout@v4
Expand All @@ -18,14 +18,8 @@ jobs:
- name: Extract test cases
id: extract-tests
run: |
echo "cases=$(go test -v -list . -tags integration ./integration | grep '^Test' | awk '{print $1}' | cut -d '(' -f1 | tr '\n' ',' | sed 's/,$//')" >> "$GITHUB_OUTPUT"
- name: Format test matrix
id: set-tests
run: |
IFS=',' read -ra TESTS <<< "${{ steps.extract-tests.outputs.cases }}"
TEST_JSON=$(printf ',"%s"' "${TESTS[@]}")
TEST_JSON="[${TEST_JSON:1}]"
echo "matrix={\"test\": $TEST_JSON}" >> "$GITHUB_OUTPUT"
# shellcheck disable=SC2046
echo "matrix={\"test\":$(jq -c -n '$ARGS.positional' --args $(grep '^func Test' integration/*_test.go | awk '{print $2}' | cut -d'(' -f1))}" >> "$GITHUB_OUTPUT"
integration:
needs: prepare
runs-on: ubuntu-latest
Expand All @@ -37,11 +31,13 @@ jobs:
uses: actions/checkout@v4
- name: Init Hermit
uses: cashapp/activate-hermit@v1
with:
cache: true
- name: Build Cache
uses: ./.github/actions/build-cache
- name: Docker Compose
run: docker compose up -d --wait
- name: Download Go Modules
run: go mod download
- name: Run ${{ matrix.test }}
run: go test -v -tags integration -run ${{ matrix.test }} ./integration
run: go test -v -tags integration -run ${{ matrix.test }} ./integration
18 changes: 9 additions & 9 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ jobs:
uses: cashapp/activate-hermit@v1
- name: Build
run: |
docker build -t ghcr.io/tbd54566975/ftl-runner:$GITHUB_SHA -t ghcr.io/tbd54566975/ftl-runner:latest -f Dockerfile.runner .
docker build -t ghcr.io/tbd54566975/ftl-runner:"$GITHUB_SHA" -t ghcr.io/tbd54566975/ftl-runner:latest -f Dockerfile.runner .
mkdir -p artifacts/ftl-runner
docker save -o artifacts/ftl-runner/ftl-runner.tar ghcr.io/tbd54566975/ftl-runner:latest
- name: Temporarily save Docker image
Expand All @@ -34,7 +34,7 @@ jobs:
uses: cashapp/activate-hermit@v1
- name: Build
run: |
docker build -t ghcr.io/tbd54566975/ftl-controller:$GITHUB_SHA -t ghcr.io/tbd54566975/ftl-controller:latest -f Dockerfile.controller .
docker build -t ghcr.io/tbd54566975/ftl-controller:"$GITHUB_SHA" -t ghcr.io/tbd54566975/ftl-controller:latest -f Dockerfile.controller .
mkdir -p artifacts/ftl-controller
docker save -o artifacts/ftl-controller/ftl-controller.tar ghcr.io/tbd54566975/ftl-controller:latest
- name: Temporarily save Docker image
Expand Down Expand Up @@ -79,12 +79,12 @@ jobs:
password: ${{ github.token }}
- name: Push Docker Images
run: |
version=$(git describe --tags --abbrev=0)
docker tag ghcr.io/tbd54566975/ftl-runner:latest ghcr.io/tbd54566975/ftl-runner:$GITHUB_SHA
docker tag ghcr.io/tbd54566975/ftl-runner:latest ghcr.io/tbd54566975/ftl-runner:$version
version="$(git describe --tags --abbrev=0)"
docker tag ghcr.io/tbd54566975/ftl-runner:latest ghcr.io/tbd54566975/ftl-runner:"$GITHUB_SHA"
docker tag ghcr.io/tbd54566975/ftl-runner:latest ghcr.io/tbd54566975/ftl-runner:"$version"
docker push -a ghcr.io/tbd54566975/ftl-runner
docker tag ghcr.io/tbd54566975/ftl-controller:latest ghcr.io/tbd54566975/ftl-controller:$GITHUB_SHA
docker tag ghcr.io/tbd54566975/ftl-controller:latest ghcr.io/tbd54566975/ftl-controller:$version
docker tag ghcr.io/tbd54566975/ftl-controller:latest ghcr.io/tbd54566975/ftl-controller:"$GITHUB_SHA"
docker tag ghcr.io/tbd54566975/ftl-controller:latest ghcr.io/tbd54566975/ftl-controller:"$version"
docker push -a ghcr.io/tbd54566975/ftl-controller
release-jars:
name: Release JARs
Expand Down Expand Up @@ -113,9 +113,9 @@ jobs:
- name: Publish JARs # Snapshots are published first, then the tagged release
run: |
mvn -U -B clean deploy -P release
mvn -B versions:set -DnewVersion=$(git describe --tags --abbrev=0 | cut -c2-) -DprocessAllModules -DgenerateBackupPoms=false
mvn -B versions:set -DnewVersion="$(git describe --tags --abbrev=0 | cut -c2-)" -DprocessAllModules -DgenerateBackupPoms=false
mvn -U -B clean deploy -P release
git clean -f *.flattened_pom.xml
git clean -f ./*.flattened_pom.xml
env:
SIGN_KEY_PASS: ${{ secrets.GPG_PASSPHRASE }}
OSSRH_USERNAME: ${{ secrets.SONATYPE_USERNAME }}
Expand Down
1 change: 1 addition & 0 deletions bin/.actionlint-1.6.26.pkg
1 change: 1 addition & 0 deletions bin/actionlint

0 comments on commit e02ead5

Please sign in to comment.