//test-splitter-forkbyOrbisK

test-splitter-fork

Splits PHPUnit tests into batches

0
0
0
PHP

PHPUnit test case splitter

PHP versions: 8.1|8.2|8.3|8.4|8.5
Latest Stable Version
License
Total Downloads

Continuous Integration
PHPStan max
Have you got a slow running test suite?
Are existing test parallelisation tools (e.g. paratest) not suitable as you need separate database instances?

If so, PHPUnit test case splitter might help.
It splits tests into batches in a deterministic way.
Each batch of tests can run in separate instances (e.g. by using a matrix in GitHub actions).

Usage

Install via Composer:

composer require --dev dave-liddament/test-splitter

This package provides an executable under vendor/bin/tsplit that takes two arguments: batch, and number of batches.
It accepts a list of tests piped into stdin and outputs the tests for the specified batch to stdout.

To split the tests into 4 batches and run the first batch you can do:

vendor/bin/phpunit --filter `vendor/bin/phpunit --list-tests | vendor/bin/tsplit 1 4`

To run the second batch out of 4 you’d use:

vendor/bin/phpunit --filter `vendor/bin/phpunit --list-tests | vendor/bin/tsplit 2 4`

GitHub actions

Add this to your GitHub actions:

jobs:
  tests:
  
    strategy:
      fail-fast: false
      matrix: 
        test-batch: [1, 2, 3, 4]

    steps: 
      # Steps to checkout code, setup environment, etc.

      - name: "Tests batch ${{ matrix.test--batch }}"
        run: vendor/bin/phpunit --filter `vendor/bin/phpunit --list-tests | vendor/bin/tsplit ${{ matrix.test-batch }} 4`

This will split the tests over 4 different jobs.

Additional documentation

[beta]v0.14.0