This post goes over how to shard PHPUnit tests with GitHub Actions.
Motivation
If you run your PHPUnit tests sequentially in GitHub Actions, it can take a long time if you have a lot of tests.
With test sharding, you divide your tests to speed up test runtime. As a result, this means your tests run in parallel for faster build times.
Although you can write a Bash script to do this, there’s already a GitHub Action called find-and-split that automates this for you.
Test Sharding
Let’s say you have a GitHub Actions workflow that runs PHPUnit tests sequentially:
# .github/workflows/test.yml
name: test
on: push
jobs:
  test:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout repository
        uses: actions/checkout@v5
      - name: Install dependencies
        run: composer install
      - name: Run tests
        run: vendor/bin/phpunit tests
With find-and-split and the matrix strategy, you can split your tests into 2 jobs based on the number of test files:
 # .github/workflows/test.yml
 name: test
 on: push
 jobs:
   test:
     runs-on: ubuntu-latest
+    strategy:
+      matrix:
+        shard: [1/2, 1/2]
     steps:
       - name: Checkout repository
         uses: actions/checkout@v5
       - name: Install dependencies
         run: composer install
+      - name: Find and split files
+        uses: remarkablemark/find-and-split@v1
+        id: tests
+        with:
+          chunk: ${{ matrix.shard }}
+          directory: tests
+          pattern: '*Test.php'
       - name: Run tests
-        run: vendor/bin/phpunit tests
+        run: vendor/bin/phpunit ${{ steps.tests.outputs.files }}
Resources
For more details, check out the test repository.