Files
mongo/jstests/core/removea.js
Jack Mulrow 00d92ece19 SERVER-31194 Add jscore tags for retryable_writes_jscore_stepdown_passthrough.yml suite
The actual suite will come in a follow-up commit.
2017-12-07 14:36:15 -05:00

34 lines
1020 B
JavaScript

// @tags: [requires_non_retryable_writes]
// Test removal of a substantial proportion of inserted documents. SERVER-3803
// A complete test will only be performed against a DEBUG build.
t = db.jstests_removea;
Random.setRandomSeed();
for (v = 0; v < 2; ++v) { // Try each index version.
t.drop();
t.ensureIndex({a: 1}, {v: v});
S = 100;
B = 100;
for (var x = 0; x < S; x++) {
var batch = [];
for (var y = 0; y < B; y++) {
var i = y + (B * x);
batch.push({a: i});
}
t.insert(batch);
}
assert.eq(t.count(), S * B);
toDrop = [];
for (i = 0; i < S * B; ++i) {
toDrop.push(Random.randInt(10000)); // Dups in the query will be ignored.
}
// Remove many of the documents; $atomic prevents use of a ClientCursor, which would invoke a
// different bucket deallocation procedure than the one to be tested (see SERVER-4575).
var res = t.remove({a: {$in: toDrop}, $atomic: true});
assert.writeOK(res);
}