0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-28 16:24:56 +01:00
mongodb/jstests/sharding/hash_basic.js
Greg Studer e88273ac94 SERVER-1424 (re)smoke tag parsing and new test library, v0
Includes:
- Smoke.py options for filtering by jstest tags
- New resmoke.py test utility in v0 alpha
- Lots of example resmoke configurations
- SCons integration for unittests
- Sample tagged jstests
2014-09-18 14:37:45 -04:00

92 lines
3.1 KiB
JavaScript

/**
* @tags : [ hashed ]
*/
var st = new ShardingTest({ shards: 2, chunkSize: 1, other: { shardOptions: { verbose: 1 }} });
st.stopBalancer();
var testDB = st.s.getDB('test');
testDB.adminCommand({ enableSharding: 'test' });
testDB.adminCommand({ shardCollection: 'test.user', key: { x: 'hashed' }});
var configDB = st.s.getDB('config');
var chunkCountBefore = configDB.chunks.count();
assert.gt(chunkCountBefore, 1);
for (var x = 0; x < 1000; x++) {
testDB.user.insert({ x: x });
}
// For debugging
(function() {
var chunkList = configDB.chunks.find().sort({ min: -1 }).toArray();
chunkList.forEach(function(chunk) { chunk.count = 0; });
for (var x = 0; x < 1000; x++) {
var hashVal = testDB.adminCommand({ _hashBSONElement: x }).out;
var countSet = false;
for (var y = 0; y < chunkList.length - 2; y++) {
var chunkDoc = chunkList[y];
if (chunkDoc.min.x <= hashVal) {
countSet = true;
chunkDoc.count++;
print('doc in chunk: x [' + x + '], h[' + hashVal +
'], min[' + chunkDoc.min.x +
'], max[' + chunkDoc.max.x + ']');
break;
}
}
if (!countSet) {
chunkDoc = chunkList[chunkList.length - 1];
print('doc in chunk: x [' + x + '], h[' + hashVal +
'], min[' + chunkDoc.min.x +
'], max[' + chunkDoc.max.x + ']');
chunkDoc.count++;
}
}
chunkList.forEach(function(chunkDoc) {
print('chunk details: ' + tojson(chunkDoc));
});
});
var chunkDoc = configDB.chunks.find().sort({ min: 1 }).next();
var min = chunkDoc.min;
var max = chunkDoc.max;
// Assumption: There are documents in the MinKey chunk, otherwise, splitVector will
// fail. Note: This chunk will have 267 documents if collection was presplit to 4.
var cmdRes = testDB.adminCommand({ split: 'test.user', bounds: [ min, max ]});
assert(cmdRes.ok, 'split on bounds failed on chunk[' + tojson(chunkDoc) +
']: ' + tojson(cmdRes));
chunkDoc = configDB.chunks.find().sort({ min: 1 }).skip(1).next();
var middle = chunkDoc.min + 1000000;
cmdRes = testDB.adminCommand({ split: 'test.user', middle: { x: middle }});
assert(cmdRes.ok, 'split failed with middle [' + middle + ']: ' + tojson(cmdRes));
cmdRes = testDB.adminCommand({ split: 'test.user', find: { x: 7 }});
assert(cmdRes.ok, 'split failed with find: ' + tojson(cmdRes));
var chunkList = configDB.chunks.find().sort({ min: 1 }).toArray();
assert.eq(chunkCountBefore + 3, chunkList.length);
chunkList.forEach(function(chunkToMove) {
var toShard = configDB.shards.findOne({ _id: { $ne: chunkToMove.shard }})._id;
print(jsTestName() + " - moving chunk " + chunkToMove._id + " from shard " +
chunkToMove.shard + " to " + toShard + "...");
var cmdRes = testDB.adminCommand({ moveChunk: 'test.user',
bounds: [ chunkToMove.min, chunkToMove.max ],
to: toShard, _waitForDelete: true });
print(jsTestName() + " - result from moving chunk " + chunkToMove._id + ": " +
tojson(cmdRes));
});
st.stop();