0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-30 00:56:44 +01:00
mongodb/jstests/replsets/maintenance_non-blocking.js
Vesselina Ratcheva 34dc015fcb SERVER-45610 Reject commands that read data when node is in RECOVERING state
This reverts commit 542de84ec1.

 create mode 100644 jstests/libs/all_commands_test.js
 create mode 100644 jstests/replsets/db_reads_while_recovering_all_commands.js
2020-02-18 18:27:39 +00:00

52 lines
1.6 KiB
JavaScript

// This test ensures that the replSetMaintenance command will not block, nor block-on, a db write
doTest = function() {
"use strict";
var replTest = new ReplSetTest({name: 'testSet', nodes: 2});
var nodes = replTest.startSet();
replTest.initiate();
var m = replTest.getPrimary();
var mColl = m.getDB("test").maint;
var s = replTest.getSecondary();
var sDB = s.getDB("test");
var sColl = sDB.maint;
var status = assert.commandWorked(sDB.adminCommand("replSetGetStatus"));
printjson(status);
print("******* fsyncLock'n secondary ************* ");
s.getDB("admin").fsyncLock();
// save some records
var len = 100;
for (var i = 0; i < len; ++i) {
assert.commandWorked(mColl.save({a: i}));
}
print("******* replSetMaintenance called on secondary ************* ");
assert.commandWorked(sDB.adminCommand("replSetMaintenance"));
var ismaster = assert.commandWorked(sColl.runCommand("ismaster"));
assert.eq(false, ismaster.ismaster);
assert.eq(false, ismaster.secondary);
print("******* writing to primary ************* ");
assert.commandWorked(mColl.save({_id: -1}));
printjson(sDB.currentOp());
assert.neq(null, mColl.findOne());
var ismaster = assert.commandWorked(sColl.runCommand("ismaster"));
assert.eq(false, ismaster.ismaster);
assert.eq(false, ismaster.secondary);
print("******* fsyncUnlock'n secondary ************* ");
sDB.fsyncUnlock();
print("******* unset replSetMaintenance on secondary ************* ");
assert.commandWorked(sDB.adminCommand({replSetMaintenance: 0}));
replTest.stopSet();
};
doTest();
print("SUCCESS");