Viewing File: /opt/alt/tests/alt-php83-pecl-mongodb_1.18.1-1.el8/tests/bug0912-001.phpt
--TEST--
PHPC-912: Child process should not destroy mongoc_client_t objects from parent
--SKIPIF--
<?php if (!function_exists('pcntl_fork')) { die('skip pcntl_fork() not available'); } ?>
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
<?php SLOW(); ?>
<?php skip_if_not_live(); ?>
<?php skip_if_not_clean(); ?>
--FILE--
<?php
require_once __DIR__ . "/../utils/basic.inc";
function logMyURI(MongoDB\Driver\Manager $manager)
{
$command = new MongoDB\Driver\Command(['whatsmyuri' => 1]);
$cursor = $manager->executeCommand(DATABASE_NAME, $command);
$uri = $cursor->toArray()[0]->you;
$bulk = new MongoDB\Driver\BulkWrite();
$bulk->insert(['pid' => getmypid(), 'uri' => $uri]);
$manager->executeBulkWrite(NS, $bulk);
}
$manager = create_test_manager();
logMyURI($manager);
$parentPid = getmypid();
$childPid = pcntl_fork();
if ($childPid === 0) {
$manager = create_test_manager();
logMyURI($manager);
exit;
}
if ($childPid) {
$waitPid = pcntl_waitpid($childPid, $status);
if ($waitPid > 0) {
printf("Parent(%d) waited for child(%d) to exit\n", $parentPid, $waitPid);
}
$cursor = $manager->executeQuery(NS, new MongoDB\Driver\Query([]));
$results = $cursor->toArray();
printf("%d connections were logged\n", count($results));
printf("PIDs differ: %s\n", $results[0]->pid !== $results[1]->pid ? 'yes' : 'no');
printf("URIs differ: %s\n", $results[0]->uri !== $results[1]->uri ? 'yes' : 'no');
}
?>
===DONE===
<?php exit(0); ?>
--EXPECTF--
Parent(%d) waited for child(%d) to exit
2 connections were logged
PIDs differ: yes
URIs differ: yes
===DONE===
Back to Directory
File Manager
<