summaryrefslogtreecommitdiff
path: root/jstests/find9.js
diff options
context:
space:
mode:
authorAaron <aaron@10gen.com>2012-03-12 13:21:57 -0700
committerAaron <aaron@10gen.com>2012-03-12 13:21:57 -0700
commit6ad63a8ab7a215c607ffd8f545cbf1be8854952b (patch)
treece79dad0402d9db52e7715c2aa224b6c8d838543 /jstests/find9.js
parent66ad20abd4d99d811cddd354d4958123ef3e4233 (diff)
downloadmongo-6ad63a8ab7a215c607ffd8f545cbf1be8854952b.tar.gz
SERVER-4150 add test for MaxBytesToReturnToClientAtOnce size limit
Diffstat (limited to 'jstests/find9.js')
-rw-r--r--jstests/find9.js28
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();
+}