forked from mongodb/mongo-php-driver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcursor-tailable-001.phpt
87 lines (71 loc) · 1.82 KB
/
cursor-tailable-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
87
--TEST--
MongoDB\Driver\Cursor 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);
$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) {
insert($manager, 7, 9);
}
echo "Awaiting results...\n";
$numAwaitAttempts += 1;
}
?>
===DONE===
<?php exit(0); ?>
--EXPECT--
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...
Inserted 3 document(s): 7, 8, 9
Awaiting results...
{_id: 7}
{_id: 8}
{_id: 9}
Awaiting results...
===DONE===