File: mongocursor-kill-cursors.phpt

package info (click to toggle)
php-mongo 1.5.7-1
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 11,040 kB
  • ctags: 2,802
  • sloc: ansic: 17,632; xml: 2,195; php: 1,630; pascal: 330; makefile: 52; sh: 39
file content (48 lines) | stat: -rw-r--r-- 3,284 bytes parent folder | download
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
--TEST--
Test for killing cursors when they haven't been exhausted.
--SKIPIF--
<?php require_once "tests/utils/standalone.inc"; ?>
--FILE--
<?php
require_once "tests/utils/server.inc";

set_error_handler('foo');function foo($code, $message) { echo $message, "\n"; }
MongoLog::setLevel(MongoLog::WARNING);
MongoLog::setModule(MongoLog::IO);
$m = mongo_standalone();
$d = $m->phpunit;
$c = $d->killcursors;
$c->drop();

for ($i = 0; $i < 1000; $i++) {
	$c->insert(array( '_id' => "d{$i}", 'v' => log(($i * 10) + 10) ), array( 'w' => true ) );
}

$tries = array(
	/* Those three should show the "kill cursors" as they are done all in the first round trip */
	1, 2, 101,
	/* These three shouldn't show it, as elements 102-1000 are returned with the second round trip */
	102, 999, 1000
);

foreach ($tries as $try) {
	$cur = $c->find();

	for ($i = 0; $i < $try; $i++) {
		$cur->getNext();
		echo ".";
	}
	echo "\n";
	$cur = null;
}
?>
--EXPECTF--
.
IO      WARN: Killing unfinished cursor %d
..
IO      WARN: Killing unfinished cursor %d
.....................................................................................................
IO      WARN: Killing unfinished cursor %d
......................................................................................................
.......................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................
........................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................