summaryrefslogtreecommitdiff
path: root/jstests/core/uniqueness.js
blob: 124748a91f444e5efbada176c671a42d89e80a1b (plain)
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
var res;

t = db.jstests_uniqueness;

t.drop();

// test uniqueness of _id

res = t.save( { _id : 3 } );
assert.writeOK( res );

// this should yield an error
res = t.insert( { _id : 3 } );
assert.writeError( res );
assert.eq( 1, t.count() );

res = t.insert( { _id : 4, x : 99 } );
assert.writeOK( res );

// this should yield an error
res = t.update( { _id : 4 } , { _id : 3, x : 99 } );
assert.writeError( res );
assert( t.findOne( {_id:4} ) );

// Check for an error message when we index and there are dups
db.jstests_uniqueness2.drop();
db.jstests_uniqueness2.insert({a:3});
db.jstests_uniqueness2.insert({a:3});
assert.eq( 2, db.jstests_uniqueness2.count() );
res = db.jstests_uniqueness2.ensureIndex({a:1}, true);
assert.commandFailed( res );
assert( res.errmsg.match( /E11000/ ) );

// Check for an error message when we index in the background and there are dups
db.jstests_uniqueness2.drop();
db.jstests_uniqueness2.insert({a:3});
db.jstests_uniqueness2.insert({a:3});
assert.eq( 2, db.jstests_uniqueness2.count() );
res = db.jstests_uniqueness2.ensureIndex({a:1}, {unique:true,background:true});
assert.commandFailed( res );
assert( res.errmsg.match( /E11000/ ) );

/* Check that if we update and remove _id, it gets added back by the DB */

/* - test when object grows */
t.drop();
t.save( { _id : 'Z' } );
t.update( {}, { k : 2 } );
assert.eq( 'Z', t.findOne()._id, "uniqueness.js problem with adding back _id" );

/* - test when doesn't grow */
t.drop();
t.save( { _id : 'Z', k : 3 } );
t.update( {}, { k : 2 } );
assert.eq( 'Z', t.findOne()._id, "uniqueness.js problem with adding back _id (2)" );