// 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();