Chris@0
|
1 <?php
|
Chris@0
|
2
|
Chris@0
|
3 namespace Drupal\Tests\Component\Datetime;
|
Chris@0
|
4
|
Chris@0
|
5 use Drupal\Component\Datetime\Time;
|
Chris@0
|
6 use PHPUnit\Framework\TestCase;
|
Chris@0
|
7 use Symfony\Component\HttpFoundation\Request;
|
Chris@0
|
8
|
Chris@0
|
9 /**
|
Chris@0
|
10 * @coversDefaultClass \Drupal\Component\Datetime\Time
|
Chris@0
|
11 * @group Datetime
|
Chris@0
|
12 *
|
Chris@0
|
13 * Isolate the tests to prevent side effects from altering system time.
|
Chris@0
|
14 *
|
Chris@0
|
15 * @runTestsInSeparateProcesses
|
Chris@0
|
16 * @preserveGlobalState disabled
|
Chris@0
|
17 */
|
Chris@0
|
18 class TimeTest extends TestCase {
|
Chris@0
|
19
|
Chris@0
|
20 /**
|
Chris@0
|
21 * The mocked request stack.
|
Chris@0
|
22 *
|
Chris@0
|
23 * @var \Symfony\Component\HttpFoundation\RequestStack|\PHPUnit_Framework_MockObject_MockObject
|
Chris@0
|
24 */
|
Chris@0
|
25 protected $requestStack;
|
Chris@0
|
26
|
Chris@0
|
27 /**
|
Chris@0
|
28 * The mocked time class.
|
Chris@0
|
29 *
|
Chris@0
|
30 * @var \Drupal\Component\Datetime\Time
|
Chris@0
|
31 */
|
Chris@0
|
32 protected $time;
|
Chris@0
|
33
|
Chris@0
|
34 /**
|
Chris@0
|
35 * {@inheritdoc}
|
Chris@0
|
36 */
|
Chris@0
|
37 protected function setUp() {
|
Chris@0
|
38 parent::setUp();
|
Chris@0
|
39
|
Chris@0
|
40 $this->requestStack = $this->getMock('Symfony\Component\HttpFoundation\RequestStack');
|
Chris@0
|
41
|
Chris@0
|
42 $this->time = new Time($this->requestStack);
|
Chris@0
|
43 }
|
Chris@0
|
44
|
Chris@0
|
45 /**
|
Chris@0
|
46 * Tests the getRequestTime method.
|
Chris@0
|
47 *
|
Chris@0
|
48 * @covers ::getRequestTime
|
Chris@0
|
49 */
|
Chris@0
|
50 public function testGetRequestTime() {
|
Chris@0
|
51 $expected = 12345678;
|
Chris@0
|
52
|
Chris@0
|
53 $request = Request::createFromGlobals();
|
Chris@0
|
54 $request->server->set('REQUEST_TIME', $expected);
|
Chris@0
|
55
|
Chris@0
|
56 // Mocks a the request stack getting the current request.
|
Chris@0
|
57 $this->requestStack->expects($this->any())
|
Chris@0
|
58 ->method('getCurrentRequest')
|
Chris@0
|
59 ->willReturn($request);
|
Chris@0
|
60
|
Chris@0
|
61 $this->assertEquals($expected, $this->time->getRequestTime());
|
Chris@0
|
62 }
|
Chris@0
|
63
|
Chris@0
|
64 /**
|
Chris@0
|
65 * Tests the getRequestMicroTime method.
|
Chris@0
|
66 *
|
Chris@0
|
67 * @covers ::getRequestMicroTime
|
Chris@0
|
68 */
|
Chris@0
|
69 public function testGetRequestMicroTime() {
|
Chris@0
|
70 $expected = 1234567.89;
|
Chris@0
|
71
|
Chris@0
|
72 $request = Request::createFromGlobals();
|
Chris@0
|
73 $request->server->set('REQUEST_TIME_FLOAT', $expected);
|
Chris@0
|
74
|
Chris@0
|
75 // Mocks a the request stack getting the current request.
|
Chris@0
|
76 $this->requestStack->expects($this->any())
|
Chris@0
|
77 ->method('getCurrentRequest')
|
Chris@0
|
78 ->willReturn($request);
|
Chris@0
|
79
|
Chris@0
|
80 $this->assertEquals($expected, $this->time->getRequestMicroTime());
|
Chris@0
|
81 }
|
Chris@0
|
82
|
Chris@0
|
83 /**
|
Chris@0
|
84 * Tests the getCurrentTime method.
|
Chris@0
|
85 *
|
Chris@0
|
86 * @covers ::getCurrentTime
|
Chris@0
|
87 */
|
Chris@0
|
88 public function testGetCurrentTime() {
|
Chris@0
|
89 $expected = 12345678;
|
Chris@0
|
90 $this->assertEquals($expected, $this->time->getCurrentTime());
|
Chris@0
|
91 }
|
Chris@0
|
92
|
Chris@0
|
93 /**
|
Chris@0
|
94 * Tests the getCurrentMicroTime method.
|
Chris@0
|
95 *
|
Chris@0
|
96 * @covers ::getCurrentMicroTime
|
Chris@0
|
97 */
|
Chris@0
|
98 public function testGetCurrentMicroTime() {
|
Chris@0
|
99 $expected = 1234567.89;
|
Chris@0
|
100 $this->assertEquals($expected, $this->time->getCurrentMicroTime());
|
Chris@0
|
101 }
|
Chris@0
|
102
|
Chris@0
|
103 }
|
Chris@0
|
104
|
Chris@0
|
105 namespace Drupal\Component\Datetime;
|
Chris@0
|
106
|
Chris@0
|
107 /**
|
Chris@0
|
108 * Shadow time() system call.
|
Chris@0
|
109 *
|
Chris@0
|
110 * @returns int
|
Chris@0
|
111 */
|
Chris@0
|
112 function time() {
|
Chris@0
|
113 return 12345678;
|
Chris@0
|
114 }
|
Chris@0
|
115
|
Chris@0
|
116 /**
|
Chris@0
|
117 * Shadow microtime system call.
|
Chris@0
|
118 *
|
Chris@0
|
119 * @returns float
|
Chris@0
|
120 */
|
Chris@0
|
121 function microtime() {
|
Chris@0
|
122 return 1234567.89;
|
Chris@0
|
123 }
|