__quiet = false; __magicNoPrint = { __magicNoPrint : 1111 } chatty = function(s){ if ( ! __quiet ) print( s ); } friendlyEqual = function( a , b ){ if ( a == b ) return true; if ( tojson( a ) == tojson( b ) ) return true; return false; } doassert = function (msg) { if (msg.indexOf("assert") == 0) print(msg); else print("assert: " + msg); throw msg; } assert = function( b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( b ) return; doassert( msg == undefined ? "assert failed" : "assert failed : " + msg ); } assert.automsg = function( b ) { assert( eval( b ), b ); } assert._debug = false; assert.eq = function( a , b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( a == b ) return; if ( ( a != null && b != null ) && friendlyEqual( a , b ) ) return; doassert( "[" + tojson( a ) + "] != [" + tojson( b ) + "] are not equal : " + msg ); } assert.eq.automsg = function( a, b ) { assert.eq( eval( a ), eval( b ), "[" + a + "] != [" + b + "]" ); } assert.neq = function( a , b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( a != b ) return; doassert( "[" + a + "] != [" + b + "] are equal : " + msg ); } assert.repeat = function( f, msg, timeout, interval ) { if ( assert._debug && msg ) print( "in assert for: " + msg ); var start = new Date(); timeout = timeout || 30000; interval = interval || 200; var last; while( 1 ) { if ( typeof( f ) == "string" ){ if ( eval( f ) ) return; } else { if ( f() ) return; } if ( ( new Date() ).getTime() - start.getTime() > timeout ) break; sleep( interval ); } } assert.soon = function( f, msg, timeout, interval ) { if ( assert._debug && msg ) print( "in assert for: " + msg ); var start = new Date(); timeout = timeout || 30000; interval = interval || 200; var last; while( 1 ) { if ( typeof( f ) == "string" ){ if ( eval( f ) ) return; } else { if ( f() ) return; } if ( ( new Date() ).getTime() - start.getTime() > timeout ) doassert( "assert.soon failed: " + f + ", msg:" + msg ); sleep( interval ); } } assert.throws = function( func , params , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); try { func.apply( null , params ); } catch ( e ){ return e; } doassert( "did not throw exception: " + msg ); } assert.throws.automsg = function( func, params ) { assert.throws( func, params, func.toString() ); } assert.commandWorked = function( res , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( res.ok == 1 ) return; doassert( "command failed: " + tojson( res ) + " : " + msg ); } assert.commandFailed = function( res , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( res.ok == 0 ) return; doassert( "command worked when it should have failed: " + tojson( res ) + " : " + msg ); } assert.isnull = function( what , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( what == null ) return; doassert( "supposed to null (" + ( msg || "" ) + ") was: " + tojson( what ) ); } assert.lt = function( a , b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( a < b ) return; doassert( a + " is not less than " + b + " : " + msg ); } assert.gt = function( a , b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( a > b ) return; doassert( a + " is not greater than " + b + " : " + msg ); } assert.lte = function( a , b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( a <= b ) return; doassert( a + " is not less than or eq " + b + " : " + msg ); } assert.gte = function( a , b , msg ){ if ( assert._debug && msg ) print( "in assert for: " + msg ); if ( a >= b ) return; doassert( a + " is not greater than or eq " + b + " : " + msg ); } assert.close = function( a , b , msg , places ){ if (places === undefined) { places = 4; } if (Math.round((a - b) * Math.pow(10, places)) === 0) { return; } doassert( a + " is not equal to " + b + " within " + places + " places, diff: " + (a-b) + " : " + msg ); }; Object.extend = function( dst , src , deep ){ for ( var k in src ){ var v = src[k]; if ( deep && typeof(v) == "object" ){ v = Object.extend( typeof ( v.length ) == "number" ? [] : {} , v , true ); } dst[k] = v; } return dst; } argumentsToArray = function( a ){ var arr = []; for ( var i=0; i>>>>>>>>>>>>>> skipping " + x.name); return; } params[ i % n ].push( x.name ); ++i; } ); // randomize ordering of the serialTests params[ 0 ] = Array.shuffle( params[ 0 ] ); for( var i in params ) { params[ i ].unshift( i ); } return params; } // runs a set of test files // first argument is an identifier for this tester, remaining arguments are file names ParallelTester.fileTester = function() { var args = argumentsToArray( arguments ); var suite = args.shift(); args.forEach( function( x ) { print(" S" + suite + " Test : " + x + " ..."); var time = Date.timeFunc( function() { load(x); }, 1); print(" S" + suite + " Test : " + x + " " + time + "ms" ); } ); } // params: array of arrays, each element of which consists of a function followed // by zero or more arguments to that function. Each function and its arguments will // be called in a separate thread. // msg: failure message // newScopes: if true, each thread starts in a fresh scope assert.parallelTests = function( params, msg, newScopes ) { newScopes = newScopes || false; var wrapper = function( fun, argv ) { eval ( "var z = function() {" + "var __parallelTests__fun = " + fun.toString() + ";" + "var __parallelTests__argv = " + tojson( argv ) + ";" + "var __parallelTests__passed = false;" + "try {" + "__parallelTests__fun.apply( 0, __parallelTests__argv );" + "__parallelTests__passed = true;" + "} catch ( e ) {" + "print( e );" + "}" + "return __parallelTests__passed;" + "}" ); return z; } var runners = new Array(); for( var i in params ) { var param = params[ i ]; var test = param.shift(); var t; if ( newScopes ) t = new ScopedThread( wrapper( test, param ) ); else t = new Thread( wrapper( test, param ) ); runners.push( t ); } runners.forEach( function( x ) { x.start(); } ); var nFailed = 0; // v8 doesn't like it if we exit before all threads are joined (SERVER-529) runners.forEach( function( x ) { if( !x.returnData() ) { ++nFailed; } } ); assert.eq( 0, nFailed, msg ); } } tojsononeline = function( x ){ return tojson( x , " " , true ); } tojson = function( x, indent , nolint ){ if ( x === null ) return "null"; if ( x === undefined ) return "undefined"; if (!indent) indent = ""; switch ( typeof x ) { case "string": { var s = "\""; for ( var i=0; i:28017/_replSet for additional diagnostic info"); } rs.slaveOk = function () { return db.getMongo().setSlaveOk(); } rs.status = function () { return db._adminCommand("replSetGetStatus"); } rs.isMaster = function () { return db.isMaster(); } rs.initiate = function (c) { return db._adminCommand({ replSetInitiate: c }); } rs.reconfig = function(cfg) { cfg.version = rs.conf().version + 1; return db._adminCommand({ replSetReconfig: cfg }); } rs.add = function (hostport, arb) { var cfg = hostport; var local = db.getSisterDB("local"); assert(local.system.replset.count() <= 1, "error: local.system.replset has unexpected contents"); var c = local.system.replset.findOne(); assert(c, "no config object retrievable from local.system.replset"); c.version++; var max = 0; for (var i in c.members) if (c.members[i]._id > max) max = c.members[i]._id; if (isString(hostport)) { cfg = { _id: max + 1, host: hostport }; if (arb) cfg.arbiterOnly = true; } c.members.push(cfg); return db._adminCommand({ replSetReconfig: c }); } rs.stepDown = function () { return db._adminCommand({ replSetStepDown:true}); } rs.addArb = function (hn) { return this.add(hn, true); } rs.conf = function () { return db.getSisterDB("local").system.replset.findOne(); } rs.remove = function (hn) { var local = db.getSisterDB("local"); assert(local.system.replset.count() <= 1, "error: local.system.replset has unexpected contents"); var c = local.system.replset.findOne(); assert(c, "no config object retrievable from local.system.replset"); c.version++; for (var i in c.members) { if (c.members[i].host == hn) { c.members.splice(i, 1); return db._adminCommand({ replSetReconfig : c}); } } return "error: couldn't find "+hn+" in "+tojson(c.members); }; help = shellHelper.help = function (x) { if (x == "connect") { print("\nNormally one specifies the server on the mongo shell command line. Run mongo --help to see those options."); print("Additional connections may be opened:\n"); print(" var x = new Mongo('host[:port]');"); print(" var mydb = x.getDB('mydb');"); print(" or"); print(" var mydb = connect('host[:port]/mydb');"); print("\nNote: the REPL prompt only auto-reports getLastError() for the shell command line connection.\n"); return; } if (x == "misc") { print("\tb = new BinData(subtype,base64str) create a BSON BinData value"); print("\tb.subtype() the BinData subtype (0..255)"); print("\tb.length() length of the BinData data in bytes"); print("\tb.hex() the data as a hex encoded string"); print("\tb.base64() the data as a base 64 encoded string"); print("\tb.toString()"); return; } if (x == "admin") { print("\tls([path]) list files"); print("\tpwd() returns current directory"); print("\tlistFiles([path]) returns file list"); print("\thostname() returns name of this host"); print("\tcat(fname) returns contents of text file as a string"); print("\tremoveFile(f) delete a file"); print("\tload(jsfilename) load and execute a .js file"); print("\trun(program[, args...]) spawn a program and wait for its completion"); print("\tsleep(m) sleep m milliseconds"); print("\tgetMemInfo() diagnostic"); return; } if (x == "test") { print("\tstartMongodEmpty(args) DELETES DATA DIR and then starts mongod"); print("\t returns a connection to the new server"); print("\tstartMongodTest() DELETES DATA DIR"); print("\t automatically picks port #s starting at 27000 and increasing"); print("\t or you can specify the port as the first arg"); print("\t dir is /data/db// if not specified as the 2nd arg"); print("\t returns a connection to the new server"); return; } print("\t" + "db.help() help on db methods"); print("\t" + "db.mycoll.help() help on collection methods"); print("\t" + "rs.help() help on replica set methods"); print("\t" + "help connect connecting to a db help"); print("\t" + "help admin administrative help"); print("\t" + "help misc misc things to know"); print(); print("\t" + "show dbs show database names"); print("\t" + "show collections show collections in current database"); print("\t" + "show users show users in current database"); print("\t" + "show profile show most recent system.profile entries with time >= 1ms"); print("\t" + "use set current database"); print("\t" + "db.foo.find() list objects in collection foo"); print("\t" + "db.foo.find( { a : 1 } ) list objects in foo where a == 1"); print("\t" + "it result of the last line evaluated; use to further iterate"); print("\t" + "exit quit the mongo shell"); }