2016-12-29 19:16:04 -06:00
|
|
|
<?php
|
2015-09-14 18:59:33 -05:00
|
|
|
|
2016-08-23 16:47:40 -05:00
|
|
|
namespace Amp\Parallel\Test\Worker;
|
2016-08-18 11:04:48 -05:00
|
|
|
|
2016-08-23 16:47:40 -05:00
|
|
|
use Amp\Parallel\Test\TestCase;
|
2017-01-09 11:11:25 -06:00
|
|
|
use AsyncInterop\Loop;
|
2015-09-14 18:59:33 -05:00
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
abstract class AbstractPoolTest extends TestCase {
|
2015-12-16 15:53:53 -06:00
|
|
|
/**
|
|
|
|
* @param int $min
|
|
|
|
* @param int $max
|
|
|
|
*
|
2016-08-23 16:47:40 -05:00
|
|
|
* @return \Amp\Parallel\Worker\Pool
|
2015-12-16 15:53:53 -06:00
|
|
|
*/
|
2015-12-16 16:39:25 -06:00
|
|
|
abstract protected function createPool($min = null, $max = null);
|
2015-09-14 18:59:33 -05:00
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testIsRunning() {
|
2016-12-29 19:17:26 -06:00
|
|
|
Loop::execute(\Amp\wrap(function () {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool();
|
|
|
|
$this->assertFalse($pool->isRunning());
|
|
|
|
|
|
|
|
$pool->start();
|
|
|
|
$this->assertTrue($pool->isRunning());
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
yield $pool->shutdown();
|
2015-11-11 02:59:22 -06:00
|
|
|
$this->assertFalse($pool->isRunning());
|
2016-12-29 19:17:26 -06:00
|
|
|
}));
|
2015-11-11 02:59:22 -06:00
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testIsIdleOnStart() {
|
2016-12-29 19:17:26 -06:00
|
|
|
Loop::execute(\Amp\wrap(function () {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool();
|
|
|
|
$pool->start();
|
|
|
|
|
|
|
|
$this->assertTrue($pool->isIdle());
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
yield $pool->shutdown();
|
2016-12-29 19:17:26 -06:00
|
|
|
}));
|
2015-11-11 02:59:22 -06:00
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testGetMinSize() {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool(7, 24);
|
|
|
|
$this->assertEquals(7, $pool->getMinSize());
|
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testGetMaxSize() {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool(3, 17);
|
|
|
|
$this->assertEquals(17, $pool->getMaxSize());
|
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testMinWorkersSpawnedOnStart() {
|
2016-12-29 19:17:26 -06:00
|
|
|
Loop::execute(\Amp\wrap(function () {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool(8, 32);
|
|
|
|
$pool->start();
|
|
|
|
|
|
|
|
$this->assertEquals(8, $pool->getWorkerCount());
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
yield $pool->shutdown();
|
2016-12-29 19:17:26 -06:00
|
|
|
}));
|
2015-11-11 02:59:22 -06:00
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testWorkersIdleOnStart() {
|
2016-12-29 19:17:26 -06:00
|
|
|
Loop::execute(\Amp\wrap(function () {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool(8, 32);
|
|
|
|
$pool->start();
|
|
|
|
|
|
|
|
$this->assertEquals(8, $pool->getIdleWorkerCount());
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
yield $pool->shutdown();
|
2016-12-29 19:17:26 -06:00
|
|
|
}));
|
2015-11-11 02:59:22 -06:00
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testEnqueue() {
|
2016-12-29 19:17:26 -06:00
|
|
|
Loop::execute(\Amp\wrap(function () {
|
2015-09-14 18:59:33 -05:00
|
|
|
$pool = $this->createPool();
|
|
|
|
$pool->start();
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
$returnValue = yield $pool->enqueue(new TestTask(42));
|
2015-09-14 18:59:33 -05:00
|
|
|
$this->assertEquals(42, $returnValue);
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
yield $pool->shutdown();
|
2016-12-29 19:17:26 -06:00
|
|
|
}));
|
2015-11-11 02:59:22 -06:00
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testEnqueueMultiple() {
|
2016-12-29 19:17:26 -06:00
|
|
|
Loop::execute(\Amp\wrap(function () {
|
2015-12-11 22:47:46 -06:00
|
|
|
$pool = $this->createPool();
|
|
|
|
$pool->start();
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
$values = yield \Amp\all([
|
|
|
|
$pool->enqueue(new TestTask(42)),
|
|
|
|
$pool->enqueue(new TestTask(56)),
|
|
|
|
$pool->enqueue(new TestTask(72))
|
2016-01-23 00:00:56 -06:00
|
|
|
]);
|
2015-12-11 22:47:46 -06:00
|
|
|
|
|
|
|
$this->assertEquals([42, 56, 72], $values);
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
yield $pool->shutdown();
|
2016-12-29 19:17:26 -06:00
|
|
|
}));
|
2015-12-11 22:47:46 -06:00
|
|
|
}
|
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
public function testKill() {
|
2015-11-11 02:59:22 -06:00
|
|
|
$pool = $this->createPool();
|
|
|
|
$pool->start();
|
2015-09-14 18:59:33 -05:00
|
|
|
|
2016-08-18 17:36:58 -05:00
|
|
|
$this->assertRunTimeLessThan([$pool, 'kill'], 1);
|
2015-11-11 02:59:22 -06:00
|
|
|
$this->assertFalse($pool->isRunning());
|
2015-09-14 18:59:33 -05:00
|
|
|
}
|
|
|
|
}
|