Files
mongo/jstests/replsets/rslib.js
Eliot Horowitz 336a1db691 better debugging
2011-04-27 00:09:07 -04:00

104 lines
2.0 KiB
JavaScript

var count = 0;
var w = 0;
var wait = function(f,msg) {
w++;
var n = 0;
while (!f()) {
if( n % 4 == 0 )
print("waiting " + w);
if (++n == 4) {
print("" + f);
}
assert(n < 200, 'tried 200 times, giving up on ' + msg );
sleep(1000);
}
};
/**
* Use this to do something once every 4 iterations.
*
* <pre>
* for (i=0; i<1000; i++) {
* occasionally(function() { print("4 more iterations"); });
* }
* </pre>
*/
var occasionally = function(f, n) {
var interval = n || 4;
if (count % interval == 0) {
f();
}
count++;
};
var reconnect = function(a) {
wait(function() {
try {
// make this work with either dbs or connections
if (typeof(a.getDB) == "function") {
a.getDB("foo").bar.stats();
}
else {
a.bar.stats();
}
return true;
} catch(e) {
print(e);
return false;
}
});
};
var getLatestOp = function(server) {
server.getDB("admin").getMongo().setSlaveOk();
var log = server.getDB("local")['oplog.rs'];
var cursor = log.find({}).sort({'$natural': -1}).limit(1);
if (cursor.hasNext()) {
return cursor.next();
}
return null;
};
var waitForAllMembers = function(master) {
var ready = false;
var count = 0;
outer:
while (count < 60) {
count++;
var state = master.getSisterDB("admin").runCommand({replSetGetStatus:1});
occasionally(function() { printjson(state); }, 10);
for (var m in state.members) {
if (state.members[m].state != 2 && state.members[m].state != 1) {
sleep(1000);
continue outer;
}
}
return;
}
assert(false, "all members not ready");
};
var reconfig = function(rs, config) {
var admin = rs.getMaster().getDB("admin");
try {
var ok = admin.runCommand({replSetReconfig : config});
assert.eq(ok.ok,1);
}
catch(e) {
print(e);
}
master = rs.getMaster().getDB("admin");
waitForAllMembers(master);
return master;
};