File: SystemStopWatchTest.php

package info (click to toggle)
phpunit 12.3.5-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 50,160 kB
  • sloc: php: 101,772; xml: 2,084; makefile: 124; sh: 99
file content (41 lines) | stat: -rw-r--r-- 1,288 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<?php declare(strict_types=1);
/*
 * This file is part of PHPUnit.
 *
 * (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 PHPUnit\Event\Telemetry;

use function hrtime;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\Small;
use PHPUnit\Framework\TestCase;

#[CoversClass(SystemStopWatch::class)]
#[Small]
final class SystemStopWatchTest extends TestCase
{
    public function testNowReturnsDateTimeImmutable(): void
    {
        $clock = new SystemStopWatch;

        $before = HRTime::fromSecondsAndNanoseconds(...hrtime(false));

        $current = $clock->current();

        $after = HRTime::fromSecondsAndNanoseconds(...hrtime(false));

        $durationBetweenCurrentAndBefore = $current->duration($before);

        $this->assertSame(0, $durationBetweenCurrentAndBefore->seconds());
        $this->assertGreaterThan(0, $durationBetweenCurrentAndBefore->nanoseconds());

        $durationBetweenAfterAndCurrent = $after->duration($current);

        $this->assertSame(0, $durationBetweenAfterAndCurrent->seconds());
        $this->assertGreaterThan(0, $durationBetweenAfterAndCurrent->nanoseconds());
    }
}