t = db.update_addToSet1; t.drop(); o = { _id: 1, a: [2, 1] }; t.insert(o); assert.eq(o, t.findOne(), "A1"); t.update({}, {$addToSet: {a: 3}}); o.a.push(3); assert.eq(o, t.findOne(), "A2"); t.update({}, {$addToSet: {a: 3}}); assert.eq(o, t.findOne(), "A3"); // SERVER-628 t.update({}, {$addToSet: {a: {$each: [3, 5, 6]}}}); o.a.push(5); o.a.push(6); assert.eq(o, t.findOne(), "B1"); t.drop(); o = { _id: 1, a: [3, 5, 6] }; t.insert(o); t.update({}, {$addToSet: {a: {$each: [3, 5, 6]}}}); assert.eq(o, t.findOne(), "B2"); t.drop(); t.update({_id: 1}, {$addToSet: {a: {$each: [3, 5, 6]}}}, true); assert.eq(o, t.findOne(), "B3"); t.update({_id: 1}, {$addToSet: {a: {$each: [3, 5, 6]}}}, true); assert.eq(o, t.findOne(), "B4"); // SERVER-630 t.drop(); t.update({_id: 2}, {$addToSet: {a: 3}}, true); assert.eq(1, t.count(), "C1"); assert.eq({_id: 2, a: [3]}, t.findOne(), "C2"); // SERVER-3245 o = { _id: 1, a: [1, 2] }; t.drop(); t.update({_id: 1}, {$addToSet: {a: {$each: [1, 2]}}}, true); assert.eq(o, t.findOne(), "D1"); t.drop(); t.update({_id: 1}, {$addToSet: {a: {$each: [1, 2, 1, 2]}}}, true); assert.eq(o, t.findOne(), "D2"); t.drop(); t.insert({_id: 1}); t.update({_id: 1}, {$addToSet: {a: {$each: [1, 2, 2, 1]}}}); assert.eq(o, t.findOne(), "D3"); t.update({_id: 1}, {$addToSet: {a: {$each: [3, 2, 2, 3, 3]}}}); o.a.push(3); assert.eq(o, t.findOne(), "D4");