diff options
author | Siyuan Zhou <siyuan.zhou@mongodb.com> | 2014-02-19 12:45:53 -0500 |
---|---|---|
committer | Matt Kangas <matt.kangas@mongodb.com> | 2014-03-03 22:54:10 -0500 |
commit | 3660343e0b4627d2fee4afb89b74d32644d16d18 (patch) | |
tree | ffa571e0b73ce56d73c2ae23f458f0db772ef782 /jstests/core/pullall.js | |
parent | 9fae141a1f3fe652fa6002e47722c5ceb051cffb (diff) | |
download | mongo-3660343e0b4627d2fee4afb89b74d32644d16d18.tar.gz |
SERVER-12127 migrate js tests to jscore suite when not related to writes
Migrate js tests starting from j-z.
Include SERVER-12920 Update use_power_of_2.js
Signed-off-by: Matt Kangas <matt.kangas@mongodb.com>
Diffstat (limited to 'jstests/core/pullall.js')
-rw-r--r-- | jstests/core/pullall.js | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/jstests/core/pullall.js b/jstests/core/pullall.js new file mode 100644 index 00000000000..7dd932c4bbf --- /dev/null +++ b/jstests/core/pullall.js @@ -0,0 +1,31 @@ +t = db.jstests_pullall; +t.drop(); + +t.save( { a: [ 1, 2, 3 ] } ); +t.update( {}, { $pullAll: { a: [ 3 ] } } ); +assert.eq( [ 1, 2 ], t.findOne().a ); +t.update( {}, { $pullAll: { a: [ 3 ] } } ); +assert.eq( [ 1, 2 ], t.findOne().a ); + +t.drop(); +t.save( { a: [ 1, 2, 3 ] } ); +t.update( {}, { $pullAll: { a: [ 2, 3 ] } } ); +assert.eq( [ 1 ], t.findOne().a ); +t.update( {}, { $pullAll: { a: [] } } ); +assert.eq( [ 1 ], t.findOne().a ); +t.update( {}, { $pullAll: { a: [ 1, 5 ] } } ); +assert.eq( [], t.findOne().a ); + +// SERVER-6047: $pullAll creates empty nested docs for dotted fields +// that don't exist. +t.drop() +t.save({ m : 1 } ); +t.update( { m : 1 }, { $pullAll : { 'a.b' : [ 1 ] } } ); +assert( ('a' in t.findOne()) == false ); +// Non-obvious bit: the implementation of non-in-place update +// might do different things depending on whether the "new" field +// comes before or after existing fields in the document. +// So for now it's worth testing that too. Sorry, future; blame the past. +t.update( { m : 1 }, { $pullAll : { 'x.y' : [ 1 ] } } ); +assert( ('z' in t.findOne()) == false ); +// End SERVER-6047 |