summaryrefslogtreecommitdiff
path: root/jstests/core/find9.js
blob: 1c56e8c850d0970a2f0b9ff04c99f99dbcad7b52 (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
// Test that the MaxBytesToReturnToClientAtOnce limit is enforced.

t = db.jstests_find9;
t.drop();

big = new Array(500000).toString();
for (i = 0; i < 60; ++i) {
    t.save({a: i, b: big});
}

// Check size limit with a simple query.
assert.eq(60, t.find({}, {a: 1}).objsLeftInBatch());  // Projection resizes the result set.
assert.gt(60, t.find().objsLeftInBatch());

// Check size limit on a query with an explicit batch size.
assert.eq(60, t.find({}, {a: 1}).batchSize(80).objsLeftInBatch());
assert.gt(60, t.find().batchSize(80).objsLeftInBatch());

for (i = 0; i < 60; ++i) {
    t.save({a: i, b: big});
}

// Check size limit with get more.
c = t.find().batchSize(80);
while (c.hasNext()) {
    assert.gt(60, c.objsLeftInBatch());
    c.next();
}