1
0
mirror of https://github.com/danog/amp.git synced 2025-01-06 13:08:22 +01:00
amp/test/Iterator/FromIterableTest.php

149 lines
3.9 KiB
PHP
Raw Normal View History

<?php
2020-05-13 17:15:21 +02:00
namespace Amp\Test\Iterator;
use Amp\Delayed;
use Amp\Failure;
2017-04-27 17:51:06 +02:00
use Amp\Iterator;
2017-04-23 14:39:19 +02:00
use Amp\Loop;
use Amp\PHPUnit\TestException;
use Amp\Success;
2020-05-13 17:15:21 +02:00
use Amp\Test\BaseTest;
2020-05-13 17:15:21 +02:00
class FromIterableTest extends BaseTest
2018-06-18 20:00:01 +02:00
{
const TIMEOUT = 10;
2018-06-18 20:00:01 +02:00
public function testSuccessfulPromises()
{
2017-04-27 17:32:53 +02:00
Loop::run(function () {
$expected = \range(1, 3);
2017-04-27 17:51:06 +02:00
$iterator = Iterator\fromIterable([new Success(1), new Success(2), new Success(3)]);
2017-01-06 23:16:06 +01:00
2017-04-27 17:51:06 +02:00
while (yield $iterator->advance()) {
$this->assertSame(\array_shift($expected), $iterator->getCurrent());
2017-04-27 17:32:53 +02:00
}
});
}
2017-01-06 23:16:06 +01:00
2018-06-18 20:00:01 +02:00
public function testFailedPromises()
{
2017-04-27 17:32:53 +02:00
Loop::run(function () {
$exception = new \Exception;
2017-04-27 17:51:06 +02:00
$iterator = Iterator\fromIterable([new Failure($exception), new Failure($exception)]);
2017-01-06 23:16:06 +01:00
2017-04-27 17:32:53 +02:00
try {
2017-04-27 17:51:06 +02:00
yield $iterator->advance();
2017-04-27 17:32:53 +02:00
} catch (\Exception $reason) {
$this->assertSame($exception, $reason);
}
});
}
2017-01-06 23:16:06 +01:00
2018-06-18 20:00:01 +02:00
public function testMixedPromises()
{
2017-04-27 17:32:53 +02:00
Loop::run(function () {
$exception = new TestException;
2017-04-27 17:32:53 +02:00
$expected = \range(1, 2);
2017-04-27 17:51:06 +02:00
$iterator = Iterator\fromIterable([new Success(1), new Success(2), new Failure($exception), new Success(4)]);
2017-01-06 23:16:06 +01:00
2017-04-27 17:32:53 +02:00
try {
2017-04-27 17:51:06 +02:00
while (yield $iterator->advance()) {
$this->assertSame(\array_shift($expected), $iterator->getCurrent());
2017-04-27 17:32:53 +02:00
}
$this->fail("A failed promise in the iterable should fail the iterator and be thrown from advance()");
} catch (TestException $reason) {
2017-04-27 17:32:53 +02:00
$this->assertSame($exception, $reason);
}
2017-01-06 23:16:06 +01:00
2017-04-27 17:32:53 +02:00
$this->assertEmpty($expected);
});
}
2017-01-06 23:16:06 +01:00
2018-06-18 20:00:01 +02:00
public function testPendingPromises()
{
2017-04-27 17:32:53 +02:00
Loop::run(function () {
$expected = \range(1, 4);
2017-04-27 17:51:06 +02:00
$iterator = Iterator\fromIterable([new Delayed(30, 1), new Delayed(10, 2), new Delayed(20, 3), new Success(4)]);
2017-01-06 23:16:06 +01:00
2017-04-27 17:51:06 +02:00
while (yield $iterator->advance()) {
$this->assertSame(\array_shift($expected), $iterator->getCurrent());
2017-04-27 17:32:53 +02:00
}
});
}
2017-01-06 23:16:06 +01:00
2018-06-18 20:00:01 +02:00
public function testTraversable()
{
2017-04-27 17:32:53 +02:00
Loop::run(function () {
$expected = \range(1, 4);
2017-01-04 02:10:27 +01:00
$generator = (function () {
foreach (\range(1, 4) as $value) {
yield $value;
}
})();
2017-01-06 23:16:06 +01:00
2017-04-27 17:51:06 +02:00
$iterator = Iterator\fromIterable($generator);
2017-01-06 23:16:06 +01:00
2017-04-27 17:51:06 +02:00
while (yield $iterator->advance()) {
$this->assertSame(\array_shift($expected), $iterator->getCurrent());
2017-04-27 17:32:53 +02:00
}
2017-01-06 23:16:06 +01:00
2017-04-27 17:32:53 +02:00
$this->assertEmpty($expected);
});
2017-01-04 02:10:27 +01:00
}
2017-01-06 23:16:06 +01:00
/**
* @dataProvider provideInvalidIteratorArguments
2017-01-06 23:16:06 +01:00
*/
2018-06-18 20:00:01 +02:00
public function testInvalid($arg)
{
2020-05-13 17:15:21 +02:00
$this->expectException(\TypeError::class);
2017-04-27 17:51:06 +02:00
Iterator\fromIterable($arg);
2017-01-06 23:16:06 +01:00
}
2018-06-18 20:00:01 +02:00
public function provideInvalidIteratorArguments()
{
2017-01-06 23:16:06 +01:00
return [
[null],
[new \stdClass],
[32],
[false],
[true],
["string"],
];
}
2018-06-18 20:00:01 +02:00
public function testInterval()
{
2017-04-27 17:32:53 +02:00
Loop::run(function () {
$count = 3;
$iterator = Iterator\fromIterable(\range(1, $count), self::TIMEOUT);
2017-04-27 17:32:53 +02:00
$i = 0;
2017-04-27 17:51:06 +02:00
while (yield $iterator->advance()) {
$this->assertSame(++$i, $iterator->getCurrent());
2017-04-27 17:32:53 +02:00
}
2017-04-27 17:32:53 +02:00
$this->assertSame($count, $i);
});
}
/**
* @depends testInterval
*/
2018-06-18 20:00:01 +02:00
public function testSlowConsumer()
{
$count = 5;
2017-04-27 17:32:53 +02:00
Loop::run(function () use ($count) {
$iterator = Iterator\fromIterable(\range(1, $count), self::TIMEOUT);
2017-04-27 17:51:06 +02:00
for ($i = 0; yield $iterator->advance(); ++$i) {
2017-04-27 17:32:53 +02:00
yield new Delayed(self::TIMEOUT * 2);
}
2017-04-27 17:32:53 +02:00
$this->assertSame($count, $i);
});
}
}