forked from mongodb/mongo-php-driver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcursor-tailable_error-001.phpt
86 lines (70 loc) · 2.08 KB
/
cursor-tailable_error-001.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
78
79
80
81
82
83
84
85
86
--TEST--
MongoDB\Driver\Cursor collection dropped during tailable iteration
--SKIPIF--
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
<?php skip_if_not_live(); ?>
<?php skip_if_not_clean(); ?>
--FILE--
<?php
require_once __DIR__ . "/../utils/basic.inc";
function insert(MongoDB\Driver\Manager $manager, $from, $to = null)
{
if ($to === null) {
$to = $from;
}
$bulkWrite = new MongoDB\Driver\BulkWrite;
for ($i = $from; $i <= $to; $i++) {
$bulkWrite->insert(['_id' => $i]);
}
$writeResult = $manager->executeBulkWrite(NS, $bulkWrite);
printf("Inserted %d document(s): %s\n", $writeResult->getInsertedCount(), implode(', ', range($from, $to)));
}
$manager = create_test_manager();
$manager->executeCommand(DATABASE_NAME, new MongoDB\Driver\Command([
'create' => COLLECTION_NAME,
'capped' => true,
'size' => 1048576,
]));
insert($manager, 1, 3);
echo throws(function() use ($manager) {
$cursor = $manager->executeQuery(NS, new MongoDB\Driver\Query([], ['tailable' => true]));
$it = new IteratorIterator($cursor);
$numAwaitAttempts = 0;
$maxAwaitAttempts = 7;
for ($it->rewind(); $numAwaitAttempts < $maxAwaitAttempts; $it->next()) {
$document = $it->current();
if ($document !== null) {
printf("{_id: %d}\n", $document->_id);
continue;
}
if ($numAwaitAttempts === 2) {
insert($manager, 4, 6);
}
if ($numAwaitAttempts === 5) {
$manager->executeCommand(DATABASE_NAME, new MongoDB\Driver\Command(['drop' => COLLECTION_NAME]));
}
echo "Awaiting results...\n";
$numAwaitAttempts += 1;
}
}, 'MongoDB\Driver\Exception\RuntimeException'), "\n";
?>
===DONE===
<?php exit(0); ?>
--EXPECTF--
Inserted 3 document(s): 1, 2, 3
{_id: 1}
{_id: 2}
{_id: 3}
Awaiting results...
Awaiting results...
Inserted 3 document(s): 4, 5, 6
Awaiting results...
{_id: 4}
{_id: 5}
{_id: 6}
Awaiting results...
Awaiting results...
Awaiting results...
OK: Got MongoDB\Driver\Exception\RuntimeException
%Scollection dropped%S
===DONE===