File: writeconcernerror-getinfo-001.phpt

package info (click to toggle)
php-mongodb 1.15.0%2B1.11.1%2B1.9.2%2B1.7.5-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 63,984 kB
  • sloc: ansic: 328,429; xml: 10,797; php: 4,235; sh: 179; python: 47; pascal: 36; makefile: 3
file content (64 lines) | stat: -rw-r--r-- 1,734 bytes parent folder | download | duplicates (2)
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
--TEST--
MongoDB\Driver\WriteConcernError::getInfo() exposes writeConcernError.errInfo
--DESCRIPTION--
CRUD spec prose test #1
https://github.com/mongodb/specifications/blob/master/source/crud/tests/README.rst#writeconcernerror-details-exposes-writeconcernerror-errinfo
--SKIPIF--
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
<?php skip_if_not_replica_set(); ?>
<?php skip_if_no_failcommand_failpoint(); ?>
<?php skip_if_not_clean(); ?>
--FILE--
<?php
require_once __DIR__ . "/../utils/basic.inc";

$manager = create_test_manager();

// Select a specific server for future operations to avoid mongos switching in sharded clusters
$server = $manager->selectServer(new MongoDB\Driver\ReadPreference('primary'));

configureTargetedFailPoint(
    $server,
    'failCommand',
    [ 'times' => 1],
    [
        'failCommands' => ['insert'],
        'writeConcernError' => [
            'code' => 100,
            'codeName' => 'UnsatisfiableWriteConcern',
            'errmsg' => 'Not enough data-bearing nodes',
            'errInfo' => [
                'writeConcern' => [
                    'w' => 2,
                    'wtimeout' => 0,
                    'provenance' => 'clientSupplied',
                ],
            ],
        ],
    ]
);

$bulk = new MongoDB\Driver\BulkWrite;
$bulk->insert(['_id' => 1]);

try {
    $server->executeBulkWrite(NS, $bulk);
} catch (MongoDB\Driver\Exception\BulkWriteException $e) {
    var_dump($e->getWriteResult()->getWriteConcernError()->getInfo());
}

?>
===DONE===
--EXPECTF--
object(stdClass)#%d (%d) {
  ["writeConcern"]=>
  object(stdClass)#%d (%d) {
    ["w"]=>
    int(2)
    ["wtimeout"]=>
    int(0)
    ["provenance"]=>
    string(14) "clientSupplied"
  }
}
===DONE===