summaryrefslogtreecommitdiff
path: root/jstests/core/find9.js
blob: 85adf93cc981e1c446645721c6472f9615a00991 (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 < 20; ++i ) {
    t.save( { a:i, b:big } );
}

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

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

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

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