HEX
Server: Apache/2.4.59 (Debian)
System: Linux keymana 4.19.0-21-cloud-amd64 #1 SMP Debian 4.19.249-2 (2022-06-30) x86_64
User: lijunjie (1003)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //home/lijunjie/swoole-cli/swoole-src-4.8.13/tests/swoole_lock/mutex_robust.phpt
--TEST--
swoole_lock: mutex robust
--SKIPIF--
<?php
require __DIR__ . '/../include/skipif.inc';
skip("no supports");
?>
--FILE--
<?php
require __DIR__ . '/../include/bootstrap.php';

$file = __DIR__.'/tmp.log';
$fp = fopen($file, 'w+');
$pm = new SwooleTest\ProcessManager;

$pm->parentFunc = function ($pid) use ($pm) {
    $pm->kill();
};

$pm->childFunc = function () use ($pm, $fp) {
    $lock = new Swoole\Lock(SWOOLE_MUTEX);
    $pid = posix_getpid();
    fwrite($fp, "[Master {$pid}]create lock\n");
    $lock->lock();
    $n = 2;
    while ($n--) {
        $process = new Swoole\Process(function ($p) use ($lock, $fp) {
            fwrite($fp, "[Child {$p->pid}] Wait Lock\n");
            $lock->lock();
            fwrite($fp, "[Child {$p->pid}] Get Lock\n");
            $lock->unlock();
            fwrite($fp, "[Child {$p->pid}] exit\n");
        });
        $process->start();
    }
    sleep(30);
    $lock->unlock();
};

$pm->childFirst();
$pm->run();
fclose($fp);
echo file_get_contents($file);
unlink($file);
?>
--EXPECTF--
[Master %d]create lock
[Child %d] Wait Lock
[Child %d] Wait Lock
[Child %d] Get Lock
[Child %d] exit
[Child %d] Get Lock
[Child %d] exit