106 lines
3.3 KiB
JavaScript
106 lines
3.3 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 options = { capped: true, size: 1000, autoIndexId: true };
|
|
db.createCollection('capped', options);
|
|
assert.eq( 1, db.system.indexes.count(), "auto index not created" );
|
|
var cappedOptions = db.capped.exists().options;
|
|
for ( var opt in options ) {
|
|
assert.eq(options[opt], cappedOptions[opt], 'invalid option')
|
|
}
|
|
db.capped.insert({ x: 1 });
|
|
db.getLastError()
|
|
|
|
// Full dump/restore
|
|
|
|
t.runTool( "dump" , "--out" , t.ext );
|
|
|
|
db.dropDatabase();
|
|
assert.eq( 0, db.capped.count(), "capped not dropped");
|
|
assert.eq( 0, db.system.indexes.count(), "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(undefined === db.capped.exists().options, "restore options not ignored");
|
|
|
|
// Dump/restore single DB
|
|
|
|
db.dropDatabase();
|
|
var options = { capped: true, size: 1000, autoIndexId: true };
|
|
db.createCollection('capped', options);
|
|
assert.eq( 1, db.system.indexes.count(), "auto index not created" );
|
|
var cappedOptions = db.capped.exists().options;
|
|
for ( var opt in options ) {
|
|
assert.eq(options[opt], cappedOptions[opt], 'invalid option')
|
|
}
|
|
db.capped.insert({ x: 1 });
|
|
db.getLastError()
|
|
|
|
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.system.indexes.count(), "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(undefined === db.capped.exists().options, "restore options not ignored");
|
|
|
|
// Dump/restore single collection
|
|
|
|
db.dropDatabase();
|
|
var options = { capped: true, size: 1000, autoIndexId: true };
|
|
db.createCollection('capped', options);
|
|
assert.eq( 1, db.system.indexes.count(), "auto index not created" );
|
|
var cappedOptions = db.capped.exists().options;
|
|
for ( var opt in options ) {
|
|
assert.eq(options[opt], cappedOptions[opt], 'invalid option')
|
|
}
|
|
db.capped.insert({ x: 1 });
|
|
db.getLastError()
|
|
|
|
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.system.indexes.count(), "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( undefined === db.capped.exists().options );
|
|
|
|
t.stop();
|