File: //home/lijunjie/swoole-cli/swoole-src-4.8.13/tests/swoole_server/taskWaitMulti.phpt
--TEST--
swoole_server: taskWaitMulti
--SKIPIF--
<?php require __DIR__ . '/../include/skipif.inc'; ?>
--FILE--
<?php
require __DIR__ . '/../include/bootstrap.php';
$port = get_one_free_port();
use Swoole\Server;
$pm = new SwooleTest\ProcessManager;
$pm->parentFunc = function ($pid) use ($port) {
$cli = new Swoole\Client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_SYNC);
$cli->connect('127.0.0.1', $port, 0.5) or die("ERROR");
$cli->send("task-01") or die("ERROR");
Assert::same($cli->recv(), 'OK');
$cli->send("task-02") or die("ERROR");
Assert::same($cli->recv(), 'OK');
$cli->close();
Swoole\Process::kill($pid);
};
$pm->childFunc = function () use ($pm, $port) {
ini_set('swoole.display_errors', 'Off');
$serv = new Server('127.0.0.1', $port, SWOOLE_PROCESS);
$serv->set(array(
'worker_num' => 1,
'task_worker_num' => 1,
'enable_coroutine' => random_int(0, 100) > 50,
'log_file' => '/dev/null',
));
$serv->on("WorkerStart", function (Server $serv) use ($pm) {
$pm->wakeup();
});
$serv->on('receive', function (Server $serv, $fd, $rid, $data) {
if ($data == 'task-01') {
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$results = $serv->taskWaitMulti($tasks, 2);
} else {
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = mt_rand(1000, 9999);
$tasks[] = 0;
$results = $serv->taskWaitMulti($tasks, 0.2);
}
if (count($results) == 4) {
$serv->send($fd, 'OK');
} else {
$serv->send($fd, 'ERR');
}
});
$serv->on('task', function (Server $serv, $task_id, $worker_id, $data) {
if ($data == 0) {
usleep(300000);
}
return $data;
});
$serv->on('finish', function (Server $serv, $fd, $rid, $data) {
});
$serv->start();
};
$pm->childFirst();
$pm->run();
?>
--EXPECT--