summaryrefslogtreecommitdiff
path: root/jstests/sharding/move_chunk_remove_with_write_retryability.js
blob: 64d1f5d2dee2197a561a76101ac5e97f702bed71 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
load("jstests/sharding/move_chunk_with_session_helper.js");

(function() {

    "use strict";

    var st = new ShardingTest({shards: {rs0: {nodes: 2}, rs1: {nodes: 2}}});
    assert.commandWorked(st.s.adminCommand({enableSharding: 'test'}));
    st.ensurePrimaryShard('test', st.shard0.shardName);

    var coll = 'delete';
    var cmd = {
        delete: coll,
        deletes: [{q: {x: 10}, limit: 1}, {q: {x: 20}, limit: 1}],
        ordered: false,
        lsid: {id: UUID()},
        txnNumber: NumberLong(36),
    };
    var setup = function(coll) {
        var bulk = coll.initializeUnorderedBulkOp();
        for (let i = 0; i < 10; i++) {
            bulk.insert({x: 10});
            bulk.insert({x: 20});
        }
        assert.writeOK(bulk.execute());
    };
    var checkRetryResult = function(result, retryResult) {
        assert.eq(result.ok, retryResult.ok);
        assert.eq(result.n, retryResult.n);
        assert.eq(result.writeErrors, retryResult.writeErrors);
        assert.eq(result.writeConcernErrors, retryResult.writeConcernErrors);
    };
    var checkDocuments = function(coll) {
        assert.eq(9, coll.find({x: 10}).itcount());
        assert.eq(9, coll.find({x: 20}).itcount());
    };

    testMoveChunkWithSession(st, coll, cmd, setup, checkRetryResult, checkDocuments);

    st.stop();
})();