diff options
author | Randolph Tan <randolph@10gen.com> | 2014-01-14 14:09:42 -0500 |
---|---|---|
committer | Randolph Tan <randolph@10gen.com> | 2014-02-28 16:26:33 -0500 |
commit | 5595b945603b0712c537787e31e6da661c424fee (patch) | |
tree | 90945ee3fe4931032f3af2d397bb755fbf5d30ef /jstests/core/create_indexes.js | |
parent | cd62080dcb036e83f8fca6d68d9bcab67bf7a21c (diff) | |
download | mongo-5595b945603b0712c537787e31e6da661c424fee.tar.gz |
SERVER-12127 migrate js tests to jscore suite when not related to writes
Moved test jstest/[a-i].js -> jstests/core/ and made changes to comply with write command api
Diffstat (limited to 'jstests/core/create_indexes.js')
-rw-r--r-- | jstests/core/create_indexes.js | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/jstests/core/create_indexes.js b/jstests/core/create_indexes.js new file mode 100644 index 00000000000..6c54c4de0cb --- /dev/null +++ b/jstests/core/create_indexes.js @@ -0,0 +1,83 @@ +t = db.create_indexes; +t.drop(); + +// TODO: revisit this after createIndexes api stabilizes. +var isMongos = ("isdbgrid" == db.runCommand("ismaster").msg); +var extractResult = function(obj) { + if (!isMongos) return obj; + + // Sample mongos format: + // { + // raw: { + // "localhost:30000": { + // createdCollectionAutomatically: false, + // numIndexesBefore: 3, + // numIndexesAfter: 5, + // ok: 1 + // } + // }, + // ok: 1 + // } + + var numFields = 0; + var result = null; + for (var field in obj.raw) { + result = obj.raw[field]; + numFields++; + } + + assert.neq(null, result); + assert.eq(1, numFields); + return result; +}; + + +res = t.runCommand( "createIndexes", { indexes : [ { key : { "x" : 1 }, name : "x_1" } ] } ); +res = extractResult( res ); +assert( res.createdCollectionAutomatically ); +assert.eq( 1, res.numIndexesBefore ); +assert.eq( 2, res.numIndexesAfter ); + +res = t.runCommand( "createIndexes", { indexes : [ { key : { "x" : 1 }, name : "x_1" } ] } ); +res = extractResult( res ); +assert.eq( 2, res.numIndexesBefore ); +assert( res.noChangesMade ); + +res = t.runCommand( "createIndexes", { indexes : [ { key : { "x" : 1 }, name : "x_1" }, + { key : { "y" : 1 }, name : "y_1" } ] } ); +res = extractResult( res ); +assert( !res.createdCollectionAutomatically ); +assert.eq( 2, res.numIndexesBefore ); +assert.eq( 3, res.numIndexesAfter ); + +res = t.runCommand( "createIndexes", { indexes : [ { key : { "a" : 1 }, name : "a_1" }, + { key : { "b" : 1 }, name : "b_1" } ] } ); +res = extractResult( res ); +assert( !res.createdCollectionAutomatically ); +assert.eq( 3, res.numIndexesBefore ); +assert.eq( 5, res.numIndexesAfter ); + +res = t.runCommand( "createIndexes", { indexes : [ { key : { "a" : 1 }, name : "a_1" }, + { key : { "b" : 1 }, name : "b_1" } ] } ); +res = extractResult( res ); +assert.eq( 5, res.numIndexesBefore ); +assert( res.noChangesMade ); + +res = t.runCommand( "createIndexes", { indexes : [ {} ] } ); +assert( !res.ok ); + +res = t.runCommand( "createIndexes", { indexes : [ {} , { key : { m : 1 }, name : "asd" } ] } ); +assert( !res.ok ); + +assert.eq( 5, t.getIndexes().length ); + +res = t.runCommand( "createIndexes", + { indexes : [ { key : { "c" : 1 }, sparse : true, name : "c_1" } ] } ) +assert.eq( 6, t.getIndexes().length ); +assert.eq( 1, t.getIndexes().filter( function(z){ return z.sparse; } ).length ); + +res = t.runCommand( "createIndexes", + { indexes : [ { key : { "x" : "foo" }, name : "x_1" } ] } ); +assert( !res.ok ) + +assert.eq( 6, t.getIndexes().length ); |