108 lines
2.5 KiB
PHP
Executable File
108 lines
2.5 KiB
PHP
Executable File
--TEST--
|
|
swoole_server: send message [02]
|
|
--SKIPIF--
|
|
<?php require __DIR__ . '/../include/skipif.inc'; ?>
|
|
--INI--
|
|
assert.active=1
|
|
assert.warning=1
|
|
assert.bail=0
|
|
assert.quiet_eval=0
|
|
|
|
--FILE--
|
|
<?php
|
|
require_once __DIR__ . '/../include/bootstrap.php';
|
|
require_once __DIR__ . '/../include/swoole.inc';
|
|
$pm = new ProcessManager;
|
|
|
|
$pm->parentFunc = function ($pid) use ($pm)
|
|
{
|
|
$client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_SYNC);
|
|
$client->set([
|
|
'package_eof' => "\r\n",
|
|
'open_eof_check' => true,
|
|
'open_eof_split' => true,
|
|
]);
|
|
if (!$client->connect('127.0.0.1', 9501))
|
|
{
|
|
exit("connect failed\n");
|
|
}
|
|
$list = [];
|
|
for ($i = 0; $i < 7; $i++)
|
|
{
|
|
$data = $client->recv();
|
|
if ($data === false or $data === '')
|
|
{
|
|
echo "ERROR\n";
|
|
break;
|
|
}
|
|
$list[] = intval($data);
|
|
}
|
|
sort($list);
|
|
assert($list == range(0, 6));
|
|
$pm->kill();
|
|
};
|
|
|
|
$pm->childFunc = function () use ($pm)
|
|
{
|
|
$serv = new swoole_server("127.0.0.1", 9501, SWOOLE_PROCESS, SWOOLE_SOCK_TCP );
|
|
$serv->set([
|
|
'log_file' => '/dev/null',
|
|
'worker_num' => 4,
|
|
'task_worker_num' => 3,
|
|
]);
|
|
|
|
$lock = new swoole\lock();
|
|
|
|
$process = new \Swoole\Process(function ($process) use ($serv) {
|
|
while (true)
|
|
{
|
|
$r = $process->read();
|
|
if (!$r)
|
|
{
|
|
continue;
|
|
}
|
|
$cmd = json_decode($r, true);
|
|
for ($i = 0; $i < ($serv->setting['worker_num'] + $serv->setting['task_worker_num']); $i++)
|
|
{
|
|
$serv->sendMessage(['worker_id' => $i, 'fd' => $cmd['fd']], $i);
|
|
}
|
|
}
|
|
});
|
|
|
|
$serv->addProcess($process);
|
|
$serv->on("workerStart", function ($serv) use ($pm)
|
|
{
|
|
$pm->wakeup();
|
|
});
|
|
$serv->on('connect', function (swoole_server $serv, $fd) use ($process) {
|
|
$process->write(json_encode(["fd" => $fd]));
|
|
});
|
|
$serv->on('receive', function ($serv, $fd, $from_id, $data) {
|
|
|
|
});
|
|
|
|
$serv->on('pipeMessage', function (swoole_server $serv, $worker_id, $data) use ($lock) {
|
|
//$lock->lock();
|
|
$serv->send($data['fd'], $data['worker_id']."\r\n");
|
|
//$lock->unlock();
|
|
});
|
|
|
|
$serv->on('task', function (swoole_server $serv, $task_id, $worker_id, $data)
|
|
{
|
|
|
|
});
|
|
|
|
$serv->on('finish', function (swoole_server $serv, $fd, $rid, $data)
|
|
{
|
|
|
|
});
|
|
|
|
$serv->start();
|
|
};
|
|
|
|
|
|
$pm->childFirst();
|
|
$pm->run();
|
|
?>
|
|
--EXPECT--
|