summaryrefslogtreecommitdiff
path: root/jstests/core/bulk_insert_capped.js
blob: 50cc8f460dd8237137c49861ee2a07398bc58302 (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
// @tags: [
//     requires_capped,
//     # Cannot implicitly shard accessed collections because of collection existing when none
//     # expected.
//     assumes_no_implicit_collection_creation_after_drop,
// ]

// SERVER-21488 Test that multi inserts into capped collections don't cause corruption.
// Note: this file must have a name that starts with "bulk" so it gets run by bulk_gle_passthrough.
(function() {
    "use strict";
    var t = db.capped_multi_insert;
    t.drop();

    db.createCollection(t.getName(), {capped: true, size: 16 * 1024, max: 1});

    t.insert([{_id: 1}, {_id: 2}]);
    assert.gleSuccess(db);

    // Ensure the collection is valid.
    var res = t.validate(true);
    assert(res.valid, tojson(res));

    // Ensure that various ways of iterating the collection only return one document.
    assert.eq(t.find().itcount(), 1);                             // Table scan.
    assert.eq(t.find({}, {_id: 1}).hint({_id: 1}).itcount(), 1);  // Index only (covered).
    assert.eq(t.find().hint({_id: 1}).itcount(), 1);              // Index scan with fetch.

    // Ensure that the second document is the one that is kept.
    assert.eq(t.findOne(), {_id: 2});
}());