summaryrefslogtreecommitdiff
path: root/jstests/replsets/rollback_empty_ns.js
diff options
context:
space:
mode:
authormatt dannenberg <matt.dannenberg@10gen.com>2014-05-21 10:45:56 -0400
committermatt dannenberg <matt.dannenberg@10gen.com>2014-05-27 05:32:04 -0400
commit0431673ee0d814d84fe6e42d7c99b94fd24206f9 (patch)
treeb38439be1830b75f630c1e2c599f9e21935cf30d /jstests/replsets/rollback_empty_ns.js
parent63f6ed53137372c8c056d730702278a36a636cd1 (diff)
downloadmongo-0431673ee0d814d84fe6e42d7c99b94fd24206f9.tar.gz
SERVER-13773 more rollback jstests
Diffstat (limited to 'jstests/replsets/rollback_empty_ns.js')
-rw-r--r--jstests/replsets/rollback_empty_ns.js73
1 files changed, 73 insertions, 0 deletions
diff --git a/jstests/replsets/rollback_empty_ns.js b/jstests/replsets/rollback_empty_ns.js
new file mode 100644
index 00000000000..5643fe9fbae
--- /dev/null
+++ b/jstests/replsets/rollback_empty_ns.js
@@ -0,0 +1,73 @@
+// test that a rollback of an op with empty ns causes a message to be logged
+
+// function to check the logs for an entry
+doesEntryMatch = function(array, regex) {
+ var found = false;
+ for (i = 0; i < array.length; i++) {
+ if (regex.test(array[i])) {
+ found = true;
+ }
+ }
+ return found;
+}
+
+// set up a set and grab things for later
+var name = "rollback_empty_ns";
+var replTest = new ReplSetTest({name: name, nodes: 3});
+var nodes = replTest.nodeList();
+var conns = replTest.startSet();
+replTest.initiate({"_id": name,
+ "members": [
+ { "_id": 0, "host": nodes[0], priority: 3 },
+ { "_id": 1, "host": nodes[1] },
+ { "_id": 2, "host": nodes[2], arbiterOnly: true}]
+ });
+var a_conn = conns[0];
+var b_conn = conns[1];
+var AID = replTest.getNodeId(a_conn);
+var BID = replTest.getNodeId(b_conn);
+
+// get master and do an initial write
+var master = replTest.getMaster();
+assert(master === conns[0], "conns[0] assumed to be master");
+assert(a_conn.host === master.host, "a_conn assumed to be master");
+var options = {writeConcern: {w: 2, wtimeout: 60000}, upsert: true};
+assert.writeOK(a_conn.getDB(name).foo.insert({x: 1}, options));
+
+// shut down master
+replTest.stop(AID);
+
+// insert a fake oplog entry with an empty ns
+master = replTest.getMaster();
+assert(b_conn.host === master.host, "b_conn assumed to be master");
+options = {writeConcern: {w: 1, wtimeout: 60000}, upsert: true};
+// another insert to set minvalid ahead
+assert.writeOK(b_conn.getDB(name).foo.insert({x: 123}));
+var oplog_entry = b_conn.getDB("local").oplog.rs.find().sort({$natural: -1})[0];
+oplog_entry["ns"] = "";
+assert.writeOK(b_conn.getDB("local").oplog.rs.insert(oplog_entry));
+
+// shut down B and bring back the original master
+replTest.stop(BID);
+replTest.restart(AID);
+master = replTest.getMaster();
+assert(a_conn.host === master.host, "a_conn assumed to be master");
+
+// do a write so that B will have to roll back
+options = {writeConcern: {w: 1, wtimeout: 60000}, upsert: true};
+assert.writeOK(a_conn.getDB(name).foo.insert({x: 2}, options));
+
+// restart B, which should rollback and log a message about not rolling back empty ns'd oplog entry
+replTest.restart(BID);
+var msg = RegExp("replSet WARNING ignoring op on rollback no ns TODO : ");
+assert.soon(function() {
+ try {
+ var log = b_conn.getDB("admin").adminCommand({getLog: "global"}).log;
+ return doesEntryMatch(log, msg);
+ }
+ catch (e) {
+ return false;
+ }
+}, "Did not see a log entry about skipping the empty ns'd oplog entry during rollback");
+
+replTest.stopSet();