0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-12-01 09:32:32 +01:00
mongodb/jstests/tool/dumprestoreWithNoOptions.js

114 lines
3.6 KiB
JavaScript

// SERVER-6366
// relates to SERVER-808
//
// This file tests that options are not restored upon
// mongorestore with --noOptionsRestore
//
// It checks that this works both when doing a full
// database dump/restore and when doing it just for a
// single db or collection.
t = new ToolTest("dumprestoreWithNoOptions");
t.startDB("foo");
db = t.db;
dbname = db.getName();
dbname2 = "NOT_" + dbname;
db.dropDatabase();
var defaultFlags = {};
var options = {capped: true, size: 4096, autoIndexId: true};
db.createCollection('capped', options);
assert.eq(1, db.capped.getIndexes().length, "auto index not created");
var cappedOptions = db.capped.exists().options;
for (var opt in options) {
assert.eq(options[opt],
cappedOptions[opt],
'invalid option:' + tojson(options) + " " + tojson(cappedOptions));
}
assert.writeOK(db.capped.insert({x: 1}));
// Full dump/restore
t.runTool("dump", "--out", t.ext);
db.dropDatabase();
assert.eq(0, db.capped.count(), "capped not dropped");
assert.eq(0, db.capped.getIndexes().length, "indexes not dropped");
t.runTool("restore", "--dir", t.ext, "--noOptionsRestore");
assert.eq(1, db.capped.count(), "wrong number of docs restored to capped");
assert(true !== db.capped.stats().capped, "restore options were not ignored");
assert.eq(defaultFlags,
db.capped.exists().options,
"restore options not ignored: " + tojson(db.capped.exists()));
// Dump/restore single DB
db.dropDatabase();
var options = {capped: true, size: 4096, autoIndexId: true};
db.createCollection('capped', options);
assert.eq(1, db.capped.getIndexes().length, "auto index not created");
var cappedOptions = db.capped.exists().options;
for (var opt in options) {
assert.eq(options[opt], cappedOptions[opt], 'invalid option');
}
assert.writeOK(db.capped.insert({x: 1}));
dumppath = t.ext + "noOptionsSingleDump/";
mkdir(dumppath);
t.runTool("dump", "-d", dbname, "--out", dumppath);
db.dropDatabase();
assert.eq(0, db.capped.count(), "capped not dropped");
assert.eq(0, db.capped.getIndexes().length, "indexes not dropped");
t.runTool("restore", "-d", dbname2, "--dir", dumppath + dbname, "--noOptionsRestore");
db = db.getSiblingDB(dbname2);
assert.eq(1, db.capped.count(), "wrong number of docs restored to capped");
assert(true !== db.capped.stats().capped, "restore options were not ignored");
assert.eq(defaultFlags,
db.capped.exists().options,
"restore options not ignored: " + tojson(db.capped.exists()));
// Dump/restore single collection
db.dropDatabase();
var options = {capped: true, size: 4096, autoIndexId: true};
db.createCollection('capped', options);
assert.eq(1, db.capped.getIndexes().length, "auto index not created");
var cappedOptions = db.capped.exists().options;
for (var opt in options) {
assert.eq(options[opt], cappedOptions[opt], 'invalid option');
}
assert.writeOK(db.capped.insert({x: 1}));
dumppath = t.ext + "noOptionsSingleColDump/";
mkdir(dumppath);
dbname = db.getName();
t.runTool("dump", "-d", dbname, "-c", "capped", "--out", dumppath);
db.dropDatabase();
assert.eq(0, db.capped.count(), "capped not dropped");
assert.eq(0, db.capped.getIndexes().length, "indexes not dropped");
t.runTool("restore", "-d", dbname, "--drop", "--noOptionsRestore", dumppath + dbname);
db = db.getSiblingDB(dbname);
assert.eq(1, db.capped.count(), "wrong number of docs restored to capped");
assert(true !== db.capped.stats().capped, "restore options were not ignored");
assert.eq(defaultFlags,
db.capped.exists().options,
"restore options not ignored: " + tojson(db.capped.exists()));
t.stop();