TimeDataCollectorTest.php 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Component\HttpKernel\Tests\DataCollector;
  11. use PHPUnit\Framework\TestCase;
  12. use Symfony\Component\HttpFoundation\Request;
  13. use Symfony\Component\HttpFoundation\Response;
  14. use Symfony\Component\HttpKernel\DataCollector\TimeDataCollector;
  15. use Symfony\Component\Stopwatch\Stopwatch;
  16. /**
  17. * @group time-sensitive
  18. */
  19. class TimeDataCollectorTest extends TestCase
  20. {
  21. public function testCollect()
  22. {
  23. $c = new TimeDataCollector();
  24. $request = new Request();
  25. $request->server->set('REQUEST_TIME', 1);
  26. $c->collect($request, new Response());
  27. $this->assertEquals(0, $c->getStartTime());
  28. $request->server->set('REQUEST_TIME_FLOAT', 2);
  29. $c->collect($request, new Response());
  30. $this->assertEquals(2000, $c->getStartTime());
  31. $request = new Request();
  32. $c->collect($request, new Response());
  33. $this->assertEquals(0, $c->getStartTime());
  34. $kernel = $this->getMockBuilder('Symfony\Component\HttpKernel\KernelInterface')->getMock();
  35. $kernel->expects($this->once())->method('getStartTime')->willReturn(123456);
  36. $c = new TimeDataCollector($kernel);
  37. $request = new Request();
  38. $request->server->set('REQUEST_TIME', 1);
  39. $c->collect($request, new Response());
  40. $this->assertEquals(123456000, $c->getStartTime());
  41. $this->assertSame(class_exists(Stopwatch::class, false), $c->isStopwatchInstalled());
  42. }
  43. }