mirror of
https://github.com/mongodb/mongo.git
synced 2024-11-24 00:17:37 +01:00
771dabd098
GitOrigin-RevId: 744aa110a53786b23c62ff53f87a1418b5991e8d
57 lines
1.5 KiB
JavaScript
57 lines
1.5 KiB
JavaScript
|
|
import {ShardingTest} from "jstests/libs/shardingtest.js";
|
|
|
|
function debug(str) {
|
|
print("---\n" + str + "\n-----");
|
|
}
|
|
|
|
var name = "badNonUpdate";
|
|
debug("Starting sharded cluster test stuff");
|
|
|
|
var s = new ShardingTest({name: name, shards: 2, mongos: 2});
|
|
|
|
var mongosA = s.s0;
|
|
var mongosB = s.s1;
|
|
|
|
let ns = "test.coll";
|
|
|
|
let adminSA = mongosA.getDB("admin");
|
|
adminSA.runCommand({enableSharding: "test", primaryShard: s.shard0.shardName});
|
|
adminSA.runCommand({enableSharding: "test2", primaryShard: s.shard1.shardName});
|
|
|
|
adminSA.runCommand({shardCollection: ns, key: {_id: 1}});
|
|
|
|
try {
|
|
s.stopBalancer();
|
|
} catch (e) {
|
|
print("coundn't stop balancer via command");
|
|
}
|
|
|
|
adminSA.settings.update({_id: 'balancer'}, {$set: {stopped: true}});
|
|
|
|
var db = mongosA.getDB("test");
|
|
var coll = db.coll;
|
|
var coll2 = db.coll2;
|
|
|
|
let numDocs = 10;
|
|
for (var i = 1; i < numDocs; i++) {
|
|
coll.insert({_id: i, control: 0});
|
|
coll2.insert({_id: i, control: 0});
|
|
}
|
|
|
|
debug("Inserted docs, now split chunks");
|
|
|
|
adminSA.runCommand({split: ns, find: {_id: 3}});
|
|
adminSA.runCommand({movechunk: ns, find: {_id: 10}, to: "s.shard1.shardName"});
|
|
|
|
var command = 'printjson(db.coll.update({ _id: 9 }, { $set: { a: "9" }}, true));';
|
|
|
|
// without this first query through mongo, the second time doesn't "fail"
|
|
debug("Try query first time");
|
|
runMongoProgram("mongo", "--quiet", "--port", "" + s._mongos[1].port, "--eval", command);
|
|
|
|
var res = mongosB.getDB("test").coll2.update({_id: 0}, {$set: {c: "333"}});
|
|
assert.eq(0, res.nModified);
|
|
|
|
s.stop();
|