mirror of
https://github.com/mongodb/mongo.git
synced 2024-11-24 00:17:37 +01:00
771dabd098
GitOrigin-RevId: 744aa110a53786b23c62ff53f87a1418b5991e8d
62 lines
1.9 KiB
JavaScript
62 lines
1.9 KiB
JavaScript
import {ShardingTest} from "jstests/libs/shardingtest.js";
|
|
|
|
var s = new ShardingTest({name: "migrateBig", shards: 2, other: {chunkSize: 1}});
|
|
|
|
assert.commandWorked(
|
|
s.config.settings.update({_id: "balancer"}, {$set: {_waitForDelete: true}}, true));
|
|
assert.commandWorked(s.s0.adminCommand({enablesharding: "test", primaryShard: s.shard1.shardName}));
|
|
assert.commandWorked(s.s0.adminCommand({shardcollection: "test.foo", key: {x: 1}}));
|
|
|
|
var db = s.getDB("test");
|
|
var coll = db.foo;
|
|
|
|
var big = "";
|
|
while (big.length < 10000)
|
|
big += "eliot";
|
|
|
|
var bulk = coll.initializeUnorderedBulkOp();
|
|
for (var x = 0; x < 100; x++) {
|
|
bulk.insert({x: x, big: big});
|
|
}
|
|
assert.commandWorked(bulk.execute());
|
|
|
|
assert.commandWorked(s.s0.adminCommand({split: "test.foo", middle: {x: 30}}));
|
|
assert.commandWorked(s.s0.adminCommand({split: "test.foo", middle: {x: 66}}));
|
|
assert.commandWorked(s.s0.adminCommand(
|
|
{movechunk: "test.foo", find: {x: 90}, to: s.getOther(s.getPrimaryShard("test")).name}));
|
|
|
|
s.printShardingStatus();
|
|
|
|
print("YO : " + s.getPrimaryShard("test").host);
|
|
var direct = new Mongo(s.getPrimaryShard("test").host);
|
|
print("direct : " + direct);
|
|
|
|
var directDB = direct.getDB("test");
|
|
|
|
for (var done = 0; done < 2 * 1024 * 1024; done += big.length) {
|
|
assert.commandWorked(directDB.foo.insert({x: 50 + Math.random(), big: big}));
|
|
}
|
|
|
|
s.printShardingStatus();
|
|
|
|
// This is a large chunk, which should not be able to move
|
|
assert.commandFailed(s.s0.adminCommand(
|
|
{movechunk: "test.foo", find: {x: 50}, to: s.getOther(s.getPrimaryShard("test")).name}));
|
|
|
|
for (var i = 0; i < 20; i += 2) {
|
|
try {
|
|
assert.commandWorked(s.s0.adminCommand({split: "test.foo", middle: {x: i}}));
|
|
} catch (e) {
|
|
// We may have auto split on some of these, which is ok
|
|
print(e);
|
|
}
|
|
}
|
|
|
|
s.printShardingStatus();
|
|
|
|
s.startBalancer();
|
|
|
|
s.awaitBalance('foo', 'test', 60 * 1000);
|
|
|
|
s.stop();
|