File: mongocursor-construct_error-001.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 (35 lines) | stat: -rw-r--r-- 1,064 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
--TEST--
MongoCursor::__construct() error with non-string field names in projection argument
--SKIPIF--
<?php require_once "tests/utils/standalone.inc" ?>
--FILE--
<?php
require_once "tests/utils/server.inc";

$host = MongoShellServer::getStandaloneInfo();
$mc = new MongoClient($host);

$collection = $mc->selectCollection(dbname(), collname(__FILE__));

$collection->drop();
$collection->insert(array('0' => 'zero', '1' => 'one'));

/* By coincidence, this legitimate $fields argument is indistinguishable from a
 * numeric array. Legacy behavior requires us to throw an exception, but this
 * test can be changed to no longer expect an exception once we finally remove
 * the legacy behavior.
 *
 * The work-around entails casting $fields to an object, which we do in a
 * related tests for MongoCursor::__construct().
 */
try {
    $document = $collection->findOne(array(), array('0' => 1));
    var_dump($document);
} catch (MongoException $e) {
    var_dump($e->getMessage(), $e->getCode());
}

?>
--EXPECTF--
string(27) "field names must be strings"
int(8)