phpunit / php-timer
Utility class for timing
9.0.0
2026-02-06 04:37 UTC
Requires
- php: >=8.4
Requires (Dev)
- phpunit/phpunit: ^13.0
- dev-main / 9.0.x-dev
- 9.0.0
- 8.0.x-dev
- 8.0.0
- 7.0.1
- 7.0.0
- 6.0.0
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.0.0
- 3.1.4
- 3.1.3
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.0
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.0
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- dev-renovate/8.0-github-actions
- dev-renovate/main-github-actions
- dev-renovate/8.0-major-github-actions
This package is auto-updated.
Last update: 2026-06-08 22:58:14 UTC
README
Utility class for timing things, factored out of PHPUnit into a stand-alone component.
Installation
You can add this library as a local, per-project dependency to your project using Composer:
composer require phpunit/php-timer
If you only need this library during development, for instance to run your project's test suite, then you should add it as a development-time dependency:
composer require --dev phpunit/php-timer
Usage
Basic Timing
require __DIR__ . '/vendor/autoload.php'; use SebastianBergmann\Timer\Timer; $timer = new Timer; $timer->start(); foreach (\range(0, 100000) as $i) { // ... } $duration = $timer->stop(); var_dump(get_class($duration)); var_dump($duration->asString()); var_dump($duration->asSeconds()); var_dump($duration->asMilliseconds()); var_dump($duration->asMicroseconds()); var_dump($duration->asNanoseconds());
The code above yields the output below:
string(32) "SebastianBergmann\Timer\Duration"
string(9) "00:00.002"
float(0.002851062)
float(2.851062)
float(2851.062)
int(2851062)
Resource Consumption
Explicit duration
require __DIR__ . '/vendor/autoload.php'; use SebastianBergmann\Timer\ResourceUsageFormatter; use SebastianBergmann\Timer\Timer; $timer = new Timer; $timer->start(); foreach (\range(0, 100000) as $i) { // ... } print (new ResourceUsageFormatter)->resourceUsage($timer->stop());
The code above yields the output below:
Time: 00:00.002, Memory: 6.00 MB
Duration since PHP Startup (using unreliable $_SERVER['REQUEST_TIME_FLOAT'])
require __DIR__ . '/vendor/autoload.php'; use SebastianBergmann\Timer\ResourceUsageFormatter; foreach (\range(0, 100000) as $i) { // ... } print (new ResourceUsageFormatter)->resourceUsageSinceStartOfRequest();
The code above yields the output below:
Time: 00:00.002, Memory: 6.00 MB