chinthakagodawita / codeception-timekeeper
A Codeception extension & Robo task that records test runtimes and lets you split tests into equal runtime-based groups for parallel runs
Requires
- php: >=7.2
- ext-json: *
- codeception/codeception: ^3.1||^4.1
Requires (Dev)
- consolidation/robo: ^1.0||^2.1
Suggests
- consolidation/robo: For time-based test splitting and parallel test run support.
This package is auto-updated.
Last update: 2025-03-11 01:12:50 UTC
README
A Codeception extension & Robo task that records test runtimes and lets you split tests into equal runtime-based groups for parallel runs.
This can be hugely useful when running your tests in an automated fashion, such as in a Continuous Integration system. You can schedule multiple parallel test runs, each with roughly-equal runtimes.
This extension supports the following Codeception version:
- 3.x
- 4.x
Usage
First, install this package:
composer require chinthakagodawita/codeception-timekeeper
Codeception time reporting extension
Update your codeception.yml
with:
extensions: enabled: - ChinthakaGodawita\CodeceptionTimekeeper\Reporter: report_location: _data/time_report.json
Then run your tests, a report with runtimes for each test will be output to _data/time_report.json
. This isn't much use on its own, read on for how you can use this to run your tests in parallel.
Parallel test runs via Robo
composer require --dev consolidation/robo
Update your Robofile
:
<?php class RoboFile extends \Robo\Tasks { use \ChinthakaGodawita\CodeceptionTimekeeper\SplitsTestsByTime; public function taskSplitTests(): \Robo\Result { $groups = 3; $timeReportLocation = '_data/time_report.json'; return $this->taskSplitTestsByTime($groups, $timeReportLocation) ->projectRoot('.') ->testsFrom('tests') ->groupsTo('tests/_data/timekeeper/group_') ->run(); } }
Then update your codeception.yml
file with:
groups: timekeeper_*: tests/_data/timekeeper/group_*
This tells Codeception about the existence of the test groups we've just created.
You'll be able to split tests using:
php vendor/bin/robo split:tests
And run these test groups using:
php vendor/bin/codecept run -g timekeeper_0
php vendor/bin/codecept run -g timekeeper_1
php vendor/bin/codecept run -g timekeeper_2
# etc.
See the Codeception documentation for more information.
Troubleshooting
Some of my tests depend on each other
This extension does not currently support tests with dependencies. Support for this is coming soon.
Help! I'm seeing strange PHP compatibility errors
If you're seeing errors similar to any of the below, then you've hit a variation of codeception/codeception#5031
ERROR: Declaration of Codeception\Test\Test::run(?PHPUnit\Framework\TestResult $result = NULL) must be compatible with PHPUnit\Framework\Test::run(?PHPUnit\Framework\TestResult $result = NULL): PHPUnit\Framework\TestResult
ERROR: Declaration of Codeception\Test\Test::toString() must be compatible with PHPUnit\Framework\SelfDescribing::toString(): string
The simplest way to fix this, till a real fix lands upstream, is to add the following to the very top of your Robofile
instead of just relying on Composer's autoloader:
<?php require_once 'vendor/autoload.php'; require_once 'vendor/codeception/codeception/autoload.php';
Update these paths depending on where your Robofile
lives in relation to Composer's vendor
directory.
This forces Codeception's autoloader to fire and redeclare the PHPUnit classes that it needs to function.
Inspiration
- robo-paracept from the Codeception folks