mirror of
https://github.com/mongodb/mongo.git
synced 2024-11-28 16:24:56 +01:00
53 lines
1.7 KiB
JavaScript
53 lines
1.7 KiB
JavaScript
/**
|
|
* this tests some of the ground work
|
|
*/
|
|
|
|
s = new ShardingTest( "shard1" , 2 );
|
|
|
|
db = s.getDB( "test" );
|
|
db.foo.insert( { num : 1 , name : "eliot" } );
|
|
db.foo.insert( { num : 2 , name : "sara" } );
|
|
db.foo.insert( { num : -1 , name : "joe" } );
|
|
db.foo.ensureIndex( { num : 1 } );
|
|
assert.eq( 3 , db.foo.find().length() , "A" );
|
|
|
|
shardCommand = { shardcollection : "test.foo" , key : { num : 1 } };
|
|
|
|
assert.throws( function(){ s.adminCommand( shardCommand ); } );
|
|
|
|
s.adminCommand( { enablesharding : "test" } );
|
|
assert.eq( 3 , db.foo.find().length() , "after partitioning count failed" );
|
|
|
|
s.adminCommand( shardCommand );
|
|
|
|
assert.throws( function(){ s.adminCommand({ shardCollection: 'test', key: { x: 1 }}); });
|
|
assert.throws( function(){ s.adminCommand({ shardCollection: '.foo', key: { x: 1 }}); });
|
|
|
|
cconfig = s.config.collections.findOne( { _id : "test.foo" } );
|
|
assert( cconfig , "why no collection entry for test.foo" )
|
|
delete cconfig.lastmod
|
|
delete cconfig.dropped
|
|
delete cconfig.lastmodEpoch
|
|
assert.eq( cconfig , { _id : "test.foo" , key : { num : 1 } , unique : false } , "Sharded content" );
|
|
|
|
s.config.collections.find().forEach( printjson )
|
|
|
|
assert.eq( 1 , s.config.chunks.count() , "num chunks A");
|
|
si = s.config.chunks.findOne();
|
|
assert( si );
|
|
assert.eq( si.ns , "test.foo" );
|
|
|
|
assert.eq( 3 , db.foo.find().length() , "after sharding, no split count failed" );
|
|
|
|
// SERVER-4284, test modified because of SERVER-5020
|
|
var invalidDB = s.getDB( "foobar" );
|
|
// hack to bypass invalid database name checking at the DB constructor
|
|
invalidDB._name = "foo bar";
|
|
assert.throws(function() {
|
|
invalidDB.blah.insert({ x: 1 });
|
|
});
|
|
assert.isnull( s.config.databases.findOne( { _id : "foo bar" } ) );
|
|
|
|
|
|
s.stop();
|