2016-12-30 02:16:04 +01:00
|
|
|
<?php
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2016-08-23 23:47:40 +02:00
|
|
|
namespace Amp\Parallel\Test\Worker;
|
2016-08-18 18:04:48 +02:00
|
|
|
|
2016-08-23 23:47:40 +02:00
|
|
|
use Amp\Parallel\Test\TestCase;
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
abstract class AbstractWorkerTest extends TestCase {
|
2015-08-29 03:55:30 +02:00
|
|
|
/**
|
2016-08-23 23:47:40 +02:00
|
|
|
* @return \Amp\Parallel\Worker\Worker
|
2015-08-29 03:55:30 +02:00
|
|
|
*/
|
2015-12-12 06:31:50 +01:00
|
|
|
abstract protected function createWorker();
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
public function testIsRunning() {
|
|
|
|
\Amp\execute(function () {
|
2015-12-12 06:31:50 +01:00
|
|
|
$worker = $this->createWorker();
|
2015-08-31 19:57:40 +02:00
|
|
|
$this->assertFalse($worker->isRunning());
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2015-08-31 19:57:40 +02:00
|
|
|
$worker->start();
|
|
|
|
$this->assertTrue($worker->isRunning());
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
yield $worker->shutdown();
|
2015-08-31 19:57:40 +02:00
|
|
|
$this->assertFalse($worker->isRunning());
|
2016-08-19 00:36:58 +02:00
|
|
|
});
|
2015-08-31 19:57:40 +02:00
|
|
|
|
2015-08-29 03:55:30 +02:00
|
|
|
}
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
public function testIsIdleOnStart() {
|
|
|
|
\Amp\execute(function () {
|
2015-12-12 06:31:50 +01:00
|
|
|
$worker = $this->createWorker();
|
2015-08-31 19:57:40 +02:00
|
|
|
$worker->start();
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2015-08-31 19:57:40 +02:00
|
|
|
$this->assertTrue($worker->isIdle());
|
2015-08-29 03:55:30 +02:00
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
yield $worker->shutdown();
|
|
|
|
});
|
2015-08-31 19:57:40 +02:00
|
|
|
|
2015-08-29 03:55:30 +02:00
|
|
|
}
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
public function testEnqueue() {
|
|
|
|
\Amp\execute(function () {
|
2015-12-12 06:31:50 +01:00
|
|
|
$worker = $this->createWorker();
|
2015-08-29 03:55:30 +02:00
|
|
|
$worker->start();
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
$returnValue = yield $worker->enqueue(new TestTask(42));
|
2015-08-29 03:55:30 +02:00
|
|
|
$this->assertEquals(42, $returnValue);
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
yield $worker->shutdown();
|
|
|
|
});
|
2015-08-29 03:55:30 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
public function testEnqueueMultiple() {
|
|
|
|
\Amp\execute(function () {
|
2015-12-12 06:31:50 +01:00
|
|
|
$worker = $this->createWorker();
|
2015-12-12 01:15:15 +01:00
|
|
|
$worker->start();
|
2016-08-19 00:36:58 +02:00
|
|
|
|
|
|
|
$values = yield \Amp\all([
|
|
|
|
$worker->enqueue(new TestTask(42)),
|
|
|
|
$worker->enqueue(new TestTask(56)),
|
|
|
|
$worker->enqueue(new TestTask(72))
|
2016-01-23 07:00:56 +01:00
|
|
|
]);
|
2015-12-12 01:15:15 +01:00
|
|
|
|
|
|
|
$this->assertEquals([42, 56, 72], $values);
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
yield $worker->shutdown();
|
|
|
|
});
|
2015-12-12 01:15:15 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
public function testNotIdleOnEnqueue() {
|
|
|
|
\Amp\execute(function () {
|
2015-12-12 06:31:50 +01:00
|
|
|
$worker = $this->createWorker();
|
2015-08-29 03:55:30 +02:00
|
|
|
$worker->start();
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
$coroutine = $worker->enqueue(new TestTask(42));
|
2015-08-29 03:55:30 +02:00
|
|
|
$this->assertFalse($worker->isIdle());
|
|
|
|
yield $coroutine;
|
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
yield $worker->shutdown();
|
|
|
|
});
|
2015-08-29 03:55:30 +02:00
|
|
|
|
|
|
|
}
|
2015-11-11 09:59:22 +01:00
|
|
|
|
2016-08-19 00:36:58 +02:00
|
|
|
public function testKill() {
|
2015-12-12 06:31:50 +01:00
|
|
|
$worker = $this->createWorker();
|
2015-11-11 09:59:22 +01:00
|
|
|
$worker->start();
|
|
|
|
|
|
|
|
$this->assertRunTimeLessThan([$worker, 'kill'], 0.2);
|
|
|
|
$this->assertFalse($worker->isRunning());
|
|
|
|
}
|
2015-08-29 03:55:30 +02:00
|
|
|
}
|