-
Notifications
You must be signed in to change notification settings - Fork 3.2k
/
Copy pathreload_process.phpt
77 lines (74 loc) · 2.39 KB
/
reload_process.phpt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
--TEST--
swoole_server: reload in process mode
--SKIPIF--
<?php
require __DIR__ . '/../include/skipif.inc';
//skip_if_in_valgrind();
?>
--FILE--
<?php
require __DIR__ . '/../include/bootstrap.php';
$worker_num = $task_worker_num = swoole_cpu_num() * 2;
$counter = [
'worker' => new Swoole\Atomic(),
'task_worker' => new Swoole\Atomic()
];
$pm = new SwooleTest\ProcessManager;
$pm->parentFunc = function () use ($pm) {
global $counter, $worker_num, $task_worker_num;
while (!file_exists(TEST_PID_FILE)) {
usleep(100 * 1000);
}
$pid = file_get_contents(TEST_PID_FILE);
$random = mt_rand(1, 4);
usleep(100 * 1000);
for ($n = $random; $n--;) {
Swoole\Process::kill($pid, SIGUSR1);
usleep(500 * 1000);
Swoole\Process::kill($pid, SIGUSR2);
usleep(500 * 1000);
}
/**@var $counter Swoole\Atomic[] */
$total = $counter['worker']->get() - $worker_num;
$expect = $random * $worker_num;
Assert::same($total, $expect, "[worker reload {$total} but expect {$expect}]");
$total = $counter['task_worker']->get() - $task_worker_num;
$expect = $random * $task_worker_num * 2;
Assert::same($total, $expect, "[task worker reload {$total} but expect {$expect}]");
$log = file_get_contents(TEST_LOG_FILE);
$log = trim(preg_replace('/.+?\s+?INFO\s+?.+/', '', $log));
if (!Assert::assert(empty($log))){
var_dump($log);
}
$pm->kill();
echo "DONE\n";
};
$pm->childFunc = function () use ($pm) {
global $worker_num, $task_worker_num;
@unlink(TEST_LOG_FILE);
@unlink(TEST_PID_FILE);
$server = new Swoole\Server('127.0.0.1', $pm->getFreePort(), SWOOLE_PROCESS);
$server->set([
'log_file' => TEST_LOG_FILE,
'pid_file' => TEST_PID_FILE,
'worker_num' => $worker_num,
'task_worker_num' => $task_worker_num
]);
$server->on('ManagerStart', function () use ($pm) {
$pm->wakeup();
});
$server->on('WorkerStart', function (Swoole\Server $server, int $worker_id) use ($pm) {
/**@var $counter Swoole\Atomic[] */
global $counter;
$atomic = $server->taskworker ? $counter['task_worker'] : $counter['worker'];
$atomic->add(1);
});
$server->on('Receive', function (Swoole\Server $server, $fd, $reactor_id, $data) { });
$server->on('Task', function () { });
$server->start();
};
$pm->childFirst();
$pm->run();
?>
--EXPECT--
DONE