1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
//Test applyops upsert flag SERVER-7452
var t = db.apply_ops2;
t.drop();
assert.eq(0, t.find().count(), "test collection not empty");
t.insert({_id:1, x:"init"});
//alwaysUpsert = true
print("Testing applyOps with alwaysUpsert = true");
var res = db.runCommand({ applyOps: [
{
op: "u",
ns: t.getFullName(),
o2 : { _id: 1 },
o: { $set: { x: "upsert=true existing" }}
},
{
op: "u",
ns: t.getFullName(),
o2: { _id: 2 },
o: { $set : { x: "upsert=true non-existing" }}
}], alwaysUpsert: true });
assert.eq(true, res.results[0], "upsert = true, existing doc update failed");
assert.eq(true, res.results[1], "upsert = true, nonexisting doc not upserted");
assert.eq(2, t.find().count(), "2 docs expected after upsert");
//alwaysUpsert = false
print("Testing applyOps with alwaysUpsert = false");
res = db.runCommand({ applyOps: [
{
op: "u",
ns: t.getFullName(),
o2: { _id: 1 },
o: { $set : { x: "upsert=false existing" }}
},
{
op: "u",
ns: t.getFullName(),
o2: { _id: 3 },
o: { $set: { x: "upsert=false non-existing" }}
}], alwaysUpsert: false });
assert.eq(true, res.results[0], "upsert = false, existing doc update failed");
assert.eq(false, res.results[1], "upsert = false, nonexisting doc upserted");
assert.eq(2, t.find().count(), "2 docs expected after upsert failure");
//alwaysUpsert not specified, should default to true
print("Testing applyOps with default alwaysUpsert");
res = db.runCommand({ applyOps: [
{
op: "u",
ns: t.getFullName(),
o2: { _id: 1 },
o: { $set: { x: "upsert=default existing" }}
},
{
op: "u",
ns: t.getFullName(),
o2: { _id: 4 },
o: { $set: { x: "upsert=defaults non-existing" }}
}]});
assert.eq(true, res.results[0], "default upsert, existing doc update failed");
assert.eq(true, res.results[1], "default upsert, nonexisting doc not upserted");
assert.eq(3, t.find().count(), "2 docs expected after upsert failure");
|