Contributed by
Nicolas Grekas
in #46715.
Testing time-related functions is difficult and produces transient test errors. That's why we introduced Clock mocking for tests in Symfony 2.8, more than six years ago. In Symfony 6.2 we're expanding those efforts with the introduction of a new component called Clock.
This new component will improve the testability of your time-sensitive code. The PHP-FIG group is working on a similar proposal in PSR-20, so we designed Symfony Clock component to ease compatibility with it.
First, this component defines the following ClockInterface
:
namespace Symfony\Component\Clock;
interface ClockInterface
{
// returns the current datetime (it's designed to be compatible with PSR-20)
public function now(): \DateTimeImmutable;
// advances the clock by the provided number of seconds
public function sleep(float|int $seconds): void;
// changes the time zone returned by now()
public function withTimeZone(\DateTimeZone|string $timezone): static;
}
In addition to the interface, the component provides three concrete implementations:
NativeClock
, uses the system clock, so it returns the real current time, it sleeps the actual number of seconds given, etc.;MockClock
, suited for tests, it always returns the same datetime (the one passed to its constructor) and it advances time instantly, without calling to the realsleep()
function of PHP;MonotonicClock
, suited for performance profiling, it uses the monotonic clock provided by PHP viahrtime()
function and it sleeps the actual number of seconds given).
Related to this, in Symfony 6.2 we've also improved the existing ClockMock
class of PHPUnit Bridge component. In #47295,
Christian Flothmann added support
for mocking the hrtime()
function.
<hr style="margin-bottom: 5px" />
<div style="font-size: 90%">
<a href="https://symfony.com/sponsor">Sponsor</a> the Symfony project.
</div>
Jelentkezéshez jelentkezzen be
EGYÉB POSTS Ebben a csoportban

This is the second part of the blog post showcasing the main DX (developer experience) features introduced in Symfony 7.3. Read the first part of this blog post.
Verify URI Signatures… https://symfon

Symfony 6.4.22 has just been released. Read the Symfony upgrade guide to learn more about upgrading Symfony and use the SymfonyInsight upgrade reports to detect the code you will need to change in you

Symfony 7.2.7 has just been released. Read the Symfony upgrade guide to learn more about upgrading Symfony and use the SymfonyInsight upgrade reports to detect the code you will need to change in your

Symfony 7.3.0 has just been released. Check the New in Symfony 7.3 posts on this blog to learn about the main features of this new stable release; or check the first beta release announcement to get t

Symfony 7.3.0 has been released. As for any other Symfony release, our backward compatibility promise applies and this means that you should be able to upgrade easily to 7.3 without changing anything

Symfony 7.3 includes many small improvements aimed at making developers' lives easier and more productive. This blog post highlights some of the most useful DX (Developer Experience) features added in

Symfony 7.3 introduces several enhancements to the Validator component, focusing on developer experience, better configurability, and more expressive constraint definitions.
Allow to Disable Translat