File: bug00647.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 (30 lines) | stat: -rw-r--r-- 984 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
--TEST--
Test for PHP-647: Queries should not be sent to recovering secondaries
--SKIPIF--
<?php echo "skip Manual test until it gets fixed"; ?>
<?php require_once dirname(__FILE__) . "/skipif.inc"; ?>
--INI--
mongo.is_master_interval=1
--FILE--
<?php
require_once "tests/utils/server.inc";

$m = mongo();
$m->setReadPreference(MongoClient::RP_SECONDARY_PREFERRED);

$explain = $m->selectCollection(dbname(), 'test')->find()->explain();
var_dump($explain['server'] === "$REPLICASET_SECONDARY:$REPLICASET_SECONDARY_PORT");

set_maintenance("$REPLICASET_SECONDARY:$REPLICASET_SECONDARY_PORT", true);

// Wait a full isMaster cycle so the driver acknowledges the new RS state
sleep(2 * ini_get('mongo.is_master_interval'));

$explain = $m->selectCollection(dbname(), 'test')->find()->explain();
var_dump($explain['server'] === "$REPLICASET_PRIMARY:$REPLICASET_PRIMARY_PORT");

set_maintenance("$REPLICASET_SECONDARY:$REPLICASET_SECONDARY_PORT", false);

--EXPECT--
bool(true)
bool(true)