From fc9401f04a3aca5abb22f87ebc210de8afe11d32 Mon Sep 17 00:00:00 2001 From: marvin-borner@live.com Date: Tue, 10 Apr 2018 21:50:16 +0200 Subject: Initial Commit --- .../react/promise-timer/tests/CallableStub.php | 10 ++ .../promise-timer/tests/FunctionRejectTest.php | 49 ++++++ .../promise-timer/tests/FunctionResolveTest.php | 71 +++++++++ .../promise-timer/tests/FunctionTimeoutTest.php | 169 +++++++++++++++++++++ .../vendor/react/promise-timer/tests/TestCase.php | 61 ++++++++ .../promise-timer/tests/TimeoutExceptionTest.php | 15 ++ 6 files changed, 375 insertions(+) create mode 100644 assets/php/vendor/react/promise-timer/tests/CallableStub.php create mode 100644 assets/php/vendor/react/promise-timer/tests/FunctionRejectTest.php create mode 100644 assets/php/vendor/react/promise-timer/tests/FunctionResolveTest.php create mode 100644 assets/php/vendor/react/promise-timer/tests/FunctionTimeoutTest.php create mode 100644 assets/php/vendor/react/promise-timer/tests/TestCase.php create mode 100644 assets/php/vendor/react/promise-timer/tests/TimeoutExceptionTest.php (limited to 'assets/php/vendor/react/promise-timer/tests') diff --git a/assets/php/vendor/react/promise-timer/tests/CallableStub.php b/assets/php/vendor/react/promise-timer/tests/CallableStub.php new file mode 100644 index 0000000..a391aa5 --- /dev/null +++ b/assets/php/vendor/react/promise-timer/tests/CallableStub.php @@ -0,0 +1,10 @@ +loop); + + $this->expectPromisePending($promise); + } + + public function testPromiseExpiredIsPendingWithoutRunningLoop() + { + $promise = Timer\reject(-1, $this->loop); + + $this->expectPromisePending($promise); + } + + public function testPromiseWillBeRejectedOnTimeout() + { + $promise = Timer\reject(0.01, $this->loop); + + $this->loop->run(); + + $this->expectPromiseRejected($promise); + } + + public function testPromiseExpiredWillBeRejectedOnTimeout() + { + $promise = Timer\reject(-1, $this->loop); + + $this->loop->run(); + + $this->expectPromiseRejected($promise); + } + + public function testCancelingPromiseWillRejectTimer() + { + $promise = Timer\reject(0.01, $this->loop); + + $promise->cancel(); + + $this->expectPromiseRejected($promise); + } +} diff --git a/assets/php/vendor/react/promise-timer/tests/FunctionResolveTest.php b/assets/php/vendor/react/promise-timer/tests/FunctionResolveTest.php new file mode 100644 index 0000000..0bfdc21 --- /dev/null +++ b/assets/php/vendor/react/promise-timer/tests/FunctionResolveTest.php @@ -0,0 +1,71 @@ +loop); + + $this->expectPromisePending($promise); + } + + public function testPromiseExpiredIsPendingWithoutRunningLoop() + { + $promise = Timer\resolve(-1, $this->loop); + + $this->expectPromisePending($promise); + } + + public function testPromiseWillBeResolvedOnTimeout() + { + $promise = Timer\resolve(0.01, $this->loop); + + $this->loop->run(); + + $this->expectPromiseResolved($promise); + } + + public function testPromiseExpiredWillBeResolvedOnTimeout() + { + $promise = Timer\resolve(-1, $this->loop); + + $this->loop->run(); + + $this->expectPromiseResolved($promise); + } + + public function testWillStartLoopTimer() + { + $loop = $this->getMockBuilder('React\EventLoop\LoopInterface')->getMock(); + $loop->expects($this->once())->method('addTimer')->with($this->equalTo(0.01)); + + Timer\resolve(0.01, $loop); + } + + public function testCancellingPromiseWillCancelLoopTimer() + { + $loop = $this->getMockBuilder('React\EventLoop\LoopInterface')->getMock(); + + $timer = $this->getMockBuilder(interface_exists('React\EventLoop\TimerInterface') ? 'React\EventLoop\TimerInterface' : 'React\EventLoop\Timer\TimerInterface')->getMock(); + $loop->expects($this->once())->method('addTimer')->will($this->returnValue($timer)); + + $promise = Timer\resolve(0.01, $loop); + + $loop->expects($this->once())->method('cancelTimer')->with($this->equalTo($timer)); + + $promise->cancel(); + } + + public function testCancelingPromiseWillRejectTimer() + { + $promise = Timer\resolve(0.01, $this->loop); + + $promise->cancel(); + + $this->expectPromiseRejected($promise); + } +} diff --git a/assets/php/vendor/react/promise-timer/tests/FunctionTimeoutTest.php b/assets/php/vendor/react/promise-timer/tests/FunctionTimeoutTest.php new file mode 100644 index 0000000..aaca2da --- /dev/null +++ b/assets/php/vendor/react/promise-timer/tests/FunctionTimeoutTest.php @@ -0,0 +1,169 @@ +loop); + + $this->expectPromiseResolved($promise); + } + + public function testResolvedExpiredWillResolveRightAway() + { + $promise = Promise\resolve(); + + $promise = Timer\timeout($promise, -1, $this->loop); + + $this->expectPromiseResolved($promise); + } + + public function testResolvedWillNotStartTimer() + { + $promise = Promise\resolve(); + + Timer\timeout($promise, 3, $this->loop); + + $time = microtime(true); + $this->loop->run(); + $time = microtime(true) - $time; + + $this->assertLessThan(0.5, $time); + } + + public function testRejectedWillRejectRightAway() + { + $promise = Promise\reject(); + + $promise = Timer\timeout($promise, 3, $this->loop); + + $this->expectPromiseRejected($promise); + } + + public function testRejectedWillNotStartTimer() + { + $promise = Promise\reject(); + + Timer\timeout($promise, 3, $this->loop); + + $time = microtime(true); + $this->loop->run(); + $time = microtime(true) - $time; + + $this->assertLessThan(0.5, $time); + } + + public function testPendingWillRejectOnTimeout() + { + $promise = $this->getMockBuilder('React\Promise\PromiseInterface')->getMock(); + + $promise = Timer\timeout($promise, 0.01, $this->loop); + + $this->loop->run(); + + $this->expectPromiseRejected($promise); + } + + public function testPendingCancellableWillBeCancelledOnTimeout() + { + $promise = $this->getMockBuilder('React\Promise\CancellablePromiseInterface')->getMock(); + $promise->expects($this->once())->method('cancel'); + + Timer\timeout($promise, 0.01, $this->loop); + + $this->loop->run(); + } + + public function testCancelTimeoutWithoutCancellationhandlerWillNotCancelTimerAndWillNotReject() + { + $promise = new \React\Promise\Promise(function () { }); + + $loop = $this->getMockBuilder('React\EventLoop\LoopInterface')->getMock(); + + $timer = $this->getMockBuilder('React\EventLoop\Timer\TimerInterface')->getMock(); + $loop->expects($this->once())->method('addTimer')->will($this->returnValue($timer)); + $loop->expects($this->never())->method('cancelTimer'); + + $timeout = Timer\timeout($promise, 0.01, $loop); + + $timeout->cancel(); + + $this->expectPromisePending($timeout); + } + + public function testResolvedPromiseWillNotStartTimer() + { + $promise = new \React\Promise\Promise(function ($resolve) { $resolve(true); }); + + $loop = $this->getMockBuilder('React\EventLoop\LoopInterface')->getMock(); + $loop->expects($this->never())->method('addTimer'); + + $timeout = Timer\timeout($promise, 0.01, $loop); + + $this->expectPromiseResolved($timeout); + } + + public function testRejectedPromiseWillNotStartTimer() + { + $promise = Promise\reject(new \RuntimeException()); + + $loop = $this->getMockBuilder('React\EventLoop\LoopInterface')->getMock(); + $loop->expects($this->never())->method('addTimer'); + + $timeout = Timer\timeout($promise, 0.01, $loop); + + $this->expectPromiseRejected($timeout); + } + + public function testCancelTimeoutWillCancelGivenPromise() + { + $promise = new \React\Promise\Promise(function () { }, $this->expectCallableOnce()); + + $timeout = Timer\timeout($promise, 0.01, $this->loop); + + $timeout->cancel(); + } + + public function testCancelGivenPromiseWillReject() + { + $promise = new \React\Promise\Promise(function () { }, function ($resolve, $reject) { $reject(); }); + + $timeout = Timer\timeout($promise, 0.01, $this->loop); + + $promise->cancel(); + + $this->expectPromiseRejected($promise); + $this->expectPromiseRejected($timeout); + } + + public function testCancelTimeoutWillRejectIfGivenPromiseWillReject() + { + $promise = new \React\Promise\Promise(function () { }, function ($resolve, $reject) { $reject(); }); + + $timeout = Timer\timeout($promise, 0.01, $this->loop); + + $timeout->cancel(); + + $this->expectPromiseRejected($promise); + $this->expectPromiseRejected($timeout); + } + + public function testCancelTimeoutWillResolveIfGivenPromiseWillResolve() + { + $promise = new \React\Promise\Promise(function () { }, function ($resolve, $reject) { $resolve(); }); + + $timeout = Timer\timeout($promise, 0.01, $this->loop); + + $timeout->cancel(); + + $this->expectPromiseResolved($promise); + $this->expectPromiseResolved($timeout); + } +} diff --git a/assets/php/vendor/react/promise-timer/tests/TestCase.php b/assets/php/vendor/react/promise-timer/tests/TestCase.php new file mode 100644 index 0000000..9d8d49a --- /dev/null +++ b/assets/php/vendor/react/promise-timer/tests/TestCase.php @@ -0,0 +1,61 @@ +loop = Factory::create(); + } + + protected function expectCallableOnce() + { + $mock = $this->createCallableMock(); + + $mock + ->expects($this->once()) + ->method('__invoke'); + + return $mock; + } + + protected function expectCallableNever() + { + $mock = $this->createCallableMock(); + + $mock + ->expects($this->never()) + ->method('__invoke'); + + return $mock; + } + + /** + * @link https://github.com/reactphp/react/blob/master/tests/React/Tests/Socket/TestCase.php (taken from reactphp/react) + */ + protected function createCallableMock() + { + return $this->getMockBuilder('React\Tests\Promise\Timer\CallableStub')->getMock(); + } + + protected function expectPromiseRejected($promise) + { + return $promise->then($this->expectCallableNever(), $this->expectCallableOnce()); + } + + protected function expectPromiseResolved($promise) + { + return $promise->then($this->expectCallableOnce(), $this->expectCallableNever()); + } + + protected function expectPromisePending($promise) + { + return $promise->then($this->expectCallableNever(), $this->expectCallableNever()); + } +} diff --git a/assets/php/vendor/react/promise-timer/tests/TimeoutExceptionTest.php b/assets/php/vendor/react/promise-timer/tests/TimeoutExceptionTest.php new file mode 100644 index 0000000..e9bedd9 --- /dev/null +++ b/assets/php/vendor/react/promise-timer/tests/TimeoutExceptionTest.php @@ -0,0 +1,15 @@ +assertEquals(10, $e->getTimeout()); + } +} -- cgit v1.2.3