HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/magento.bikenow.co/vendor/phpunit/php-timer/tests/TimerTest.php
<?php declare(strict_types=1);
/*
 * This file is part of phpunit/php-timer.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace SebastianBergmann\Timer;

use PHPUnit\Framework\TestCase;

/**
 * @covers \SebastianBergmann\Timer\Timer
 */
final class TimerTest extends TestCase
{
    public function testCanBeStartedAndStopped(): void
    {
        Timer::start();

        $this->assertIsFloat(Timer::stop());
    }

    public function testCanFormatTimeSinceStartOfRequest(): void
    {
        $this->assertStringMatchesFormat('%d:%d%s', Timer::timeSinceStartOfRequest());
    }

    public function testCanFormatResourceUsage(): void
    {
        $this->assertStringMatchesFormat('Time: %s, Memory: %f %s', Timer::resourceUsage());
    }

    /**
     * @dataProvider secondsToTimeStringProvider
     * @testdox Can format $seconds as '$string'
     */
    public function testCanFormatSecondsAsString(string $string, float $seconds): void
    {
        $this->assertEquals($string, Timer::secondsToTimeString($seconds));
    }

    public function secondsToTimeStringProvider(): array
    {
        return [
            ['0 milliseconds', 0],
            ['1 millisecond', .001],
            ['10 milliseconds', .01],
            ['100 milliseconds', .1],
            ['999 milliseconds', .999],
            ['1 second', .9999],
            ['1 second', 1],
            ['2 seconds', 2],
            ['59 seconds, 900 milliseconds', 59.9],
            ['59 seconds, 990 milliseconds', 59.99],
            ['59 seconds, 999 milliseconds', 59.999],
            ['1 minute', 59.9999],
            ['59 seconds, 1 millisecond', 59.001],
            ['59 seconds, 10 milliseconds', 59.01],
            ['1 minute', 60],
            ['1 minute, 1 second', 61],
            ['2 minutes', 120],
            ['2 minutes, 1 second', 121],
            ['59 minutes, 59 seconds, 900 milliseconds', 3599.9],
            ['59 minutes, 59 seconds, 990 milliseconds', 3599.99],
            ['59 minutes, 59 seconds, 999 milliseconds', 3599.999],
            ['1 hour', 3599.9999],
            ['59 minutes, 59 seconds, 1 millisecond', 3599.001],
            ['59 minutes, 59 seconds, 10 milliseconds', 3599.01],
            ['1 hour', 3600],
            ['1 hour, 1 second', 3601],
            ['1 hour, 1 second, 900 milliseconds', 3601.9],
            ['1 hour, 1 second, 990 milliseconds', 3601.99],
            ['1 hour, 1 second, 999 milliseconds', 3601.999],
            ['1 hour, 2 seconds', 3601.9999],
            ['1 hour, 1 minute', 3659.9999],
            ['1 hour, 59 seconds, 1 millisecond', 3659.001],
            ['1 hour, 59 seconds, 10 milliseconds', 3659.01],
            ['2 hours', 7199.9999],
        ];
    }

    /**
     * @dataProvider secondsToTimeShortStringProvider
     * @testdox Can format $seconds as '$string'
     */
    public function testCanFormatSecondsAsShortString(string $string, float $seconds): void
    {
        $this->assertEquals($string, Timer::secondsToShortTimeString($seconds));
    }

    public function secondsToTimeShortStringProvider(): array
    {
        return [
            ['00:00', 0],
            ['00:00.001', .001],
            ['00:00.010', .01],
            ['00:00.100', .1],
            ['00:00.999', .999],
            ['00:01', .9999],
            ['00:01', 1],
            ['00:02', 2],
            ['00:59.900', 59.9],
            ['00:59.990', 59.99],
            ['00:59.999', 59.999],
            ['01:00', 59.9999],
            ['00:59.001', 59.001],
            ['00:59.010', 59.01],
            ['01:00', 60],
            ['01:01', 61],
            ['02:00', 120],
            ['02:01', 121],
            ['59:59.900', 3599.9],
            ['59:59.990', 3599.99],
            ['59:59.999', 3599.999],
            ['01:00:00', 3599.9999],
            ['59:59.001', 3599.001],
            ['59:59.010', 3599.01],
            ['01:00:00', 3600],
            ['01:00:01', 3601],
            ['01:00:01.900', 3601.9],
            ['01:00:01.990', 3601.99],
            ['01:00:01.999', 3601.999],
            ['01:00:02', 3601.9999],
            ['01:01:00', 3659.9999],
            ['01:00:59.001', 3659.001],
            ['01:00:59.010', 3659.01],
            ['02:00:00', 7199.9999],
        ];
    }

    /**
     * @dataProvider bytesProvider
     * @testdox Can format $bytes as '$string'
     */
    public function testCanFormatBytesAsString(string $string, float $bytes): void
    {
        $this->assertEquals($string, Timer::bytesToString($bytes));
    }

    public function bytesProvider(): array
    {
        return [
            ['0 bytes', 0],
            ['1 byte', 1],
            ['1023 bytes', 1023],
            ['1.00 KB', 1024],
            ['1.50 KB', 1.5 * 1024],
            ['2.00 MB', 2 * 1048576],
            ['2.50 MB', 2.5 * 1048576],
            ['3.00 GB', 3 * 1073741824],
            ['3.50 GB', 3.5 * 1073741824],
        ];
    }

    /**
     * @backupGlobals enabled
     * @testdox Cannot access time since start of request when $_SERVER['REQUEST_TIME_FLOAT'] is not set
     */
    public function testCannotAccessTimeSinceStartOfRequestWhenServerRequestTimeFloatIsNotSet(): void
    {
        unset($_SERVER['REQUEST_TIME_FLOAT']);

        $this->expectException(RuntimeException::class);
        $this->expectExceptionMessage('Cannot determine time at which the request started because $_SERVER[\'REQUEST_TIME_FLOAT\'] is not available');

        Timer::timeSinceStartOfRequest();
    }

    /**
     * @backupGlobals enabled
     * @testdox Cannot access time since start of request when $_SERVER['REQUEST_TIME_FLOAT'] is not of type float
     */
    public function testCannotAccessTimeSinceStartOfRequestWhenServerRequestTimeFloatIsNotFloat(): void
    {
        $_SERVER['REQUEST_TIME_FLOAT'] = 'string';

        $this->expectException(RuntimeException::class);
        $this->expectExceptionMessage('Cannot determine time at which the request started because $_SERVER[\'REQUEST_TIME_FLOAT\'] is not of type float');

        Timer::timeSinceStartOfRequest();
    }
}