diff options
author | Aaron <aaron@10gen.com> | 2012-03-12 13:21:57 -0700 |
---|---|---|
committer | Aaron <aaron@10gen.com> | 2012-03-12 13:21:57 -0700 |
commit | 6ad63a8ab7a215c607ffd8f545cbf1be8854952b (patch) | |
tree | ce79dad0402d9db52e7715c2aa224b6c8d838543 /jstests | |
parent | 66ad20abd4d99d811cddd354d4958123ef3e4233 (diff) | |
download | mongo-6ad63a8ab7a215c607ffd8f545cbf1be8854952b.tar.gz |
SERVER-4150 add test for MaxBytesToReturnToClientAtOnce size limit
Diffstat (limited to 'jstests')
-rw-r--r-- | jstests/find9.js | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/jstests/find9.js b/jstests/find9.js new file mode 100644 index 00000000000..85adf93cc98 --- /dev/null +++ b/jstests/find9.js @@ -0,0 +1,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(); +} |